forked from pr1ntf/iohyve
-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathiohyve.8.txt
412 lines (320 loc) · 13.7 KB
/
iohyve.8.txt
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
148
149
150
151
152
153
154
155
156
157
158
159
160
161
162
163
164
165
166
167
168
169
170
171
172
173
174
175
176
177
178
179
180
181
182
183
184
185
186
187
188
189
190
191
192
193
194
195
196
197
198
199
200
201
202
203
204
205
206
207
208
209
210
211
212
213
214
215
216
217
218
219
220
221
222
223
224
225
226
227
228
229
230
231
232
233
234
235
236
237
238
239
240
241
242
243
244
245
246
247
248
249
250
251
252
253
254
255
256
257
258
259
260
261
262
263
264
265
266
267
268
269
270
271
272
273
274
275
276
277
278
279
280
281
282
283
284
285
286
287
288
289
290
291
292
293
294
295
296
297
298
299
300
301
302
303
304
305
306
307
308
309
310
311
312
313
314
315
316
317
318
319
320
321
322
323
324
325
326
327
328
329
330
331
332
333
334
335
336
337
338
339
340
341
342
343
344
345
346
347
348
349
350
351
352
353
354
355
356
357
358
359
360
361
362
363
364
365
366
367
368
369
370
371
372
373
374
375
376
377
378
379
380
381
382
383
384
385
386
387
388
389
390
391
392
393
394
395
396
397
398
399
400
401
402
403
404
405
406
407
408
409
410
411
412
NAME
iohyve(8) - bhyve manager/launcher v0.7.5 "Tennessee Cherry Moonshine Edition"
SYNOPSIS
iohyve version
iohyve setup pool=[poolname] kmod=[0/1] net=[interface]
iohyve list [-l]
iohyve info [-vsdl]
iohyve isolist
iohyve fwlist
iohyve fetchiso [URL]
iohyve cpiso [path]
iohyve renameiso [ISO] [newname]
iohyve rmiso [ISO]
iohyve fetchfw [URL]
iohyve cpfw [path]
iohyve renamefw [firmware] [newname]
iohyve rmfw [firmware]
iohyve create [name] [size] [[pool]]
iohyve install [name] [ISO]
iohyve load [name]
iohyve boot [name] [ISO]
iohyve start [name] [-a | -s]
iohyve stop [name]
iohyve forcekill [name]
iohyve scram
iohyve destroy [name]
iohyve rename [name] [newname]
iohyve delete [-f] [name]
iohyve set [name] [prop1=value] [prop2=value]...
iohyve get [name] [prop]
iohyve rmpci [-f] [name] [pcidev:N]
iohyve getall [name]
iohyve add [name] [size] [[pool]]
iohyve remove [-f] [name] [diskN]
iohyve resize [name] [diskN] [size]
iohyve disks [name]
iohyve snap [name]@[snapshotname]
iohyve roll [name]@[snapshotname]
iohyve clone [-c | -r] [name] [clonename]
iohyve export [name]
iohyve snaplist
iohyve taplist
iohyve activetaps
iohyve conlist
iohyve console [name]
iohyve conreset
iohyve help
iohyve man
DESCRIPTION
The iohyve(8) shell script utilizes the FreeBSD hypervisor bhyve(8),
zfs(8), and nmdm(4) to make virtualization on FreeBSD easy and simple.
The basic idea is to store bhyve settings in zfs user properties of zfs
datasets that house important guest files like block devices and grub
configurations. iohyve(8) uses the virtio drivers built into the GENERIC
kernel for virtualization.
OPTIONS
version Prints the current running version of iohyve
setup Installs required zfs datasets and kernel modules for iohyve.
Usage: 'iohyve setup pool=poolname kmod=0/1 net=[iface]'
where [poolname] is the pool you want to install iohyve on,
kmod=[0/1] is if you want iohyve to load or unload the
kernel modules required by iohyve. 1 is load. net=[iface]
will set up the network bridge to the specified interface.
Multiple pools are supported, additional pools get mounted
in /iohyve/poolname
list Lists the name, status for VMM, active bhyve (Running), boot
on start flag (rcboot), and description for each guest.
-l flag pipes the final output to less
info Lists properties about the guests and their disks using flags
to control level of output. Fields include CPU count, RAM, Disk
Size, Pool, OS, Loader, Tap, Console, VMM status, Running status,
rcboot flag, pool, and the description. Use -l to pipe to less.
-v is for verbose which adds the fields: OS,
Loader, Tap, and Con.
-s is for status which add the fields: VMM,
Running, and rcboot.
-d is for description. Shows the guest description.
-l is for less and pipes the final output to less.
Order of flags is not important. The proper syntax is to use
the flags contiguiously. So "-ld" is the correct way to display
the base output plus description, and then have the output
piped to less.
isolist Lists the installed ISOs in the /iohyve/ISO directory.
fwlist Lists the firmwares in the /iohyve/Firmware directory.
fetchiso Fetches installation ISO or install image and creates a
dataset for it.
Usage: 'iohyve fetchiso [URL]' where [URL] is the HTTP or FTP URL to
fetchiso from the internet.
cpiso Copies installation ISO or install image from your host and
creates a dataset for it.
Usage: 'iohyve cpiso [path]' where [path] is the full path to
ISO file on the host machine.
renameiso Renames an ISO
Usage: 'iohyve renameiso [ISO] [newname]' where [ISO] is the
name of the ISO you would like to rename. [newname]
is a new name.
rmiso Removes installed ISO from /iohyve/ISO
Usage: 'iohyve rmiso [ISO]' where [ISO] is the name of the ISO
you would like to delete.
fetchfw Fetches firmware and creates a dataset for it.
Usage: 'iohyve fetchfw [URL]' where [URL] is the HTTP or FTP URL to
fetch from the internet.
cpfw Copies firmware from your host and creates a dataset for it.
Usage: 'iohyve cpfw [path]' where [path] is the full path to
firmware file on the host machine.
renamefw Renames a Firmware
Usage: 'iohyve renamefw [firmware] [newname]' where [firmware]
is the name of the firmware you would like to rename.
[newname] is a new name.
rmfw Removes installed firmware from /iohyve/Firmware
Usage: 'iohyve rmfw [firmware]' where [firmware] is the name of
the firmware you would like to delete.
create Creates new guest operating system.
Usage: 'iohyve create [name] [size] [[pool]]' where [name] is
the name you would like to use, [size] is the size of the
virtual block device in '16G' format where the capital G
signifies gigabytes. If you specify the pool, the first disk
gets added on that pool.
install Loads and boots into ISO for guest installation.
Usage: 'iohyve install [name] [ISO]' where [name] is the name
of the guest, and [ISO] is the name of the ISO you would
like to boot from in the form of: 'instal.iso'
load Loads the guest operating system bootloader and resources.
Usage: 'iohyve load [name] [ISO]'
where [name]is the name of the guest operating system.
[bootimg] is the path to the boot medium
boot Boots the guest into the operating system. 'iohyve run' needs
to be run before this is done.
Usage: 'iohyve boot [name] [runmode] [pci]'
where [name]is the name of the guest operating system.
[runmode] describes how to start the guest:
0 = start only once
1 = regular persist
Stop if the guest is powering off
2 = always persist
Always restart the guest
[pci] is a space separated list of pci devices
based on slot-less bhyve -s commands.
Example:
"ahci-hd,/path/disk.img virtio-net,tap0"
Note: hostbridge and lpc are automatically
added
start Starts the guest operating system. (Combines load & boot)
Usage: 'iohyve start [name] [-s | -a]'
where [name] is the name of the guest operating system.
[-s] will cause the guest to be started once
[-a] will cause the guest to always restart
stop Gracefully stops guest operating system.
Usage: 'iohyve stop [name]' where [name] is the name
of the guest operating system.
forcekill Forces the guest to stop. Runs kill -9 and destroys the guest
in VMM. USE WITH EXTREME CAUTION AND AS A LAST RESORT. Can be
used to kill guests stuck at the GRUB console that you
do not have access to.
scram Gracefully stop all bhyve guests. Does not destroy resources.
destroy Destroys guest resources.
Usage: 'iohyve destroy [name]' where [name] is the name
of the guest operating system. Destroying a guest does
not [delete] a guest from the host, it destroys the guest in VMM.
rename Renames the guest
Usage: 'iohyve rename [name] [newname]' where [name] is the
name of the guest and [newname] is the new name.
delete Deletes all data for the guest.
Usage: 'iohyve delete [name]' where [name] is the name
of the guest operating system. If [-f] is supplied before the
[name], there is no prompt to delete.
set Sets ZFS properties for guests one at a time
Usage: 'iohyve set [name] [prop1=value] [prop2=value]...' where
[name] is the name of the guest operating system.
Properties:
ram=512M or ram=2G (M for megabytes, G for gigabtyes)
cpu=1 (number of cpu cores)
con=nmdm0 (where to attach null modem console)
tap=tap[n](,tap[n]) (tap device for virtio-net)
[n] is a generic number to specify the tap interface to use
Specify a list o tap separated by comma for multiple tap
Single tap: iohyve set [name] tap=tap0
Multiple tap : iohyve set [name] tap=tap0,tap1,tap2,tap3
size=size of block device
mac_tap[n]=[MAC Address]
[n] is a generic number to specify the tap interface to use
Forces a specific MAC address to be attached to the
network adapter in the guest OS. iohyve does not check
for a valid MAC address, so double check the property.
pcidev:[n]=[spec]
Generic way to add devices to the guest.
[n] is a generic random number or string
[spec] defines a virtual device added to the guest
by using a bhyve -s argument without the pcislot
or function argument. PCI slot numbers are assigned
automatically by iohyve.
Examples: "pcidev:1=passthru,2/0/0"
"pcidev:2=ahci-hd,/some/place/disk.img"
get Gets ZFS properties for guests one at a time
Usage: 'iohyve get [name] [prop]' where [name] is the name
of the guest operating system. [prop] is the
property you want to view. (See 'iohyve set' info)
rmpci Removes a pcidev from the guest
Usage: 'iohyve rmpci [name] [pcidev:N]' where [name] is the name
of the guest operating system. [pcidev:N] is the PCI
device you want removed. Ex: 'pcidev:3' If [-f] is supplied
before the [name], there is no prompt to remove.
getall Gets all the ZFS properties for a guest
Usage: 'iohyve getall [name]' where [name] is the name
of the guest operating system.
add Adds a new disk to the guest.
Usage: 'iohyve add [name] [size] [[pool]]' where [name] is
the name of the guest, [size] is the size of the
virtual block device in '16G' format where the capital G
signifies gigabytes. If pool is specified, the disk gets
added on that pool
remove Removes a disk from the guest. Cannot be disk0.
Usage: 'iohyve remove [name] [diskN]' where [name] is
the name of the guest, [diskN] is the disk you would
like to remove from the guest. See 'iohyve disks' for
a list of disks for a guest. If [-f] is supplied before the
[name], there is no prompt to remove.
resize Resizes a disk. THIS CAN BREAK THINGS ON THE GUEST.
Usage: 'iohyve resize [name] [diskN] [size]' where [name] is
the name of the guest, [diskN] is the disk you would
like to remove from the guest, and [size] is the size
of the virtual block device in '16G' format where the
capital G signifies gigabytes.
See 'iohyve disks' for a list of disks for a guest
disks Lists the disks attached to a guest.
Usage: 'iohyve disks [name]' where [name] is the name
of the guest operating system.
snap Take a snapshot of a guest.
Usage: 'iohyve snap [name]@[snapshot]' where [name] is the
name of the guest and [snapshot] is what you would
like to name the snapshot.
roll Rollback guest to a snapshot.
Usage: 'iohyve roll [name]@[snapshot]' where [name] is the
name of the guest and [snapshot] is what you would
like to name the snapshot.
clone Clone a guest. Note that this will clone all of the properties.
If you want to use the clone and the original guest at the
same time you will need to change the tap and nmdm properties
or use the -r option to have iohyve do this for you
Usage: 'iohyve clone [-c | -r] [name] [clonename]' where [name]
is the name of the guest and [clonename] is what you would
like to name the new clone.
export Export a guest with all of it's properties and disks to a
GZip'd tarball. Property file is in a ucl-type format.
Disks output to a raw file, allowing for other managers using
ahci-hd emulation to use them. Tarball is put in the guest
dataset ex: /iohyve/guestname/guestname.tar.gz
Usage: 'iohyve export [name]' where [name] is the name of the
guest.
snaplist List all of the snapshots for all the guests. Does not show
snapshots of disks (they are there, though).
taplist Lists all of the network taps taken by iohyve guests
This will list taps that are not active as well.
activetaps Lists all active taps in use
conlist Lists all of the nullmodem consoles taken by iohyve guests.
This will list taps that are not active as well.
console Consoles into a guest operating system. Utilizes nmdm(4) and
cu(1) to open a console on a guest operating system. Since
bhyve(8) does not emulate video, so we need to administer
the guests via a serial communication device. Since iohyve
uses cu(1), you will need to press the tilde (~) twice
then period (.) to exit the console.
(Think typing ~~. real fast to exit console)
If that fails to work, try pressing tilde (~) then press
Control + D (^D). Note that on some machines, you cannot
escape the console. See conreset below to escape all consoles.
Usage: 'iohyve console [name]' where [name] is the name
of the guest operating system.
conreset Ends all console sessions for when things get weird.
help General usage help.
EXAMPLES
Setup iohyve zpool named tank:
iohyve setup pool=tank
Fetch FreeBSD install ISO for later:
iohyve fetchiso ftp://ftp.freebsd.org/.../10.2/FreeBSD....iso
Create a new FreeBSD guest named bsdguest on console nmdm0 with an 8Gigabyte virtual HDD:
iohyve create bsdguest 8G
List ISO's:
iohyve isolist
Install the FreeBSD guest bsdguest:
iohyve install bsdguest FreeBSD-10.2-RELEASE-amd64-bootonly.iso
Console into the intallation:
iohyve console bsdguest
Once installation is done, exit console (~~.) and destroy guest:
iohyve destroy bsdguest
Now that the guest is installed, it can be started like usual:
iohyve start bsdguest
Some guest os's can be gracefully stopped:
iohyve stop bsdguest
List all guests created with:
iohyve list
List all guests that have resources allocated using:
iohyve vmmlist
List all runnng guests using:
iohvye running
You can change guest properties by using set:
iohyve set bsdguest ram=512M
iohyve set bsdguest cpu=1
iohyve set bsdguest tap=tap0
iohyve set bsdguest con=nmdm0
Get a spcific guest property:
iohyve get bsdguest ram
Get all guest properties:
iohyve getall bsdguest
Install and run a Debian guest:
iohyve create debianvm 8G
iohyve set debianvm loader=grub-bhyve
iohyve install debianvm deb8.1-net.iso
iohyve start debianvm
Take a snapshot of a guest:
iohyve snap bsdguest@beforeupdate
iohyve snaplist
iohyve roll bsdguest@beforeupdate
Make an independent clone of a guest:
iohyve clone bsdguest dolly
AUTHOR
Trent -- @pr1ntf
SEE ALSO
bhyve(8), bhyveload(8), zfs(8), nmdm(4),
cu(1), if_bridge(4), grub2-bhyve(8)