Difference between revisions of "Vnx-rootfsubuntu"
Line 3: | Line 3: | ||
== Basic installation == | == Basic installation == | ||
− | Follow this procedure to create a KVM Ubuntu based root filesystem for VNX. The procedure has been tested with Ubuntu 9.10, 10.04, 10.10, 11.04, 12.04, 13.04, 13.10, 14.04, 14.10, 15.04 | + | Follow this procedure to create a KVM Ubuntu based root filesystem for VNX. The procedure has been tested with Ubuntu 9.10, 10.04, 10.10, 11.04, 12.04, 13.04, 13.10, 14.04, 14.10, 15.04, 15.10 and 16.04. |
<ul> | <ul> | ||
<li>Create the filesystem disk image:</li> | <li>Create the filesystem disk image:</li> | ||
qemu-img create -f qcow2 vnx_rootfs_kvm_ubuntu.qcow2 20G | qemu-img create -f qcow2 vnx_rootfs_kvm_ubuntu.qcow2 20G | ||
<li>Get Ubuntu installation CD. For example:</li> | <li>Get Ubuntu installation CD. For example:</li> | ||
− | wget ftp://ftp.rediris.es/mirror/ubuntu-releases/ | + | wget ftp://ftp.rediris.es/mirror/ubuntu-releases/16.04/ubuntu-16.04-server-i386.iso |
− | cp ubuntu- | + | cp ubuntu-16.04-server-i386.iso /almacen/iso |
Note: use 'server' or 'desktop' CD versions depending on the system you want to create. | Note: use 'server' or 'desktop' CD versions depending on the system you want to create. | ||
<li>Create the virtual machine with:</li> | <li>Create the virtual machine with:</li> | ||
− | vnx --create-rootfs vnx_rootfs_kvm_ubuntu.qcow2 --install-media /almacen/iso/ubuntu- | + | vnx --create-rootfs vnx_rootfs_kvm_ubuntu.qcow2 --install-media /almacen/iso/ubuntu-16.04-server-i386.iso --mem 512M |
Note: add '''"--arch x86_64"''' option for 64 bits virtual machines | Note: add '''"--arch x86_64"''' option for 64 bits virtual machines | ||
<li>Follow Ubuntu installation menus to install a basic system with ssh server.</li> | <li>Follow Ubuntu installation menus to install a basic system with ssh server.</li> | ||
− | <li>Configure a serial console on ttyS0 (skip this step for 15.04 | + | <li>Configure a serial console on ttyS0 (skip this step for 15.04 or later releases):</li> |
cd /etc/init | cd /etc/init | ||
cp tty1.conf ttyS0.conf | cp tty1.conf ttyS0.conf | ||
Line 23: | Line 23: | ||
GRUB_TIMEOUT=0 | GRUB_TIMEOUT=0 | ||
GRUB_RECORDFAIL_TIMEOUT=1 | GRUB_RECORDFAIL_TIMEOUT=1 | ||
− | <li>Only for Ubuntu 15.10:</li> | + | <li>Only for Ubuntu 15.10 or later releases:</li> |
GRUB_CMDLINE_LINUX="net.ifnames=0 biosdevname=0" | GRUB_CMDLINE_LINUX="net.ifnames=0 biosdevname=0" | ||
<li>Make grub process the previous changes:</li> | <li>Make grub process the previous changes:</li> |
Revision as of 17:46, 7 May 2016
How to create a KVM Ubuntu root filesystem for VNX
Contents
[hide]Basic installation
Follow this procedure to create a KVM Ubuntu based root filesystem for VNX. The procedure has been tested with Ubuntu 9.10, 10.04, 10.10, 11.04, 12.04, 13.04, 13.10, 14.04, 14.10, 15.04, 15.10 and 16.04.
- Create the filesystem disk image:
qemu-img create -f qcow2 vnx_rootfs_kvm_ubuntu.qcow2 20G
wget ftp://ftp.rediris.es/mirror/ubuntu-releases/16.04/ubuntu-16.04-server-i386.iso cp ubuntu-16.04-server-i386.iso /almacen/iso
Note: use 'server' or 'desktop' CD versions depending on the system you want to create.
vnx --create-rootfs vnx_rootfs_kvm_ubuntu.qcow2 --install-media /almacen/iso/ubuntu-16.04-server-i386.iso --mem 512M
Note: add "--arch x86_64" option for 64 bits virtual machines
cd /etc/init cp tty1.conf ttyS0.conf sed -i -e 's/tty1/ttyS0/' ttyS0.conf
GRUB_CMDLINE_LINUX_DEFAULT="console=ttyS0" GRUB_TIMEOUT=0 GRUB_RECORDFAIL_TIMEOUT=1
GRUB_CMDLINE_LINUX="net.ifnames=0 biosdevname=0"
update-grub
rm /etc/udev/rules.d/70-persistent-net.rules halt -p
Configuration
- Restart the system with the following command:
vnx --modify-rootfs vnx_rootfs_kvm_ubuntu.qcow2 --update-aced --mem 512M
Note: add "--arch x86_64" option for 64 bits virtual machines Note: ignore the errors "timeout waiting for response on VM socket". 768M are needed if you are installing a root filesystem with desktop interface
virsh console vnx_rootfs_kvm_ubuntu.qcow2
sudo su
apt-get update apt-get dist-upgrade
apt-get install libxml-libxml-perl libnetaddr-ip-perl acpid
mount /dev/sdb /mnt/ perl /mnt/vnxaced-lf/install_vnxaced
- Minimal:
# recommended option sudo apt-get install lubuntu-desktop # old recipe not tested in later versions sudo apt-get install xorg gnome-core gksu gdm gnome-system-tools gnome-nettool firefox-gnome-support
sudo apt-get install ubuntu-desktop
Note: to avoid nautilus being launched any time you remotely execute a command on the virtual machine using VNX (which interferes with the normal execution of commands), you should disable the start of programs when media insertion takes place. Go to "System settings->System->Details->Removable Media" and deselect the checkbox "Never prompt or start programs on media insertion".
- Apache server:
sudo apt-get install apache2 update-rc.d -f apache2 remove # to avoid automatic start
sudo apt-get install traceroute sudo apt-get install xterm # needed to have the 'resize' tool to resize consoles
VER=v0.25 OS=Ubuntu 15.04 DESC=Basic Ubuntu 15.04 root filesystem without GUI
sudo vnx_halt
If everything went well, your root filesystem will be ready to be used with VNX. You can make a simple test using the simple_ubuntu.xml scenario distributed with VNX.
Installing additional software
To install additional software or to modify your root file system, you just have to:
- Start a virtual machine from it:
vnx --modify-rootfs vnx_rootfs_kvm_ubuntu.qcow2
dhclient eth0
Note: use "ip link show" to know which network interface to use.
vnx_halt
Examples
- dhcp server and relay:
- Install dhcp3 packages:
apt-get install dhcp3-server dhcp3-relay
update-rc.d -f isc-dhcp-server remove update-rc.d -f isc-dhcp-relay remove
Updating VNXACED
You can automatically update the VNXACE daemon with the following command:
vnx --modify-rootfs vnx_rootfs_kvm_ubuntu.qcow2 --update-aced -y
If VNXACE daemon is not updated automatically, you can do it manually by accessing the virtual machine console and type:
mount /dev/sdb /mnt/ perl /mnt/vnxaced-lf/install_vnxaced
Known problems
- Sometimes after restarting, the virtual machines stop at showing the grub menu and do not start until you manually choose one option. To avoid it, just follow the instructions here: http://www.linuxquestions.org/questions/linux-server-73/how-to-disable-grub-2-menu-even-after-server-crash-796562/. Beware that the changes you make to grub.cfg file are lost after executing "update-grub" command.
- In Ubuntu 12.04 Desktop, graphical commands execution does not work. Command execution fails with "ERROR: no user logged on display :0.0" (see /var/log/vnxaced.log). If you just open a "terminal" window, commands work correctly (does not work if you open other applications; only when you start a terminal...).
- Each time a cdrom is mounted (for example, whenever a command is executed on the virtual machine) the following error appears in the console:
Jul 27 22:33:31 vnx kernel: [ 4384.875886] ata1.01: exception Emask 0x0 SAct 0x0 SErr 0x0 action 0x6 Jul 27 22:33:31 vnx kernel: [ 4385.291374] ata1.01: BMDMA stat 0x5 Jul 27 22:33:31 vnx kernel: [ 4385.493411] sr 0:0:1:0: [sr0] CDB: Read(10): 28 00 00 00 00 18 00 00 01 00 Jul 27 22:33:31 vnx kernel: [ 4385.493460] ata1.01: cmd a0/01:00:00:00:08/00:00:00:00:00/b0 tag 0 dma 2048 in Jul 27 22:33:31 vnx kernel: [ 4385.493461] res 01/60:00:00:00:08/00:00:00:00:00/b0 Emask 0x3 (HSM violation) Jul 27 22:33:31 vnx kernel: [ 4386.263553] ata1.01: status: { ERR }
Despite of the error trace, the commands are executed correctly. This error does not appear on Ubuntu 9.10 filesystems.