about summary refs log tree commit diff stats
path: root/tools/qemu.html
blob: ef1c36defcd978e5ac2cd290487c80d746ba55df (plain) (blame)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
<!DOCTYPE html>
<html dir="ltr" lang="en">
    <head>
        <meta charset='utf-8'>
        <title>Qemu</title>
    </head>
    <body>

        <a href="index.html">Tools Index</a>

        <h1>Qemu</h1>

        <h2 id="kern">Kernel configuration</h2>

        <pre>
        # usermod -a -G kvm c9admin
        # usermod -a -G kvm username
        </pre>

        <h2 id="disk">Disk images</h2>

        <dl>
            <dt>img</dt>
            <dd>network slirp</dd>
            <dt>raw</dt>
            <dd>network tap</dd>
            <dt>qcow2</dt>
            <dd>... ...</dd>
        </dl>



        <p>Create hard disk image, there is different types,
        this describes how to create a qcow2 type;</p>

        <pre>
        $ qemu-img create -f qcow2 crux-img.qcow2 20G
        </pre>

        <p>You can mount disk image;</p>

        <pre>
        $ sudo modprobe nbd
        $ sudo qemu-nbd -c /dev/nbd0 /crux-img.qcow2
        </pre>

        <p>To disconnect image disk (ndb);</a>

        <pre>
        $ sudo qemu-nbd -d /dev/nbd0
        </pre>

        <p>You can use image as a normal disk, example how
        to use parted to create a gpt system table;</p>

        <pre>
        # parted /dev/nbd0
        (parted) mklabel gpt
        </pre>

        <p>More information about
        <a href="http://devil-detail.blogspot.pt/2013/07/install-grub2-on-gpt-disk-dedicated-partition.html">gpt partition table</a>.
        </p>

        <p>If partitions are on qcow2 image then setup partitions;</p>

        <pre>
        # kpartx -a -s -l /dev/nbd0
        </pre>


        <p>Network configuration;</p>
        <dl>
            <dt>slirp</dt>
            <dd>network slirp</dd>
            <dt>tun/tap</dt>
            <dd>network tap</dd>
            <dt>...</dt>
            <dd>... ...</dd>
        </dl>

        <h2>Network configuration</h2>

        <h3>Tap interfaces</h3>

        <pre>
        KERNEL=="tun", GROUP="kvm", MODE="0660", OPTIONS+="static_node=net/tun"
        </pre>

        <p>Automatic creation of tap interface with
        correct permissions set for user and group,
        you can set only user or group;</p>

        <pre>
        # tunctl -u username -g kvm
        </pre>

        <p>Set permissions to existing tap interface;</p>

        <pre>
        # tunctl -u username -t tap0
        </pre>


        <p>Manual creation of tap interface;</p>

	<pre>
	# ip tuntap add name tap0 mode tap
        # chmod 0666 /dev/tap0
        # chown root:username /dev/tap0
	# ip link show
	</pre>

        <p>Start qemu with 512 of ram, mydisk.img as disk and boot from iso</p>

        <pre>
        $ qemu-system-x86_64 \
        -enable-kvm \
        -m 512 \
        -boot d -cdrom image.iso \
        -hda mydisk.img
    	</pre>

        <p>Start qemu with 1024 of ram, network configured using tap0
        interface device no host and boot from crux.qcow2;</p>

	<pre>
	$ qemu-system-x86_64 \
	-enable-kvm \
	-m 1024 \
	-hda c9/local/crux.qcow2 \
	-net nic,model=virtio -net tap,ifname=tap0,script=no,downscript=no
        </pre>

	<p>On host machine test network;</p>

	<pre>
	# tcpdump tap0
	</pre>
        <a href="index.html">Tools Index</a>
        <p>This is part of the c9 Manual.
        Copyright (C) 2016
        c9 team.
        See the file <a href="../fdl-1.3-standalone.html">Gnu Free Documentation License</a>
        for copying conditions.</p>
    </body>
</html>