Projet

Général

Profil

Libvirt (ancien) » Historique » Version 58

Mehdi Abaakouk, 10/04/2017 20:41

1 1 Mehdi Abaakouk
h1. Libvirt
2 1 Mehdi Abaakouk
3 12 Mehdi Abaakouk
h2. Resources/Liens
4 12 Mehdi Abaakouk
5 18 Laurent GUERBY
* Virtualisation du routage IPv4 pour les VM http://lists.tetaneutral.net/pipermail/technique/2013-April/000810.html
6 18 Laurent GUERBY
7 12 Mehdi Abaakouk
* libvirt
8 12 Mehdi Abaakouk
9 12 Mehdi Abaakouk
http://builder.virt-tools.org/artifacts/libvirt-virshcmdref/html/index.html
10 12 Mehdi Abaakouk
http://docs.fedoraproject.org/en-US/Fedora/13/html/Virtualization_Guide/chap-Virtualization-Managing_guests_with_virsh.html
11 12 Mehdi Abaakouk
12 12 Mehdi Abaakouk
* virt-install et preseed sans server web et pxe:
13 12 Mehdi Abaakouk
14 12 Mehdi Abaakouk
http://honk.sigxcpu.org/con/Preseeding_Debian_virtual_machines_with_virt_install.html
15 12 Mehdi Abaakouk
16 58 Mehdi Abaakouk
h2. /!\ tetaneutral utilise Openstack maintenant /!\
17 58 Mehdi Abaakouk
18 58 Mehdi Abaakouk
https://chiliproject.tetaneutral.net/projects/tetaneutral/wiki/Openstack_Management_TTNN
19 58 Mehdi Abaakouk
20 28 Mehdi Abaakouk
h2. Backup d'un VM n7
21 28 Mehdi Abaakouk
22 28 Mehdi Abaakouk
sur h2:
23 28 Mehdi Abaakouk
24 29 Mehdi Abaakouk
<pre>
25 28 Mehdi Abaakouk
# VM=XXX.gz; cd /backup/libvirt-n7-vm-raw/20140319/ ; if [ ! -f ${VM} ]; then socat -u tcp4-listen:50555 - > $VM ; zcat $VM | md5sum -; du -hs *; else echo $VM already present;fi
26 29 Mehdi Abaakouk
</pre>
27 28 Mehdi Abaakouk
28 28 Mehdi Abaakouk
sur la machine n7:
29 28 Mehdi Abaakouk
30 29 Mehdi Abaakouk
<pre>
31 28 Mehdi Abaakouk
# virsh shutdown XXX
32 1 Mehdi Abaakouk
# LV=XXX; cat /dev/raid5/$LV | gzip --fast|socat -u - tcp4:h2.tetaneutral.net:50555;md5sum /dev/raid5/$LV
33 29 Mehdi Abaakouk
</pre>
34 28 Mehdi Abaakouk
35 1 Mehdi Abaakouk
h2. Installation VM sans bridge avec routage static (en /32 pour l'ipv4)
36 1 Mehdi Abaakouk
37 28 Mehdi Abaakouk
Note: tous les fichiers utilisés et créés ne sont peut être pas à jour, voir ici pour les dernières version: http://git.tetaneutral.net/libvirt.git/
38 11 Mehdi Abaakouk
39 28 Mehdi Abaakouk
Le répertoire /etc/libvirt/ttnn cité plustard est géré dans ce git.
40 1 Mehdi Abaakouk
41 1 Mehdi Abaakouk
h3. Configuration de la libvirt
42 1 Mehdi Abaakouk
43 28 Mehdi Abaakouk
On créé un réseau libvirt qui fait rien (déjà fait sur n7):
44 1 Mehdi Abaakouk
45 10 Mehdi Abaakouk
<pre>
46 1 Mehdi Abaakouk
cat > libvirt_dump_network.xml <<EOF
47 1 Mehdi Abaakouk
<network ipv6='yes'>
48 6 Mehdi Abaakouk
<name>dump-net</name>
49 1 Mehdi Abaakouk
<bridge name='dumpbr0' />
50 1 Mehdi Abaakouk
</network>
51 1 Mehdi Abaakouk
EOF
52 10 Mehdi Abaakouk
53 1 Mehdi Abaakouk
virsh net-define libvirt_dump_network.xml
54 1 Mehdi Abaakouk
virsh net-autostart dump-net
55 1 Mehdi Abaakouk
virsh net-start dump-net
56 1 Mehdi Abaakouk
</pre>
57 1 Mehdi Abaakouk
58 28 Mehdi Abaakouk
On créé un hook libvirt (déjà fait sur n7):
59 1 Mehdi Abaakouk
<pre>
60 9 Mehdi Abaakouk
mkdir -p /etc/libvirt/ttnn/hooks
61 9 Mehdi Abaakouk
ln -s /etc/libvirt/ttnn/hooks /etc/libvirt/hooks
62 1 Mehdi Abaakouk
vi /etc/libvirt/hooks/qemu
63 1 Mehdi Abaakouk
----8<--------------->8----
64 1 Mehdi Abaakouk
#!/bin/bash
65 1 Mehdi Abaakouk
66 1 Mehdi Abaakouk
name="$1"
67 1 Mehdi Abaakouk
operation="$2"
68 1 Mehdi Abaakouk
suboperation="$3"
69 1 Mehdi Abaakouk
70 7 Mehdi Abaakouk
[ "$operation" != "start" ] && exit 0
71 1 Mehdi Abaakouk
[ "$suboperation" != "begin" ] && exit 0
72 1 Mehdi Abaakouk
73 1 Mehdi Abaakouk
# get interface from the libvirt xml
74 1 Mehdi Abaakouk
interface=$(cat - | sed -ne "/vnet/s/.*dev='\([^']*\)'.*/\1/gp")
75 5 Mehdi Abaakouk
76 5 Mehdi Abaakouk
[ -f /etc/libvirt/ttnn/${name}.conf ] && source /etc/libvirt/ttnn/${name}.conf
77 5 Mehdi Abaakouk
78 1 Mehdi Abaakouk
[ "$ip" -o "$ip6" ] && brctl delif dumpbr0 $interface
79 1 Mehdi Abaakouk
[ "$ip" ] && ip route add $ip/32 dev $interface
80 1 Mehdi Abaakouk
[ "$ip6" ] && ip route add $ip6/56 dev $interface
81 1 Mehdi Abaakouk
[ "$ip6" ] && ip -6 addr add fe80::31/64 dev $interface
82 1 Mehdi Abaakouk
exit 0
83 1 Mehdi Abaakouk
----8<--------------->8----
84 1 Mehdi Abaakouk
</pre>
85 1 Mehdi Abaakouk
86 1 Mehdi Abaakouk
87 4 Mehdi Abaakouk
h3. Preparation de l'installer
88 1 Mehdi Abaakouk
89 28 Mehdi Abaakouk
Pour une squeeze on met à jour virtinst  (déjà fait sur n7):
90 1 Mehdi Abaakouk
91 9 Mehdi Abaakouk
<pre>
92 9 Mehdi Abaakouk
wget http://ftp.us.debian.org/debian/pool/main/v/virtinst/virtinst_0.600.3-3_all.deb
93 1 Mehdi Abaakouk
dpkg -i virtinst_0.600.3-3_all.deb
94 1 Mehdi Abaakouk
</pre>
95 1 Mehdi Abaakouk
96 28 Mehdi Abaakouk
On install le preseed.cfg attaché à la page dans /etc/libvirt/preseed.cfg  (déjà fait sur n7)
97 1 Mehdi Abaakouk
98 1 Mehdi Abaakouk
h4. Installation d'une VM
99 4 Mehdi Abaakouk
100 28 Mehdi Abaakouk
Creation du disk (déjà fait sur n7):
101 1 Mehdi Abaakouk
<pre>
102 1 Mehdi Abaakouk
lvcreate -n picttn -L 50G /dev/raid5
103 1 Mehdi Abaakouk
</pre>
104 5 Mehdi Abaakouk
105 5 Mehdi Abaakouk
Configuration du routage static:
106 5 Mehdi Abaakouk
107 1 Mehdi Abaakouk
<pre>
108 5 Mehdi Abaakouk
vi /etc/libvirt/ttnn/picttn.conf 
109 16 Mehdi Abaakouk
# le /32 ipv4
110 1 Mehdi Abaakouk
ip="91.224.148.252"
111 16 Mehdi Abaakouk
# le /56 ipv6
112 5 Mehdi Abaakouk
ip6="2a01:6600:8080:FC00::"
113 5 Mehdi Abaakouk
</pre>
114 8 Mehdi Abaakouk
115 28 Mehdi Abaakouk
Lancement de l'installation via le réseau natter de libvirt
116 1 Mehdi Abaakouk
<pre>
117 1 Mehdi Abaakouk
virt-install -n picttn -r 2048 --os-type=linux \
118 8 Mehdi Abaakouk
    --autostart \
119 1 Mehdi Abaakouk
    --disk /dev/raid5/picttn,bus=virtio,cache=none,io=native \
120 13 Mehdi Abaakouk
    --network network=default,model=virtio \
121 8 Mehdi Abaakouk
    --nographics \
122 6 Mehdi Abaakouk
    --noreboot \
123 1 Mehdi Abaakouk
    --wait -1 \
124 1 Mehdi Abaakouk
    --location http://ftp.debian.org/debian/dists/wheezy/main/installer-amd64/ \
125 6 Mehdi Abaakouk
    --serial pty \
126 8 Mehdi Abaakouk
    --initrd-inject /etc/libvirt/ttnn/preseed.cfg \
127 7 Mehdi Abaakouk
    --initrd-inject /etc/libvirt/ttnn/picttn.conf \
128 1 Mehdi Abaakouk
    --initrd-inject /etc/libvirt/ttnn/postinstall.sh \
129 1 Mehdi Abaakouk
    --extra-args "console=ttyS0,9600n8 DEBIAN_FRONTEND=text auto priority=critical hostname=picttn domain=le-pic.org"
130 8 Mehdi Abaakouk
</pre>
131 8 Mehdi Abaakouk
132 28 Mehdi Abaakouk
Une fois l'installation terminée, on change la conf réseau:
133 1 Mehdi Abaakouk
134 14 Mehdi Abaakouk
<pre>
135 8 Mehdi Abaakouk
EDITOR="sed -ie s/default/dump-net/g" virsh edit picttn
136 8 Mehdi Abaakouk
</pre>
137 1 Mehdi Abaakouk
138 28 Mehdi Abaakouk
On peux démarrer la VM
139 8 Mehdi Abaakouk
<pre>
140 8 Mehdi Abaakouk
virsh start picttn
141 3 Mehdi Abaakouk
virsh console picttn
142 1 Mehdi Abaakouk
</pre>
143 1 Mehdi Abaakouk
144 28 Mehdi Abaakouk
Ensuite on peux se connecte à la VM
145 17 Laurent GUERBY
<pre>
146 17 Laurent GUERBY
ssh root@2a01:6600:8080:FC00::1
147 17 Laurent GUERBY
</pre>
148 17 Laurent GUERBY
149 28 Mehdi Abaakouk
Le /etc/network/interfaces IPv4 après installation
150 21 Laurent GUERBY
151 21 Laurent GUERBY
<pre>
152 21 Laurent GUERBY
iface eth0 inet static
153 21 Laurent GUERBY
    address 91.224.148.xxx
154 1 Mehdi Abaakouk
    netmask 32
155 1 Mehdi Abaakouk
    up ip route add 91.224.148.0/32 dev eth0
156 1 Mehdi Abaakouk
    up ip route add default via 91.224.148.0
157 1 Mehdi Abaakouk
158 1 Mehdi Abaakouk
iface eth0 inet6 static
159 21 Laurent GUERBY
    address 2a01:6600:8080:xx00::1
160 1 Mehdi Abaakouk
    netmask 56
161 21 Laurent GUERBY
    gateway fe80::31
162 21 Laurent GUERBY
    pre-up /sbin/sysctl -w net.ipv6.conf.eth0.accept_ra=0
163 17 Laurent GUERBY
    pre-up /sbin/sysctl -w net.ipv6.conf.eth0.autoconf=0
164 19 Laurent GUERBY
165 19 Laurent GUERBY
</pre>
166 19 Laurent GUERBY
167 19 Laurent GUERBY
h2. Misc
168 19 Laurent GUERBY
169 28 Mehdi Abaakouk
<H4Mm3r> si tu lance la création de la VM sans avoir créé le disk --disk /vmroot/testnat.qcow2,format=qcow2,size=12,bus=virtio,cache=writeback
170 28 Mehdi Abaakouk
<H4Mm3r> le disk se créé mais dans le XML le format est à RAW
171 28 Mehdi Abaakouk
<H4Mm3r> si tu le créé à l'avance avec qemu-img create -f qcow2
172 19 Laurent GUERBY
<H4Mm3r> et que tu lance ta commande --disk /vmroot/testnat.qcow2,format=qcow2
173 28 Mehdi Abaakouk
<guerby> ok donc c'etait bien ça :)
174 19 Laurent GUERBY
<guerby> bbl (miam)
175 28 Mehdi Abaakouk
<H4Mm3r> dans le fichier XML le format est à RAW
176 28 Mehdi Abaakouk
<H4Mm3r> il faut en effet dumper un XML, modifier la valeur à QCOW2
177 28 Mehdi Abaakouk
<H4Mm3r> et créer la VM depuis ce XML
178 19 Laurent GUERBY
<H4Mm3r> virsh create file.xml
179 20 Joris Michaux
<H4Mm3r> pourqu'enfin il comprenne que c'est du QCOW...
180 28 Mehdi Abaakouk
<H4Mm3r> et là mon disk fait bien 265ko, mais est détecté comme 12G :D
181 20 Joris Michaux
182 20 Joris Michaux
h2. HOWTO by H4Mm3r (under contruction)
183 20 Joris Michaux
184 20 Joris Michaux
h3. Usefull links
185 20 Joris Michaux
186 20 Joris Michaux
#### Misc
187 20 Joris Michaux
188 20 Joris Michaux
#OS Type
189 20 Joris Michaux
http://rhevdup.blogspot.fr/2012/05/list-available-os-types-for-kvm-on-rhel.html
190 20 Joris Michaux
191 20 Joris Michaux
#Libvirt TTN
192 20 Joris Michaux
http://chiliproject.tetaneutral.net/projects/tetaneutral/wiki/Libvirt
193 20 Joris Michaux
194 20 Joris Michaux
#### KVM management
195 20 Joris Michaux
196 20 Joris Michaux
#Install QEMU KVM + LIBVIRT
197 20 Joris Michaux
http://www.howtoforge.com/virtualization-with-kvm-on-a-debian-squeeze-server
198 20 Joris Michaux
199 20 Joris Michaux
#Edit XML file
200 20 Joris Michaux
http://vladnevzorov.com/2011/02/11/how-to-change-configuration-of-kvm-virtual-machine/
201 20 Joris Michaux
202 20 Joris Michaux
#Clone a KVM
203 20 Joris Michaux
https://help.ubuntu.com/community/KVM/CreateGuests#Cloning_a_virtual_machine
204 20 Joris Michaux
http://linux.die.net/man/1/virt-clone
205 20 Joris Michaux
206 20 Joris Michaux
#### Network
207 20 Joris Michaux
208 20 Joris Michaux
#NAT
209 20 Joris Michaux
http://www.linuxquestions.org/questions/linux-networking-3/kvm-qemu-and-nat-on-the-host-machine-mini-tutorial-697980/
210 20 Joris Michaux
http://wiki.libvirt.org/page/Networking
211 20 Joris Michaux
http://libvirt.org/formatnetwork.html#examplesNAT
212 20 Joris Michaux
https://help.ubuntu.com/community/KVM/Networking
213 20 Joris Michaux
214 20 Joris Michaux
#Bridge
215 20 Joris Michaux
http://toast.djw.org.uk/qemu.html
216 20 Joris Michaux
http://www.mediaonfire.com/en/tech_tips/QEMUNetworking.html (bridge, nat, arp)
217 20 Joris Michaux
218 20 Joris Michaux
#### Improve performance
219 20 Joris Michaux
http://blog.bodhizazen.net/linux/improve-kvm-performance/
220 20 Joris Michaux
http://www.linux-kvm.org/page/Tuning_KVM
221 20 Joris Michaux
http://www.ezunix.org/index.php?title=Boost_performance_of_KVM_guests
222 20 Joris Michaux
223 20 Joris Michaux
#### Storage
224 20 Joris Michaux
http://doc.opensuse.org/products/draft/SLES/SLES-kvm_sd_draft/cha.libvirt.storage.html
225 20 Joris Michaux
226 20 Joris Michaux
h3. HOWTO
227 20 Joris Michaux
228 20 Joris Michaux
<pre>
229 20 Joris Michaux
[H] = Host
230 20 Joris Michaux
[G] = Guest
231 20 Joris Michaux
[XML] = XML content
232 20 Joris Michaux
"command"
233 20 Joris Michaux
</pre>
234 20 Joris Michaux
235 20 Joris Michaux
#### Diskfile Storage
236 20 Joris Michaux
237 20 Joris Michaux
#Create qcow2 disk
238 20 Joris Michaux
<pre>
239 20 Joris Michaux
[H] "qemu-img create -f qcow2 /path/to/disk.qcow2 $SIZE" (ex: 20G)
240 20 Joris Michaux
[H] "chmod +x /path/to/disk.qcow2"
241 20 Joris Michaux
</pre>
242 20 Joris Michaux
243 20 Joris Michaux
#Convert raw to qcow2
244 20 Joris Michaux
<pre>
245 20 Joris Michaux
[H] "qemu-img convert -O qcow2 disk.img disk.qcow2"
246 20 Joris Michaux
</pre>
247 20 Joris Michaux
248 20 Joris Michaux
#Disable cache to improve performance 
249 20 Joris Michaux
<pre>
250 20 Joris Michaux
[XML] <driver name='qemu' type='qcow2' cache='none'/>
251 20 Joris Michaux
</pre>
252 20 Joris Michaux
253 20 Joris Michaux
#### LVM Storage
254 20 Joris Michaux
255 20 Joris Michaux
<pre>
256 20 Joris Michaux
[H] Create "/etc/libvirt/storage/vmdata.xml" file :
257 20 Joris Michaux
      <pool type="logical">
258 20 Joris Michaux
        <name>my_pool</name>
259 20 Joris Michaux
        <source>
260 20 Joris Michaux
          <device path="/path/to/dev"/>
261 20 Joris Michaux
        </source>
262 20 Joris Michaux
        <target>
263 20 Joris Michaux
          <path>/target/path/path> (LV will be created there)
264 20 Joris Michaux
        </target>
265 20 Joris Michaux
      </pool>
266 20 Joris Michaux
[H] "virsh pool-define /etc/libvirt/storage/my_pool.xml"
267 20 Joris Michaux
[H] "virsh pool-start my_pool"
268 20 Joris Michaux
[H] "virsh pool-autostart my_pool"
269 20 Joris Michaux
[H] "virsh pool-info my_pool"
270 20 Joris Michaux
[H] "virsh vol-create-as my_pool my_logical_volume 12G"
271 20 Joris Michaux
[H] You must create a LV to be able to give it to a KVM "virsh vol-create-as my_pool my_vol 12G --format=lvm2"
272 20 Joris Michaux
</pre>
273 20 Joris Michaux
274 20 Joris Michaux
h3. Create KVM
275 20 Joris Michaux
276 20 Joris Michaux
#Bridged with TAP + LVM
277 20 Joris Michaux
<pre>
278 20 Joris Michaux
[H] "virt-install -d --hvm --vnc --name=my_kvm --vcpus=4 --cpuset=0-4 --ram 2048 --disk vol=my_pool/my_vol,bus=virtio,cache=none --network bridge=my_bridge,model=virtio -c /path/to/distrib.iso --keymap=fr --os-type=linux --noautoconsole"
279 20 Joris Michaux
</pre>
280 20 Joris Michaux
281 20 Joris Michaux
#TAP (if you want to rename the default "vnetX" interface by "tapX"
282 20 Joris Michaux
<pre>
283 20 Joris Michaux
[H] "virsh dumpxml my_guest > my_guest.xml
284 20 Joris Michaux
[H] "virsh undefine my_guest"
285 20 Joris Michaux
[H] Edit the my_guest.xml file to rename VNETX by TAPX
286 20 Joris Michaux
[H] "virsh define my_guest.xml"
287 20 Joris Michaux
[H] "virsh start my_guest"
288 20 Joris Michaux
</pre>
289 20 Joris Michaux
290 20 Joris Michaux
#NATed + LVM
291 20 Joris Michaux
<pre>
292 20 Joris Michaux
[H] "virt-install -d --hvm --vnc --name=my_kvm --vcpus=4 --cpuset=0-4 --ram 2048 --disk vol=my_pool/my_vol,bus=virtio,cache=none --network network=my_network,model=virtio -c /path/to/distrib.iso --keymap=fr --os-type=linux --noautoconsole"
293 20 Joris Michaux
</pre>
294 20 Joris Michaux
295 20 Joris Michaux
#Clone VM
296 20 Joris Michaux
<pre>
297 20 Joris Michaux
[H] Create the LVM dest
298 20 Joris Michaux
[H] Pause the KVM "virsh suspend my_kvm"
299 20 Joris Michaux
[H] virt-clone -o my_orig_kvm -n my_cloned_kvm -f=/path/to/lvm/dev
300 20 Joris Michaux
[G] Go and change the hostname and resolv.conf
301 20 Joris Michaux
</pre>
302 20 Joris Michaux
303 20 Joris Michaux
h3. Command explanation
304 20 Joris Michaux
305 20 Joris Michaux
#Bridged with tap
306 20 Joris Michaux
<pre>
307 20 Joris Michaux
virt-install -d --hvm --vnc --name=testlvm \
308 20 Joris Michaux
    --vcpus=4 --cpuset=0-4 \
309 20 Joris Michaux
    --ram 2048 \ 
310 20 Joris Michaux
    --disk vol=vmdata/testlvm,bus=virtio,cache=none \
311 20 Joris Michaux
    --network bridge=br0,model=virtio \
312 20 Joris Michaux
    -c /data/isos/debian-testing-amd64-netinst.iso \
313 20 Joris Michaux
    --keymap=fr --os-type=linux --os-variant=debiansqueeze --noautoconsole
314 20 Joris Michaux
</pre>
315 20 Joris Michaux
316 20 Joris Michaux
#NATed
317 20 Joris Michaux
<pre>
318 20 Joris Michaux
virt-install -d --hvm --vnc --name=testlvm \
319 20 Joris Michaux
    --vcpus=4 --cpuset=0-4 \
320 20 Joris Michaux
    --ram 2048 \ 
321 20 Joris Michaux
    --disk vol=vmdata/testlvm,bus=virtio,cache=none \
322 20 Joris Michaux
    --network network=frp_network,model=virtio \
323 20 Joris Michaux
    -c /data/isos/debian-testing-amd64-netinst.iso \
324 20 Joris Michaux
    --keymap=fr --os-type=linux --os-variant=debiansqueeze --noautoconsole
325 20 Joris Michaux
</pre>
326 20 Joris Michaux
327 20 Joris Michaux
[OLD QCOW2]
328 20 Joris Michaux
<pre>
329 20 Joris Michaux
[H] "virt-install --connect qemu:///system -n puppetnode1 -r 1024 --vcpus=4 --cpuset=4-7 --disk path=/vmroot/puppetnode1.qcow2 -c /data/isos/debian-6.0.6-amd64-netinst.iso --vnc --keymap=fr --noautoconsole --os-type linux --os-variant debiansqueeze --accelerate --network network=default --hvm"
330 20 Joris Michaux
[H] "virt-install --connect qemu:///system -n testnat -r 1024 --vcpus=2 --cpuset=2-3 --disk /vmroot/testnat.qcow2,format=qcow2,size=12,bus=virtio,cache=writeback -c /data/isos/debian-6.0.6-amd64-netinst.iso --vnc --keymap=fr --noautoconsole --os-type linux --os-variant debiansqueeze --accelerate --network bridge=br0 --hvm"
331 20 Joris Michaux
</pre>
332 20 Joris Michaux
333 20 Joris Michaux
#Start a KVM
334 20 Joris Michaux
<pre>
335 20 Joris Michaux
[H] "virsh start my_kvm"
336 20 Joris Michaux
</pre>
337 20 Joris Michaux
338 20 Joris Michaux
#Stop node
339 20 Joris Michaux
<pre>
340 20 Joris Michaux
[H] Soft : "virsh shutdown my_kvm"
341 20 Joris Michaux
[H] Hard : "virsh destroy my_kvm"
342 20 Joris Michaux
</pre>
343 20 Joris Michaux
344 20 Joris Michaux
#Suppr node del
345 20 Joris Michaux
<pre>
346 20 Joris Michaux
[H] "virsh undefine node" (+ remove files)
347 20 Joris Michaux
</pre>
348 20 Joris Michaux
349 20 Joris Michaux
#Rename node
350 20 Joris Michaux
<pre>
351 20 Joris Michaux
[H] "virsh dumpxml my_kvm > foo.xml"
352 20 Joris Michaux
[H] <edit foo.xml, change the name, move storage>
353 20 Joris Michaux
[H] "virsh undefine my_kvm"
354 20 Joris Michaux
[H] "virsh define foo.xml"
355 20 Joris Michaux
</pre>
356 20 Joris Michaux
357 20 Joris Michaux
# Connect to virsh qemu
358 20 Joris Michaux
<pre>
359 20 Joris Michaux
[H] "virsh --connect qemu:///system"
360 20 Joris Michaux
[H] "virsh # help"
361 20 Joris Michaux
</pre>
362 20 Joris Michaux
363 20 Joris Michaux
#Start a network
364 20 Joris Michaux
<pre>
365 20 Joris Michaux
[H] "virsh net-start my_network"
366 20 Joris Michaux
</pre>
367 20 Joris Michaux
368 20 Joris Michaux
#Configure VNC
369 20 Joris Michaux
370 20 Joris Michaux
<pre>
371 20 Joris Michaux
[H] Edit /etc/libvirt/qemu.conf and set vnc_listen = "your.ip.addd"
372 20 Joris Michaux
[H] You need to restart service "/etc/init.d/libvirtd restart"
373 20 Joris Michaux
[H] "ps aux | grep -i kvm" (find vnc display for your KVM)
374 20 Joris Michaux
</pre>
375 20 Joris Michaux
376 20 Joris Michaux
#Connect to a KVM through VNC
377 20 Joris Michaux
378 20 Joris Michaux
<pre>
379 20 Joris Michaux
tightvncviewer -compresslevel 7 -encodings "copyrect tight hextile zlib corre rre raw" x.xxx.xxx.xxx:x
380 20 Joris Michaux
</pre>
381 20 Joris Michaux
382 20 Joris Michaux
#Keyboard FR for KVM
383 20 Joris Michaux
<pre>
384 20 Joris Michaux
[H] "virsh edit my_kvm"
385 20 Joris Michaux
[XML] <graphics type='vnc' port='-1' autoport='yes' keymap='fr'/>
386 20 Joris Michaux
</pre>
387 20 Joris Michaux
388 20 Joris Michaux
#Create your own NAT network
389 20 Joris Michaux
<pre>
390 20 Joris Michaux
[H] Create your_nat.xml file :
391 20 Joris Michaux
[XML] <network>
392 20 Joris Michaux
  <name>frp_network</name>
393 20 Joris Michaux
  <forward mode='nat'/>
394 20 Joris Michaux
  <bridge name='br1' stp='on' delay='0' />
395 20 Joris Michaux
  <ip address='10.16.42.1' netmask='255.255.255.0'>
396 20 Joris Michaux
    <dhcp>
397 20 Joris Michaux
      <range start='10.16.42.2' end='10.16.42.50' />
398 20 Joris Michaux
    </dhcp>
399 20 Joris Michaux
  </ip>
400 20 Joris Michaux
</network>
401 20 Joris Michaux
[H] "virsh net-define your_nat.xml"
402 20 Joris Michaux
[H] "virsh net-start your_nat.xml"
403 20 Joris Michaux
[H] "virsh net-autostart your_nat.xml"
404 20 Joris Michaux
[XML] Network type "interface type = network, source network=your_nat"
405 20 Joris Michaux
</pre>
406 20 Joris Michaux
407 20 Joris Michaux
#IBM advisements to improve performance
408 20 Joris Michaux
<pre>
409 20 Joris Michaux
[H] Use LVM (or other direct access to HDD) for VMs storage (from 45 to 3' to install a VM)
410 20 Joris Michaux
[H] Set the swappiness value to 0 ("echo 0 > /proc/sys/vm/swappiness" && edit "/etc/sysctl.conf" and add "vm.swappiness=0")
411 20 Joris Michaux
[H] Disable zone_reclaim ("echo 0 > /proc/sys/vm/zone_reclaim_mode" && edit "/etc/sysctl.conf" and add "vm.zone_reclaim_mode=0")
412 22 Mehdi Abaakouk
[H] Enable KSM ("echo 1 > /sys/kernel/mm/ksm/run") and set the check time to 200ms ("echo 200 > /sys/kernel/mm/ksm/sleep_millisecs")
413 22 Mehdi Abaakouk
</pre>
414 22 Mehdi Abaakouk
415 22 Mehdi Abaakouk
416 22 Mehdi Abaakouk
417 22 Mehdi Abaakouk
h2. PC velizy
418 22 Mehdi Abaakouk
419 22 Mehdi Abaakouk
420 22 Mehdi Abaakouk
<pre>
421 22 Mehdi Abaakouk
root@tetaneutral1:~# fdisk /dev/sdb
422 22 Mehdi Abaakouk
423 22 Mehdi Abaakouk
Command (m for help): p
424 22 Mehdi Abaakouk
425 22 Mehdi Abaakouk
Disk /dev/sdb: 2000.4 GB, 2000398934016 bytes
426 22 Mehdi Abaakouk
255 heads, 63 sectors/track, 243201 cylinders, total 3907029168 sectors
427 22 Mehdi Abaakouk
Units = sectors of 1 * 512 = 512 bytes
428 22 Mehdi Abaakouk
Sector size (logical/physical): 512 bytes / 512 bytes
429 22 Mehdi Abaakouk
I/O size (minimum/optimal): 512 bytes / 512 bytes
430 22 Mehdi Abaakouk
Disk identifier: 0x9bf0c7df
431 22 Mehdi Abaakouk
432 22 Mehdi Abaakouk
   Device Boot      Start         End      Blocks   Id  System
433 22 Mehdi Abaakouk
434 22 Mehdi Abaakouk
Command (m for help): n
435 22 Mehdi Abaakouk
Partition type:
436 22 Mehdi Abaakouk
   p   primary (0 primary, 0 extended, 4 free)
437 22 Mehdi Abaakouk
   e   extended
438 22 Mehdi Abaakouk
Select (default p): p
439 22 Mehdi Abaakouk
Partition number (1-4, default 1): 
440 22 Mehdi Abaakouk
Using default value 1
441 22 Mehdi Abaakouk
First sector (2048-3907029167, default 2048): 
442 22 Mehdi Abaakouk
Using default value 2048
443 22 Mehdi Abaakouk
Last sector, +sectors or +size{K,M,G} (2048-3907029167, default 3907029167): 
444 22 Mehdi Abaakouk
Using default value 3907029167
445 22 Mehdi Abaakouk
446 22 Mehdi Abaakouk
Command (m for help): n
447 22 Mehdi Abaakouk
Partition type:
448 22 Mehdi Abaakouk
   p   primary (1 primary, 0 extended, 3 free)
449 22 Mehdi Abaakouk
   e   extended
450 22 Mehdi Abaakouk
Select (default p): ^C
451 22 Mehdi Abaakouk
root@tetaneutral1:~# fdisk /dev/sdb
452 22 Mehdi Abaakouk
453 22 Mehdi Abaakouk
Command (m for help): n
454 22 Mehdi Abaakouk
Partition type:
455 22 Mehdi Abaakouk
   p   primary (0 primary, 0 extended, 4 free)
456 22 Mehdi Abaakouk
   e   extended
457 22 Mehdi Abaakouk
Select (default p): p
458 22 Mehdi Abaakouk
Partition number (1-4, default 1): 1
459 22 Mehdi Abaakouk
First sector (2048-3907029167, default 2048): 
460 22 Mehdi Abaakouk
Using default value 2048
461 22 Mehdi Abaakouk
Last sector, +sectors or +size{K,M,G} (2048-3907029167, default 3907029167): 
462 22 Mehdi Abaakouk
Using default value 3907029167
463 22 Mehdi Abaakouk
464 22 Mehdi Abaakouk
Command (m for help): p
465 22 Mehdi Abaakouk
466 22 Mehdi Abaakouk
Disk /dev/sdb: 2000.4 GB, 2000398934016 bytes
467 22 Mehdi Abaakouk
255 heads, 63 sectors/track, 243201 cylinders, total 3907029168 sectors
468 22 Mehdi Abaakouk
Units = sectors of 1 * 512 = 512 bytes
469 22 Mehdi Abaakouk
Sector size (logical/physical): 512 bytes / 512 bytes
470 22 Mehdi Abaakouk
I/O size (minimum/optimal): 512 bytes / 512 bytes
471 22 Mehdi Abaakouk
Disk identifier: 0x9bf0c7df
472 22 Mehdi Abaakouk
473 22 Mehdi Abaakouk
   Device Boot      Start         End      Blocks   Id  System
474 22 Mehdi Abaakouk
/dev/sdb1            2048  3907029167  1953513560   83  Linux
475 22 Mehdi Abaakouk
476 22 Mehdi Abaakouk
Command (m for help): m
477 22 Mehdi Abaakouk
Command action
478 22 Mehdi Abaakouk
   a   toggle a bootable flag
479 22 Mehdi Abaakouk
   b   edit bsd disklabel
480 22 Mehdi Abaakouk
   c   toggle the dos compatibility flag
481 22 Mehdi Abaakouk
   d   delete a partition
482 22 Mehdi Abaakouk
   l   list known partition types
483 22 Mehdi Abaakouk
   m   print this menu
484 22 Mehdi Abaakouk
   n   add a new partition
485 22 Mehdi Abaakouk
   o   create a new empty DOS partition table
486 22 Mehdi Abaakouk
   p   print the partition table
487 22 Mehdi Abaakouk
   q   quit without saving changes
488 22 Mehdi Abaakouk
   s   create a new empty Sun disklabel
489 22 Mehdi Abaakouk
   t   change a partition's system id
490 22 Mehdi Abaakouk
   u   change display/entry units
491 22 Mehdi Abaakouk
   v   verify the partition table
492 22 Mehdi Abaakouk
   w   write table to disk and exit
493 22 Mehdi Abaakouk
   x   extra functionality (experts only)
494 22 Mehdi Abaakouk
495 22 Mehdi Abaakouk
Command (m for help): t
496 22 Mehdi Abaakouk
Selected partition 1
497 22 Mehdi Abaakouk
Hex code (type L to list codes): L
498 22 Mehdi Abaakouk
499 22 Mehdi Abaakouk
 0  Empty           24  NEC DOS         81  Minix / old Lin bf  Solaris        
500 22 Mehdi Abaakouk
 1  FAT12           27  Hidden NTFS Win 82  Linux swap / So c1  DRDOS/sec (FAT-
501 22 Mehdi Abaakouk
 2  XENIX root      39  Plan 9          83  Linux           c4  DRDOS/sec (FAT-
502 22 Mehdi Abaakouk
 3  XENIX usr       3c  PartitionMagic  84  OS/2 hidden C:  c6  DRDOS/sec (FAT-
503 22 Mehdi Abaakouk
 4  FAT16 <32M      40  Venix 80286     85  Linux extended  c7  Syrinx         
504 22 Mehdi Abaakouk
 5  Extended        41  PPC PReP Boot   86  NTFS volume set da  Non-FS data    
505 22 Mehdi Abaakouk
 6  FAT16           42  SFS             87  NTFS volume set db  CP/M / CTOS / .
506 22 Mehdi Abaakouk
 7  HPFS/NTFS/exFAT 4d  QNX4.x          88  Linux plaintext de  Dell Utility   
507 22 Mehdi Abaakouk
 8  AIX             4e  QNX4.x 2nd part 8e  Linux LVM       df  BootIt         
508 22 Mehdi Abaakouk
 9  AIX bootable    4f  QNX4.x 3rd part 93  Amoeba          e1  DOS access     
509 22 Mehdi Abaakouk
 a  OS/2 Boot Manag 50  OnTrack DM      94  Amoeba BBT      e3  DOS R/O        
510 22 Mehdi Abaakouk
 b  W95 FAT32       51  OnTrack DM6 Aux 9f  BSD/OS          e4  SpeedStor      
511 22 Mehdi Abaakouk
 c  W95 FAT32 (LBA) 52  CP/M            a0  IBM Thinkpad hi eb  BeOS fs        
512 22 Mehdi Abaakouk
 e  W95 FAT16 (LBA) 53  OnTrack DM6 Aux a5  FreeBSD         ee  GPT            
513 22 Mehdi Abaakouk
 f  W95 Ext'd (LBA) 54  OnTrackDM6      a6  OpenBSD         ef  EFI (FAT-12/16/
514 22 Mehdi Abaakouk
10  OPUS            55  EZ-Drive        a7  NeXTSTEP        f0  Linux/PA-RISC b
515 22 Mehdi Abaakouk
11  Hidden FAT12    56  Golden Bow      a8  Darwin UFS      f1  SpeedStor      
516 22 Mehdi Abaakouk
12  Compaq diagnost 5c  Priam Edisk     a9  NetBSD          f4  SpeedStor      
517 22 Mehdi Abaakouk
14  Hidden FAT16 <3 61  SpeedStor       ab  Darwin boot     f2  DOS secondary  
518 22 Mehdi Abaakouk
16  Hidden FAT16    63  GNU HURD or Sys af  HFS / HFS+      fb  VMware VMFS    
519 22 Mehdi Abaakouk
17  Hidden HPFS/NTF 64  Novell Netware  b7  BSDI fs         fc  VMware VMKCORE 
520 22 Mehdi Abaakouk
18  AST SmartSleep  65  Novell Netware  b8  BSDI swap       fd  Linux raid auto
521 22 Mehdi Abaakouk
1b  Hidden W95 FAT3 70  DiskSecure Mult bb  Boot Wizard hid fe  LANstep        
522 22 Mehdi Abaakouk
1c  Hidden W95 FAT3 75  PC/IX           be  Solaris boot    ff  BBT            
523 22 Mehdi Abaakouk
1e  Hidden W95 FAT1 80  Old Minix      
524 22 Mehdi Abaakouk
Hex code (type L to list codes): 8e
525 22 Mehdi Abaakouk
Changed system type of partition 1 to 8e (Linux LVM)
526 22 Mehdi Abaakouk
527 22 Mehdi Abaakouk
Command (m for help): w
528 22 Mehdi Abaakouk
The partition table has been altered!
529 22 Mehdi Abaakouk
530 22 Mehdi Abaakouk
Calling ioctl() to re-read partition table.
531 22 Mehdi Abaakouk
Syncing disks.
532 22 Mehdi Abaakouk
</pre>
533 1 Mehdi Abaakouk
<pre>
534 23 Mehdi Abaakouk
pvcreate /dev/sdb1
535 24 Mehdi Abaakouk
vgcreate vm-velizy /dev/sdb1
536 1 Mehdi Abaakouk
lvcreate -n velizy-vm1 -L 50G vm-velizy
537 25 Mehdi Abaakouk
apt-get install virtinst
538 1 Mehdi Abaakouk
539 25 Mehdi Abaakouk
540 27 Mehdi Abaakouk
/root/preseed.cfg @ http://git.tetaneutral.net/libvirt.git/
541 27 Mehdi Abaakouk
542 1 Mehdi Abaakouk
replace the late-command line at the end of the file by:
543 27 Mehdi Abaakouk
d-i preseed/late_command string cp -f /postinstall-velizy.sh /target/; in-target bash /postinstall-velizy.sh
544 25 Mehdi Abaakouk
545 25 Mehdi Abaakouk
546 25 Mehdi Abaakouk
vmname=velizy-vm1
547 25 Mehdi Abaakouk
ip=192.166.143.24
548 25 Mehdi Abaakouk
549 25 Mehdi Abaakouk
virt-install -n $vmname -r 2048 --os-type=linux \
550 25 Mehdi Abaakouk
    --debug \
551 25 Mehdi Abaakouk
    --autostart \
552 25 Mehdi Abaakouk
    --disk /dev/vm-velizy/$vmname,bus=virtio,cache=none,io=native \
553 25 Mehdi Abaakouk
    --network bridge=br0,model=virtio \
554 25 Mehdi Abaakouk
    --nographics \
555 25 Mehdi Abaakouk
    --noreboot \
556 25 Mehdi Abaakouk
    --wait -1 \
557 1 Mehdi Abaakouk
    --location http://ftp.debian.org/debian/dists/wheezy/main/installer-amd64/ \
558 27 Mehdi Abaakouk
    --serial pty \
559 25 Mehdi Abaakouk
    --initrd-inject /root/preseed.cfg \
560 1 Mehdi Abaakouk
    --initrd-inject /root/postinstall-velizy.sh \
561 27 Mehdi Abaakouk
    --extra-args "console=ttyS0,9600n8 DEBIAN_FRONTEND=text auto priority=critical hostname=$vmname domain=tetaneutral.net netcfg/get_ipaddress=$ip netcfg/get_netmask=255.255.252.0 netcfg/get_gateway=192.166.143.254 netcfg/get_nameservers=192.166.143.23 netcfg/disable_dhcp=true" 
562 27 Mehdi Abaakouk
563 27 Mehdi Abaakouk
</pre>
564 27 Mehdi Abaakouk
565 27 Mehdi Abaakouk
566 27 Mehdi Abaakouk
postinstall-velizy.sh
567 27 Mehdi Abaakouk
<pre>
568 27 Mehdi Abaakouk
#!/bin/bash
569 27 Mehdi Abaakouk
sed -i -e 's/^.*Port.*$/Port 2222/' -e 's/^[# ]*PasswordAuthentication.*$/PasswordAuthenticati
570 27 Mehdi Abaakouk
on no/' /etc/ssh/sshd_config
571 27 Mehdi Abaakouk
572 27 Mehdi Abaakouk
mkdir -p /root/.ssh
573 27 Mehdi Abaakouk
cat > /root/.ssh/authorized_keys  <<EOF
574 27 Mehdi Abaakouk
ssh-dss AAAAB3NzaC1kc3MAAACBAJtnGLvuz4uVD6fnERDxDi/C0UyzwCiKmgNtEessopREYasAX4Gu6Fg10jAyIL5Nuc
575 27 Mehdi Abaakouk
7YDnqj//pOfxNjD7hp99a2ZmkRQgh/ltClxYML9fqhBHgsUCpVse9nOYDHDnDgvXIPRSDUHat2UFpdchHVrFURNLIlZnBz
576 27 Mehdi Abaakouk
tsr+GCDURTV/AAAAFQD9SrBcH49ltaKOm6V5ssCPmgs1SwAAAIAbAvkQ3/tMzzdACO5B9s5Yb3ZuM7XImm0iqufivVf2Xy
577 27 Mehdi Abaakouk
39g8HOBulUsN7eKEGPhVriqNolgIO7q7tVgYAff4/NE4yDP0Kp0SPg4tjt2yFJuL31Y3wzwHjnKrjgNlDSLl3uZnRXSipw
578 27 Mehdi Abaakouk
UMwGKbdHB6NZSqlq192VKbHilQ00pbiMlAAAAIB5dfB1lVHkJ0o5CcaVQRPbca9DvbbRwnoTSmKHc5DUcqsPqDhS07CkM9
579 27 Mehdi Abaakouk
ZcJuY1Nh4wGl4Q9kArj7Tnsvvygf/HReSUcIk4+nbDytJ8/pca/Qx4fzQQyppa94TylN62LSFT6MIJKLoMwYa0dQURT7Mv
580 27 Mehdi Abaakouk
5+9Qj2vk5pZ38w2iQ9zVCg== root@h1
581 27 Mehdi Abaakouk
EOF
582 25 Mehdi Abaakouk
583 25 Mehdi Abaakouk
passwd -d root
584 1 Mehdi Abaakouk
</pre>
585 24 Mehdi Abaakouk
586 24 Mehdi Abaakouk
587 1 Mehdi Abaakouk
apt-get install debconf-utils
588 1 Mehdi Abaakouk
debconf-get-selections > preseed.cfg # marche pas