1virt-v2v(1) Virtualization Support virt-v2v(1)
2
3
4
6 virt-v2v - Convert a guest to use KVM
7
9 virt-v2v [-i mode] [other -i* options]
10 [-o mode] [other -o* options]
11 [guest|filename]
12
13 virt-v2v --in-place
14 [-i mode] [other -i* options]
15 [guest|filename]
16
18 Virt-v2v converts a single guest from a foreign hypervisor to run on
19 KVM. It can read Linux and Windows guests running on VMware, Xen,
20 Hyper-V and some other hypervisors, and convert them to KVM managed by
21 libvirt, OpenStack, oVirt, Red Hat Virtualisation (RHV) or several
22 other targets. It can modify the guest to make it bootable on KVM and
23 install virtio drivers so it will run quickly.
24
25 There is also a companion front-end called virt-p2v(1) which comes as
26 an ISO, CD or PXE image that can be booted on physical machines to
27 virtualize those machines (physical to virtual, or p2v).
28
29 Input and Output
30 You normally run virt-v2v with several -i* options controlling the
31 input mode and also several -o* options controlling the output mode.
32 In this sense, "input" refers to the source foreign hypervisor such as
33 VMware, and "output" refers to the target KVM-based management system
34 such as oVirt or OpenStack.
35
36 The input and output sides of virt-v2v are separate and unrelated.
37 Virt-v2v can read from any input and write to any output. Therefore
38 these sides of virt-v2v are documented separately in this manual.
39
40 Virt-v2v normally copies from the input to the output, called "copying
41 mode". In this case the source guest is always left unchanged. In-
42 place conversion (--in-place) only uses the -i* options and modifies
43 the source guest in-place. (See "In-place conversion" below.)
44
45 Other virt-v2v topics
46 virt-v2v-support(1) — Supported hypervisors, virtualization management
47 systems, guests.
48
49 virt-v2v-input-vmware(1) — Input from VMware.
50
51 virt-v2v-input-xen(1) — Input from Xen.
52
53 virt-v2v-output-local(1) — Output to local files or local libvirt.
54
55 virt-v2v-output-rhv(1) — Output to oVirt or RHV.
56
57 virt-v2v-output-openstack(1) — Output to OpenStack.
58
59 virt-v2v-release-notes-1.42(1) — Release notes for this release.
60
61 virt-v2v-copy-to-local(1) — Deprecated tool to handle Xen guests using
62 host block device storage.
63
65 Convert from VMware vCenter server to local libvirt
66 You have a VMware vCenter server called "vcenter.example.com", a
67 datacenter called "Datacenter", and an ESXi hypervisor called "esxi".
68 You want to convert a guest called "vmware_guest" to run locally under
69 libvirt.
70
71 virt-v2v -ic vpx://vcenter.example.com/Datacenter/esxi vmware_guest
72
73 In this case you will most likely have to run virt-v2v as "root", since
74 it needs to talk to the system libvirt daemon and copy the guest disks
75 to /var/lib/libvirt/images.
76
77 For more information see virt-v2v-input-vmware(1).
78
79 Convert from VMware to RHV/oVirt
80 This is the same as the previous example, except you want to send the
81 guest to a RHV Data Domain using the RHV REST API. Guest network
82 interface(s) are connected to the target network called "ovirtmgmt".
83
84 virt-v2v -ic vpx://vcenter.example.com/Datacenter/esxi vmware_guest \
85 -o rhv-upload -oc https://ovirt-engine.example.com/ovirt-engine/api \
86 -os ovirt-data -op /tmp/ovirt-admin-password -of raw \
87 -oo rhv-cafile=/tmp/ca.pem -oo rhv-direct \
88 --bridge ovirtmgmt
89
90 In this case the host running virt-v2v acts as a conversion server.
91
92 For more information see virt-v2v-output-rhv(1).
93
94 Convert from ESXi hypervisor over SSH to local libvirt
95 You have an ESXi hypervisor called "esxi.example.com" with SSH access
96 enabled. You want to convert from VMFS storage on that server to a
97 local file.
98
99 virt-v2v \
100 -i vmx -it ssh \
101 "ssh://root@esxi.example.com/vmfs/volumes/datastore1/guest/guest.vmx" \
102 -o local -os /var/tmp
103
104 The guest must not be running. Virt-v2v would not need to be run as
105 root in this case.
106
107 For more information about converting from VMX files see
108 virt-v2v-input-vmware(1).
109
110 Convert disk image to OpenStack
111 Given a disk image from another hypervisor that you want to convert to
112 run on OpenStack (only KVM-based OpenStack is supported), you can run
113 virt-v2v inside an OpenStack VM (called "v2v-vm" below), and do:
114
115 virt-v2v -i disk disk.img -o openstack -oo server-id=v2v-vm
116
117 See virt-v2v-output-openstack(1).
118
119 Convert disk image to disk image
120 Given a disk image from another hypervisor that you want to convert to
121 run on KVM, you have two options. The simplest way is to try:
122
123 virt-v2v -i disk disk.img -o local -os /var/tmp
124
125 where virt-v2v guesses everything about the input disk.img and (in this
126 case) writes the converted result to /var/tmp.
127
128 A more complex method is to write some libvirt XML describing the input
129 guest (if you can get the source hypervisor to provide you with libvirt
130 XML, then so much the better). You can then do:
131
132 virt-v2v -i libvirtxml guest-domain.xml -o local -os /var/tmp
133
134 Since guest-domain.xml contains the path(s) to the guest disk image(s)
135 you do not need to specify the name of the disk image on the command
136 line.
137
138 To convert a local disk image and immediately boot it in local qemu,
139 do:
140
141 virt-v2v -i disk disk.img -o qemu -os /var/tmp --qemu-boot
142
144 --help
145 Display help.
146
147 --bandwidth bps
148 --bandwidth-file filename
149 Some input methods are able to limit the network bandwidth they
150 will use statically or dynamically. In the first variant this sets
151 the bandwidth limit statically in bits per second. Formats like
152 "10M" may be used (meaning 10 megabits per second).
153
154 In the second variant the bandwidth is limited dynamically from the
155 content of the file (also in bits per second, in the same formats
156 supported by the first variant). You may use both parameters
157 together, meaning: first limit to a static rate, then you can
158 create the file while virt-v2v is running to adjust the rate
159 dynamically.
160
161 This is only supported for:
162
163 · input from Xen
164
165 · input from VMware VMX when using the SSH transport method
166
167 · input from VDDK
168
169 · -i libvirtxml when using HTTP or HTTPS disks
170
171 · input from VMware vCenter server
172
173 The options are silently ignored for other input methods.
174
175 -b ...
176 --bridge ...
177 See --network below.
178
179 --colors
180 --colours
181 Use ANSI colour sequences to colourize messages. This is the
182 default when the output is a tty. If the output of the program is
183 redirected to a file, ANSI colour sequences are disabled unless you
184 use this option.
185
186 --compressed
187 Write a compressed output file. This is only allowed if the output
188 format is qcow2 (see -of below), and is equivalent to the -c option
189 of qemu-img(1).
190
191 --debug-overlays
192 Save the overlay file(s) created during conversion. This option is
193 only used for debugging virt-v2v and may be removed in a future
194 version.
195
196 --echo-keys
197 When prompting for keys and passphrases, virt-v2v normally turns
198 echoing off so you cannot see what you are typing. If you are not
199 worried about Tempest attacks and there is no one else in the room
200 you can specify this flag to see what you are typing.
201
202 Note this options only applies to keys and passphrases for
203 encrypted devices and partitions, not for passwords used to connect
204 to remote servers.
205
206 -i disk
207 Set the input method to disk.
208
209 In this mode you can read a virtual machine disk image with no
210 metadata. virt-v2v tries to guess the best default metadata. This
211 is usually adequate but you can get finer control (eg. of memory
212 and vCPUs) by using -i libvirtxml instead. Only guests that use a
213 single disk can be imported this way.
214
215 -i libvirt
216 Set the input method to libvirt. This is the default.
217
218 In this mode you have to specify a libvirt guest name or UUID on
219 the command line. You may also specify a libvirt connection URI
220 (see -ic).
221
222 -i libvirtxml
223 Set the input method to libvirtxml.
224
225 In this mode you have to pass a libvirt XML file on the command
226 line. This file is read in order to get metadata about the source
227 guest (such as its name, amount of memory), and also to locate the
228 input disks. See "Minimal XML for -i libvirtxml option" below.
229
230 -i local
231 This is the same as -i disk.
232
233 -i ova
234 Set the input method to ova.
235
236 In this mode you can read a VMware ova file. Virt-v2v will read
237 the ova manifest file and check the vmdk volumes for validity
238 (checksums) as well as analyzing the ovf file, and then convert the
239 guest. See virt-v2v-input-vmware(1).
240
241 -i vmx
242 Set the input method to vmx.
243
244 In this mode you can read a VMware vmx file directly or over SSH.
245 This is useful when VMware VMs are stored on an NFS server which
246 you can mount directly, or where you have access by SSH to an ESXi
247 hypervisor. See virt-v2v-input-vmware(1).
248
249 -ic libvirtURI
250 Specify a libvirt connection URI to use when reading the guest.
251 This is only used when -i libvirt.
252
253 Only local libvirt connections, VMware vCenter connections, or RHEL
254 5 Xen remote connections can be used. Other remote libvirt
255 connections will not work in general.
256
257 See also virt-v2v-input-vmware(1), virt-v2v-input-xen(1).
258
259 -if format
260 For -i disk only, this specifies the format of the input disk
261 image. For other input methods you should specify the input format
262 in the metadata.
263
264 --in-place
265 Do not create an output virtual machine in the target hypervisor.
266 Instead, adjust the guest OS in the source VM to run in the input
267 hypervisor.
268
269 This mode is meant for integration with other toolsets, which take
270 the responsibility of converting the VM configuration, providing
271 for rollback in case of errors, transforming the storage, etc.
272
273 See "In-place conversion" below.
274
275 Conflicts with all -o * options.
276
277 -io OPTION=VALUE
278 Set input option(s) related to the current input mode or transport.
279 To display short help on what options are available you can use:
280
281 virt-v2v -it vddk -io "?"
282
283 -io vddk-libdir=LIBDIR
284 Set the VDDK library directory. This directory should contain
285 subdirectories called include, lib64 etc., but do not include lib64
286 actually in the parameter.
287
288 In most cases this parameter is required when using the -it vddk
289 (VDDK) transport. See virt-v2v-input-vmware(1) for details.
290
291 -io vddk-thumbprint=xx:xx:xx:...
292 Set the thumbprint of the remote VMware server.
293
294 This parameter is required when using the -it vddk (VDDK)
295 transport. See virt-v2v-input-vmware(1) for details.
296
297 -io vddk-config=FILENAME
298 -io vddk-cookie=COOKIE
299 -io vddk-nfchostport=PORT
300 -io vddk-port=PORT
301 -io vddk-snapshot=SNAPSHOT-MOREF
302 -io vddk-transports=MODE:MODE:...
303 When using VDDK mode, these options are passed unmodified to the
304 nbdkit(1) VDDK plugin. Please refer to nbdkit-vddk-plugin(1). Do
305 not use these options unless you know what you are doing. These
306 are all optional.
307
308 -ip filename
309 Supply a file containing a password to be used when connecting to
310 the target hypervisor. If this is omitted then the input
311 hypervisor may ask for the password interactively. Note the file
312 should contain the whole password, without any trailing newline,
313 and for security the file should have mode 0600 so that others
314 cannot read it.
315
316 -it ssh
317 When using -i vmx, this enables the ssh transport. See
318 virt-v2v-input-vmware(1).
319
320 -it vddk
321 Use VMware VDDK as a transport to copy the input disks. See
322 virt-v2v-input-vmware(1). If you use this parameter then you may
323 need to use other -io vddk* options to specify how to connect
324 through VDDK.
325
326 --key SELECTOR
327 Specify a key for LUKS, to automatically open a LUKS device when
328 using the inspection. "ID" can be either the libguestfs device
329 name, or the UUID of the LUKS device.
330
331 --key "ID":key:KEY_STRING
332 Use the specified "KEY_STRING" as passphrase.
333
334 --key "ID":file:FILENAME
335 Read the passphrase from FILENAME.
336
337 --keys-from-stdin
338 Read key or passphrase parameters from stdin. The default is to
339 try to read passphrases from the user by opening /dev/tty.
340
341 Note this options only applies to keys and passphrases for
342 encrypted devices and partitions, not for passwords used to connect
343 to remote servers.
344
345 --mac aa:bb:cc:dd:ee:ff:network:out
346 --mac aa:bb:cc:dd:ee:ff:bridge:out
347 Map source NIC MAC address to a network or bridge.
348
349 See "Networks and bridges" below.
350
351 --mac aa:bb:cc:dd:ee:ff:ip:ipaddr[,gw[,len[,ns,ns,...]]]
352 Force a particular interface (controlled by its MAC address) to
353 have a static IP address after boot.
354
355 The fields in the parameter are: "ipaddr" is the IP address. "gw"
356 is the optional gateway IP address. "len" is the subnet mask
357 length (an integer). The final parameters are zero or more
358 nameserver IP addresses.
359
360 This option can be supplied zero or more times.
361
362 You only need to use this option for certain broken guests such as
363 Windows which are unable to preserve MAC to static IP address
364 mappings automatically. You don't need to use it if Windows is
365 using DHCP. It is currently ignored for Linux guests since they do
366 not have this problem.
367
368 --machine-readable
369 --machine-readable=format
370 This option is used to make the output more machine friendly when
371 being parsed by other programs. See "Machine readable output"
372 below.
373
374 -n in:out
375 -n out
376 --network in:out
377 --network out
378 -b in:out
379 -b out
380 --bridge in:out
381 --bridge out
382 Map network (or bridge) called "in" to network (or bridge) called
383 "out". If no "in:" prefix is given, all other networks (or
384 bridges) are mapped to "out".
385
386 See "Networks and bridges" below.
387
388 --no-copy
389 Don’t copy the disks. Instead, conversion is performed (and thrown
390 away), and metadata is written, but no disks are created. See also
391 discussion of -o null below.
392
393 This is useful in two cases: Either you want to test if conversion
394 is likely to succeed, without the long copying process. Or you are
395 only interested in looking at the metadata.
396
397 This option is not compatible with -o libvirt since it would create
398 a faulty guest (one with no disks).
399
400 This option is not compatible with -o glance for technical reasons.
401
402 -o disk
403 This is the same as -o local.
404
405 -o glance
406 This is a legacy option. You should probably use -o openstack
407 instead.
408
409 Set the output method to OpenStack Glance. In this mode the
410 converted guest is uploaded to Glance. See
411 virt-v2v-output-openstack(1).
412
413 -o json
414 Set the output method to json.
415
416 In this mode, the converted guest is written to a local directory
417 specified by -os /dir (the directory must exist), with a JSON file
418 containing the majority of the metadata that virt-v2v gathered
419 during the conversion.
420
421 See virt-v2v-output-local(1).
422
423 -o libvirt
424 Set the output method to libvirt. This is the default.
425
426 In this mode, the converted guest is created as a libvirt guest.
427 You may also specify a libvirt connection URI (see -oc).
428
429 See virt-v2v-output-local(1).
430
431 -o local
432 Set the output method to local.
433
434 In this mode, the converted guest is written to a local directory
435 specified by -os /dir (the directory must exist). The converted
436 guest’s disks are written as:
437
438 /dir/name-sda
439 /dir/name-sdb
440 [etc]
441
442 and a libvirt XML file is created containing guest metadata:
443
444 /dir/name.xml
445
446 where "name" is the guest name.
447
448 -o null
449 Set the output method to null.
450
451 The guest is converted and copied (unless you also specify
452 --no-copy), but the results are thrown away and no metadata is
453 written.
454
455 -o openstack
456 Set the output method to OpenStack. See
457 virt-v2v-output-openstack(1).
458
459 -o ovirt
460 This is the same as -o rhv.
461
462 -o ovirt-upload
463 This is the same as -o rhv-upload.
464
465 -o qemu
466 Set the output method to qemu.
467
468 This is similar to -o local, except that a shell script is written
469 which you can use to boot the guest in qemu. The converted disks
470 and shell script are written to the directory specified by -os.
471
472 When using this output mode, you can also specify the --qemu-boot
473 option which boots the guest under qemu immediately.
474
475 -o rhev
476 This is the same as -o rhv.
477
478 -o rhv
479 Set the output method to rhv.
480
481 The converted guest is written to a RHV Export Storage Domain. The
482 -os parameter must also be used to specify the location of the
483 Export Storage Domain. Note this does not actually import the
484 guest into RHV. You have to do that manually later using the UI.
485
486 See virt-v2v-output-rhv(1).
487
488 -o rhv-upload
489 Set the output method to rhv-upload.
490
491 The converted guest is written directly to a RHV Data Domain. This
492 is a faster method than -o rhv, but requires oVirt or RHV ≥ 4.2.
493
494 See virt-v2v-output-rhv(1).
495
496 -o vdsm
497 Set the output method to vdsm.
498
499 This mode is similar to -o rhv, but the full path to the data
500 domain must be given:
501 /rhv/data-center/<data-center-uuid>/<data-domain-uuid>. This mode
502 is only used when virt-v2v runs under VDSM control.
503
504 -oa sparse
505 -oa preallocated
506 Set the output file allocation mode. The default is "sparse".
507
508 -oc URI
509 Specify a connection URI to use when writing the converted guest.
510
511 For -o libvirt this is the libvirt URI. Only local libvirt
512 connections can be used. Remote libvirt connections will not work.
513 See virt-v2v-output-local(1) for further information.
514
515 -of format
516 When converting the guest, convert the disks to the given format.
517
518 If not specified, then the input format is used.
519
520 -on name
521 Rename the guest when converting it. If this option is not used
522 then the output name is the same as the input name.
523
524 -oo OPTION=VALUE
525 Set output option(s) related to the current output mode. To
526 display short help on what options are available you can use:
527
528 virt-v2v -o rhv-upload -oo "?"
529
530 -oo guest-id="ID"
531 For -o openstack (virt-v2v-output-openstack(1)) only, set a guest
532 ID which is saved on each Cinder volume in the "virt_v2v_guest_id"
533 volume property.
534
535 -oo verify-server-certificate
536 -oo verify-server-certificate="true|false"
537 For -o openstack (virt-v2v-output-openstack(1)) only, this can be
538 used to disable SSL certification validation when connecting to
539 OpenStack by specifying -oo verify-server-certificate=false.
540
541 -oo os-*=*
542 For -o openstack (virt-v2v-output-openstack(1)) only, set optional
543 OpenStack authentication. For example -oo os-username=NAME is
544 equivalent to "openstack --os-username=NAME".
545
546 -oo rhv-cafile=ca.pem
547 For -o rhv-upload (virt-v2v-output-rhv(1)) only, the ca.pem file
548 (Certificate Authority), copied from /etc/pki/ovirt-engine/ca.pem
549 on the oVirt engine.
550
551 -oo rhv-cluster="CLUSTERNAME"
552 For -o rhv-upload (virt-v2v-output-rhv(1)) only, set the RHV
553 Cluster Name. If not given it uses "Default".
554
555 -oo rhv-direct
556 For -o rhv-upload (virt-v2v-output-rhv(1)) only, if this option is
557 given then virt-v2v will attempt to directly upload the disk to the
558 oVirt node, otherwise it will proxy the upload through the oVirt
559 engine. Direct upload requires that you have network access to the
560 oVirt nodes. Non-direct upload is slightly slower but should work
561 in all situations.
562
563 -oo rhv-verifypeer
564 For -o rhv-upload (virt-v2v-output-rhv(1)) only, verify the
565 oVirt/RHV server’s identity by checking the server‘s certificate
566 against the Certificate Authority.
567
568 -oo server-id="NAME|UUID"
569 For -o openstack (virt-v2v-output-openstack(1)) only, set the name
570 of the conversion appliance where virt-v2v is running.
571
572 -oo vdsm-compat=0.10
573 -oo vdsm-compat=1.1
574 If -o vdsm and the output format is qcow2, then we add the qcow2
575 compat=0.10 option to the output file for compatibility with RHEL 6
576 (see https://bugzilla.redhat.com/1145582).
577
578 If -oo vdsm-compat=1.1 is used then modern qcow2 (compat=1.1) files
579 are generated instead.
580
581 Currently -oo vdsm-compat=0.10 is the default, but this will change
582 to -oo vdsm-compat=1.1 in a future version of virt-v2v (when we can
583 assume that everyone is using a modern version of qemu).
584
585 Note this option only affects -o vdsm output. All other output
586 modes (including -o rhv) generate modern qcow2 compat=1.1 files,
587 always.
588
589 If this option is available, then "vdsm-compat-option" will appear
590 in the --machine-readable output.
591
592 -oo vdsm-image-uuid=UUID
593 -oo vdsm-vol-uuid=UUID
594 -oo vdsm-vm-uuid=UUID
595 -oo vdsm-ovf-output=DIR
596 Normally the RHV output mode chooses random UUIDs for the target
597 guest. However VDSM needs to control the UUIDs and passes these
598 parameters when virt-v2v runs under VDSM control. The parameters
599 control:
600
601 · the image directory of each guest disk (-oo vdsm-image-uuid)
602 (this option is passed once for each guest disk)
603
604 · UUIDs for each guest disk (-oo vdsm-vol-uuid) (this option is
605 passed once for each guest disk)
606
607 · the OVF file name (-oo vdsm-vm-uuid).
608
609 · the OVF output directory (default current directory) (-oo vdsm-
610 ovf-output).
611
612 The format of UUIDs is: "12345678-1234-1234-1234-123456789abc"
613 (each hex digit can be "0-9" or "a-f"), conforming to OSF DCE 1.1.
614
615 These options can only be used with -o vdsm.
616
617 -oo vdsm-ovf-flavour=flavour
618 This option controls the format of the OVF generated at the end of
619 conversion. Currently there are two possible flavours:
620
621 rhvexp
622 The OVF format used in RHV export storage domain.
623
624 ovirt
625 The OVF format understood by oVirt REST API.
626
627 For backward compatibility the default is rhvexp, but this may
628 change in the future.
629
630 -op file
631 Supply a file containing a password to be used when connecting to
632 the target hypervisor. Note the file should contain the whole
633 password, without any trailing newline, and for security the file
634 should have mode 0600 so that others cannot read it.
635
636 -os storage
637 The location of the storage for the converted guest.
638
639 For -o libvirt, this is a libvirt directory pool (see
640 "virsh pool-list") or pool UUID.
641
642 For -o json, -o local and -o qemu, this is a directory name. The
643 directory must exist.
644
645 For -o rhv-upload, this is the name of the destination Storage
646 Domain.
647
648 For -o openstack, this is the optional Cinder volume type.
649
650 For -o rhv, this can be an NFS path of the Export Storage Domain of
651 the form "<host>:<path>", eg:
652
653 rhv-storage.example.com:/rhv/export
654
655 The NFS export must be mountable and writable by the user and host
656 running virt-v2v, since the virt-v2v program has to actually mount
657 it when it runs. So you probably have to run virt-v2v as "root".
658
659 Or: You can mount the Export Storage Domain yourself, and point -os
660 to the mountpoint. Note that virt-v2v will still need to write to
661 this remote directory, so virt-v2v will still need to run as
662 "root".
663
664 You will get an error if virt-v2v is unable to mount/write to the
665 Export Storage Domain.
666
667 --print-estimate
668 Print the estimated size of the data which will be copied from the
669 source disk(s) and stop. One number (the size in bytes) is printed
670 per disk, and a total:
671
672 $ virt-v2v --print-estimate
673 ...
674 disk 1: 100000
675 disk 2: 200000
676 total: 300000
677
678 With the --machine-readable option you get JSON output which can be
679 directed into a file or elsewhere:
680
681 $ virt-v2v --print-estimate --machine-readable=file:estimates
682 ...
683 $ cat estimates
684 {
685 "disks": [ 100000, 200000 ],
686 "total": 300000
687 }
688
689 When using this option you must specify an output mode. This is
690 because virt-v2v has to perform the conversion in order to print
691 the estimate, and the conversion depends on the output mode. Using
692 -o null should be safe for most purposes.
693
694 When this option is used along with --machine-readable you can
695 direct the output to an alternate file.
696
697 --print-source
698 Print information about the source guest and stop. This option is
699 useful when you are setting up network and bridge maps. See
700 "Networks and bridges".
701
702 --qemu-boot
703 When using -o qemu only, this boots the guest immediately after
704 virt-v2v finishes.
705
706 -q
707 --quiet
708 This disables progress bars and other unnecessary output.
709
710 --root ask
711 --root single
712 --root first
713 --root /dev/sdX
714 --root /dev/VG/LV
715 Choose the root filesystem to be converted.
716
717 In the case where the virtual machine is dual-boot or multi-boot,
718 or where the VM has other filesystems that look like operating
719 systems, this option can be used to select the root filesystem
720 (a.k.a. "C:" drive or /) of the operating system that is to be
721 converted. The Windows Recovery Console, certain attached DVD
722 drives, and bugs in libguestfs inspection heuristics, can make a
723 guest look like a multi-boot operating system.
724
725 The default in virt-v2v ≤ 0.7.1 was --root single, which causes
726 virt-v2v to die if a multi-boot operating system is found.
727
728 Since virt-v2v ≥ 0.7.2 the default is now --root ask: If the VM is
729 found to be multi-boot, then virt-v2v will stop and list the
730 possible root filesystems and ask the user which to use. This
731 requires that virt-v2v is run interactively.
732
733 --root first means to choose the first root device in the case of a
734 multi-boot operating system. Since this is a heuristic, it may
735 sometimes choose the wrong one.
736
737 You can also name a specific root device, eg. --root /dev/sda2
738 would mean to use the second partition on the first hard drive. If
739 the named root device does not exist or was not detected as a root
740 device, then virt-v2v will fail.
741
742 Note that there is a bug in grub which prevents it from
743 successfully booting a multiboot system if virtio is enabled. Grub
744 is only able to boot an operating system from the first virtio
745 disk. Specifically, /boot must be on the first virtio disk, and it
746 cannot chainload an OS which is not in the first virtio disk.
747
748 -v
749 --verbose
750 Enable verbose messages for debugging.
751
752 -V
753 --version
754 Display version number and exit.
755
756 -x Enable tracing of libguestfs API calls.
757
759 Xen paravirtualized guests
760 Older versions of virt-v2v could turn a Xen paravirtualized (PV) guest
761 into a KVM guest by installing a new kernel. This version of virt-v2v
762 does not attempt to install any new kernels. Instead it will give you
763 an error if there are only Xen PV kernels available.
764
765 Therefore before conversion you should check that a regular kernel is
766 installed. For some older Linux distributions, this means installing a
767 kernel from the table below:
768
769 RHEL 3 (Does not apply, as there was no Xen PV kernel)
770
771 RHEL 4 i686 with > 10GB of RAM: install 'kernel-hugemem'
772 i686 SMP: install 'kernel-smp'
773 other i686: install 'kernel'
774 x86-64 SMP with > 8 CPUs: install 'kernel-largesmp'
775 x86-64 SMP: install 'kernel-smp'
776 other x86-64: install 'kernel'
777
778 RHEL 5 i686: install 'kernel-PAE'
779 x86-64: install 'kernel'
780
781 SLES 10 i586 with > 10GB of RAM: install 'kernel-bigsmp'
782 i586 SMP: install 'kernel-smp'
783 other i586: install 'kernel-default'
784 x86-64 SMP: install 'kernel-smp'
785 other x86-64: install 'kernel-default'
786
787 SLES 11+ i586: install 'kernel-pae'
788 x86-64: install 'kernel-default'
789
790 Windows (Does not apply, as there is no Xen PV Windows kernel)
791
792 Enabling virtio
793 "Virtio" is the name for a set of drivers which make disk (block
794 device), network and other guest operations work much faster on KVM.
795
796 Older versions of virt-v2v could install these drivers for certain
797 Linux guests. This version of virt-v2v does not attempt to install new
798 Linux kernels or drivers, but will warn you if they are not installed
799 already.
800
801 In order to enable virtio, and hence improve performance of the guest
802 after conversion, you should ensure that the minimum versions of
803 packages are installed before conversion, by consulting the table
804 below.
805
806 RHEL 3 No virtio drivers are available
807
808 RHEL 4 kernel >= 2.5.9-89.EL
809 lvm2 >= 2.02.42-5.el4
810 device-mapper >= 1.02.28-2.el4
811 selinux-policy-targeted >= 1.17.30-2.152.el4
812 policycoreutils >= 1.18.1-4.13
813
814 RHEL 5 kernel >= 2.6.18-128.el5
815 lvm2 >= 2.02.40-6.el5
816 selinux-policy-targeted >= 2.4.6-203.el5
817
818 RHEL 6+ All versions support virtio
819
820 Fedora All versions support virtio
821
822 SLES 11+ All versions support virtio
823
824 SLES 10 kernel >= 2.6.16.60-0.85.1
825
826 OpenSUSE 11+ All versions support virtio
827
828 OpenSUSE 10 kernel >= 2.6.25.5-1.1
829
830 Debian 6+ All versions support virtio
831
832 Ubuntu 10.04+ All versions support virtio
833
834 Windows Drivers are installed from the ISO or directory pointed
835 to by "VIRTIO_WIN" environment variable if present
836
837 RHEL 4: SELinux relabel appears to hang forever
838 In RHEL ≤ 4.7 there was a bug which causes SELinux relabelling to
839 appear to hang forever at:
840
841 *** Warning -- SELinux relabel is required. ***
842 *** Disabling security enforcement. ***
843 *** Relabeling could take a very long time, ***
844 *** depending on file system size. ***
845
846 In reality it is waiting for you to press a key (but there is no visual
847 indication of this). You can either hit the "[Return]" key, at which
848 point the guest will finish relabelling and reboot, or you can install
849 policycoreutils ≥ 1.18.1-4.13 before starting the v2v conversion. See
850 also https://bugzilla.redhat.com/show_bug.cgi?id=244636
851
852 Debian and Ubuntu
853 "warning: could not determine a way to update the configuration of
854 Grub2"
855
856 Currently, virt-v2v has no way to set the default kernel in Debian and
857 Ubuntu guests using GRUB 2 as bootloader. This means that virt-v2v
858 will not change the default kernel used for booting, even in case it is
859 not the best kernel available on the guest. A recommended procedure
860 is, before using virt-v2v, to check that the boot kernel is the best
861 kernel available in the guest (for example by making sure the guest is
862 up-to-date).
863
864 "vsyscall attempted with vsyscall=none"
865
866 When run on a recent Debian host virt-v2v may fail to convert guests
867 which were created before 2013. In the debugging output you will see a
868 crash message similar to:
869
870 vsyscall attempted with vsyscall=none ip:...
871 segfault at ...
872
873 This is caused because Debian removed support for running old binaries
874 which used the legacy vsyscall page to call into the kernel.
875
876 You can work around this problem by running this command before running
877 virt-v2v:
878
879 export LIBGUESTFS_APPEND="vsyscall=emulate"
880
881 For more information, see https://bugzilla.redhat.com/1592061
882
883 Windows
884 Windows ≥ 8 Fast Startup is incompatible with virt-v2v
885
886 Guests which use the Windows ≥ 8 "Fast Startup" feature (or guests
887 which are hibernated) cannot be converted with virt-v2v. You will see
888 an error:
889
890 virt-v2v: error: unable to mount the disk image for writing. This has
891 probably happened because Windows Hibernation or Fast Restart is being
892 used in this guest. You have to disable this (in the guest) in order
893 to use virt-v2v.
894
895 As the message says, you need to boot the guest and disable the "Fast
896 Startup" feature (Control Panel → Power Options → Choose what the power
897 buttons do → Change settings that are currently unavailable → Turn on
898 fast startup), and shut down the guest, and then you will be able to
899 convert it.
900
901 For more information, see: "WINDOWS HIBERNATION AND WINDOWS 8 FAST
902 STARTUP" in guestfs(3).
903
904 Boot failure: 0x0000007B
905
906 This boot failure is caused by Windows being unable to find or load the
907 right disk driver (eg. viostor.sys). If you experience this error,
908 here are some things to check:
909
910 · First ensure that the guest boots on the source hypervisor before
911 conversion.
912
913 · Check you have the Windows virtio drivers available in
914 /usr/share/virtio-win, and that virt-v2v did not print any warning
915 about not being able to install virtio drivers.
916
917 On Red Hat Enterprise Linux 7, you will need to install the signed
918 drivers available in the "virtio-win" package. If you do not have
919 access to the signed drivers, then you will probably need to
920 disable driver signing in the boot menus.
921
922 · Check that you are presenting a virtio-blk interface (not virtio-
923 scsi and not ide) to the guest. On the qemu/KVM command line you
924 should see something similar to this:
925
926 ... -drive file=windows-sda,if=virtio ...
927
928 In libvirt XML, you should see:
929
930 <target dev='vda' bus='virtio'/>
931
932 · Check that Windows Group Policy does not prevent the driver from
933 being installed or used. Try deleting Windows Group Policy before
934 conversion.
935
936 · Check there is no anti-virus or other software which implements
937 Group Policy-like prohibitions on installing or using new drivers.
938
939 · Enable boot debugging and check the viostor.sys driver is being
940 loaded.
941
942 OpenStack and Windows reactivation
943
944 OpenStack does not offer stable device / PCI addresses to guests.
945 Every time it creates or starts a guest, it regenerates the libvirt XML
946 for that guest from scratch. The libvirt XML will have no <address>
947 fields. Libvirt will then assign addresses to devices, in a
948 predictable manner. Addresses may change if any of the following are
949 true:
950
951 · A new disk or network device has been added or removed from the
952 guest.
953
954 · The version of OpenStack or (possibly) libvirt has changed.
955
956 Because Windows does not like "hardware" changes of this kind, it may
957 trigger Windows reactivation.
958
959 This can also prevent booting with a 7B error [see previous section] if
960 the guest has group policy containing "Device Installation
961 Restrictions".
962
963 Support for SHA-2 certificates in Windows 7 and Windows Server 2008 R2
964
965 Later versions of the Windows virtio drivers are signed using SHA-2
966 certificates (instead of SHA-1). The original shipping Windows 7 and
967 Windows Server 2008 R2 did not understand SHA-2 certificates and so the
968 Windows virtio drivers will not install properly.
969
970 To fix this you must apply SHA-2 Code Signing Support from:
971 https://docs.microsoft.com/en-us/security-updates/SecurityAdvisories/2015/3033929
972 before converting the guest.
973
974 For further information see:
975 https://bugzilla.redhat.com/show_bug.cgi?id=1624878
976
977 Networks and bridges
978 Guests are usually connected to one or more networks, and when
979 converted to the target hypervisor you usually want to reconnect those
980 networks at the destination. The options --network, --bridge and --mac
981 allow you to do that.
982
983 If you are unsure of what networks and bridges are in use on the source
984 hypervisor, then you can examine the source metadata (libvirt XML,
985 vCenter information, etc.). Or you can run virt-v2v with the
986 --print-source option which causes virt-v2v to print out the
987 information it has about the guest on the source and then exit.
988
989 In the --print-source output you will see a section showing the guest’s
990 Network Interface Cards (NICs):
991
992 $ virt-v2v [-i ...] --print-source name
993 [...]
994 NICs:
995 Network "default" mac: 52:54:00:d0:cf:0e
996
997 Bridges are special classes of network devices which are attached to a
998 named external network on the source hypervisor, for example:
999
1000 $ virt-v2v [-i ...] --print-source name
1001 [...]
1002 NICs:
1003 Bridge "br0"
1004
1005 To map a specific source bridge to a target network, for example "br0"
1006 on the source to "ovirtmgmt" on the target, use:
1007
1008 virt-v2v [...] --bridge br0:ovirtmgmt
1009
1010 To map every bridge to a target network, use:
1011
1012 virt-v2v [...] --bridge ovirtmgmt
1013
1014 Fine-grained mapping of guest NICs
1015
1016 The --mac option gives you more control over the mapping, letting you
1017 map single NICs to either networks or bridges on the target. For
1018 example a source guest with two NICs could map them individually to two
1019 networks called "mgmt" and "clientdata" like this:
1020
1021 $ virt-v2v [...] \
1022 --mac 52:54:00:d0:cf:0e:network:mgmt \
1023 --mac 52:54:00:d0:cf:0f:network:clientdata
1024
1025 Note that virt-v2v does not have the ability to change a guest’s MAC
1026 address. The MAC address is part of the guest metadata and must remain
1027 the same on source and target hypervisors. Most guests will use the
1028 MAC address to set up persistent associations between NICs and internal
1029 names (like "eth0"), with firewall settings, or even for other purposes
1030 like software licensing.
1031
1032 Resource requirements
1033 Network
1034
1035 The most important resource for virt-v2v appears to be network
1036 bandwidth. Virt-v2v should be able to copy guest data at gigabit
1037 ethernet speeds or greater.
1038
1039 Ensure that the network connections between servers (conversion server,
1040 NFS server, vCenter, Xen) are as fast and as low latency as possible.
1041
1042 Disk space
1043
1044 Virt-v2v places potentially large temporary files in
1045 $LIBGUESTFS_CACHEDIR (which is /var/tmp if you don't set it). Using
1046 tmpfs is a bad idea.
1047
1048 For each guest disk, an overlay is stored temporarily. This stores the
1049 changes made during conversion, and is used as a cache. The overlays
1050 are not particularly large - tens or low hundreds of megabytes per disk
1051 is typical. In addition to the overlay(s), input and output methods
1052 may use disk space, as outlined in the table below.
1053
1054 -i ova
1055 This temporarily places a full copy of the uncompressed source
1056 disks in $LIBGUESTFS_CACHEDIR (or /var/tmp).
1057
1058 -o glance
1059 This temporarily places a full copy of the output disks in
1060 $LIBGUESTFS_CACHEDIR (or /var/tmp).
1061
1062 -o local
1063 -o qemu
1064 You must ensure there is sufficient space in the output directory
1065 for the converted guest.
1066
1067 See also "Minimum free space check in the host" below.
1068
1069 VMware vCenter resources
1070
1071 Copying from VMware vCenter is currently quite slow, but we believe
1072 this to be an issue with VMware. Ensuring the VMware ESXi hypervisor
1073 and vCenter are running on fast hardware with plenty of memory should
1074 alleviate this.
1075
1076 Compute power and RAM
1077
1078 Virt-v2v is not especially compute or RAM intensive. If you are
1079 running many parallel conversions, then you may consider allocating one
1080 CPU core and 2 GB of RAM per running instance.
1081
1082 Virt-v2v can be run in a virtual machine.
1083
1084 Trimming
1085
1086 Virt-v2v attempts to optimize the speed of conversion by ignoring guest
1087 filesystem data which is not used. This would include unused
1088 filesystem blocks, blocks containing zeroes, and deleted files.
1089
1090 To do this, virt-v2v issues a non-destructive fstrim(8) operation. As
1091 this happens to an overlay placed over the guest data, it does not
1092 affect the source in any way.
1093
1094 If this fstrim operation fails, you will see a warning, but virt-v2v
1095 will continue anyway. It may run more slowly (in some cases much more
1096 slowly), because it is copying the unused parts of the disk.
1097
1098 Unfortunately support for fstrim is not universal, and it also depends
1099 on specific details of the filesystem, partition alignment, and backing
1100 storage. As an example, NTFS filesystems cannot be fstrimmed if they
1101 occupy a partition which is not aligned to the underlying storage.
1102 That was the default on Windows before Vista. As another example, VFAT
1103 filesystems (used by UEFI guests) cannot be trimmed at all.
1104
1105 fstrim support in the Linux kernel is improving gradually, so over time
1106 some of these restrictions will be lifted and virt-v2v will work
1107 faster.
1108
1109 Post-conversion tasks
1110 Guest network configuration
1111
1112 Virt-v2v cannot currently reconfigure a guest’s network configuration.
1113 If the converted guest is not connected to the same subnet as the
1114 source, its network configuration may have to be updated. See also
1115 virt-customize(1).
1116
1117 Converting a Windows guest
1118
1119 When converting a Windows guests, the conversion process is split into
1120 two stages:
1121
1122 1. Offline conversion.
1123
1124 2. First boot.
1125
1126 The guest will be bootable after the offline conversion stage, but will
1127 not yet have all necessary drivers installed to work correctly. These
1128 will be installed automatically the first time the guest boots.
1129
1130 N.B. Take care not to interrupt the automatic driver installation
1131 process when logging in to the guest for the first time, as this may
1132 prevent the guest from subsequently booting correctly.
1133
1134 Free space for conversion
1135 Free space in the guest
1136
1137 Virt-v2v checks there is sufficient free space in the guest filesystem
1138 to perform the conversion. Currently it checks:
1139
1140 Linux root filesystem or Windows "C:" drive
1141 Minimum free space: 20 MB
1142
1143 Linux /boot
1144 Minimum free space: 50 MB
1145
1146 This is because we need to build a new initramfs for some
1147 Enterprise Linux conversions.
1148
1149 Any other mountable filesystem
1150 Minimum free space: 10 MB
1151
1152 In addition to the actual free space, each filesystem is required to
1153 have at least 100 available inodes.
1154
1155 Minimum free space check in the host
1156
1157 You must have sufficient free space in the host directory used to store
1158 temporary overlays (except in --in-place mode). To find out which
1159 directory this is, use:
1160
1161 $ df -h "`guestfish get-cachedir`"
1162 Filesystem Size Used Avail Use% Mounted on
1163 /dev/mapper/root 50G 40G 6.8G 86% /
1164
1165 and look under the "Avail" column. Virt-v2v will refuse to do the
1166 conversion at all unless at least 1GB is available there.
1167
1168 See also "Resource requirements" above.
1169
1170 Running virt-v2v as root or non-root
1171 Nothing in virt-v2v inherently needs root access, and it will run just
1172 fine as a non-root user. However, certain external features may
1173 require either root or a special user:
1174
1175 Mounting the Export Storage Domain
1176 When using -o rhv -os server:/esd virt-v2v has to have sufficient
1177 privileges to NFS mount the Export Storage Domain from "server".
1178
1179 You can avoid needing root here by mounting it yourself before
1180 running virt-v2v, and passing -os /mountpoint instead, but first of
1181 all read the next section ...
1182
1183 Writing to the Export Storage Domain as 36:36
1184 RHV-M cannot read files and directories from the Export Storage
1185 Domain unless they have UID:GID 36:36. You will see VM import
1186 problems if the UID:GID is not correct.
1187
1188 When you run virt-v2v -o rhv as root, virt-v2v attempts to create
1189 files and directories with the correct ownership. If you run
1190 virt-v2v as non-root, it will probably still work, but you will
1191 need to manually change ownership after virt-v2v has finished.
1192
1193 Writing to libvirt
1194 When using -o libvirt, you may need to run virt-v2v as root so that
1195 it can write to the libvirt system instance (ie. "qemu:///system")
1196 and to the default location for disk images (usually
1197 /var/lib/libvirt/images).
1198
1199 You can avoid this by setting up libvirt connection authentication,
1200 see http://libvirt.org/auth.html. Alternatively, use -oc
1201 qemu:///session, which will write to your per-user libvirt
1202 instance.
1203
1204 Writing to Openstack
1205 Because of how Cinder volumes are presented as /dev block devices,
1206 using -o openstack normally requires that virt-v2v is run as root.
1207
1208 Writing to Glance
1209 This does not need root (in fact it probably won’t work), but may
1210 require either a special user and/or for you to source a script
1211 that sets authentication environment variables. Consult the Glance
1212 documentation.
1213
1214 Minimal XML for -i libvirtxml option
1215 When using the -i libvirtxml option, you have to supply some libvirt
1216 XML. Writing this from scratch is hard, so the template below is
1217 helpful.
1218
1219 Note this should only be used for testing and/or where you know what
1220 you're doing! If you have libvirt metadata for the guest, always use
1221 that instead.
1222
1223 <domain type='kvm'>
1224 <name> NAME </name>
1225 <memory>1048576</memory>
1226 <vcpu>2</vcpu>
1227 <os>
1228 <type>hvm</type>
1229 <boot dev='hd'/>
1230 </os>
1231 <features>
1232 <acpi/>
1233 <apic/>
1234 <pae/>
1235 </features>
1236 <devices>
1237 <disk type='file' device='disk'>
1238 <driver name='qemu' type='raw'/>
1239 <source file='/path/to/disk/image'/>
1240 <target dev='hda' bus='ide'/>
1241 </disk>
1242 <interface type='network'>
1243 <mac address='52:54:00:01:02:03'/>
1244 <source network='default'/>
1245 <model type='rtl8139'/>
1246 </interface>
1247 </devices>
1248 </domain>
1249
1250 In-place conversion
1251 It is also possible to use virt-v2v in scenarios where a foreign VM has
1252 already been imported into a KVM-based hypervisor, but still needs
1253 adjustments in the guest to make it run in the new virtual hardware.
1254
1255 In that case it is assumed that a third-party tool has created the
1256 target VM in the supported KVM-based hypervisor based on the source VM
1257 configuration and contents, but using virtual devices more appropriate
1258 for KVM (e.g. virtio storage and network, etc.).
1259
1260 Then, to make the guest OS boot and run in the changed environment, one
1261 can use:
1262
1263 virt-v2v -ic qemu:///system converted_vm --in-place
1264
1265 Virt-v2v will analyze the configuration of "converted_vm" in the
1266 "qemu:///system" libvirt instance, and apply various fixups to the
1267 guest OS configuration to make it match the VM configuration. This may
1268 include installing virtio drivers, configuring the bootloader, the
1269 mountpoints, the network interfaces, and so on.
1270
1271 Should an error occur during the operation, virt-v2v exits with an
1272 error code leaving the VM in an undefined state.
1273
1274 Machine readable output
1275 The --machine-readable option can be used to make the output more
1276 machine friendly, which is useful when calling virt-v2v from other
1277 programs, GUIs etc.
1278
1279 There are two ways to use this option.
1280
1281 Firstly use the option on its own to query the capabilities of the
1282 virt-v2v binary. Typical output looks like this:
1283
1284 $ virt-v2v --machine-readable
1285 virt-v2v
1286 libguestfs-rewrite
1287 colours-option
1288 vdsm-compat-option
1289 input:disk
1290 [...]
1291 output:local
1292 [...]
1293 convert:linux
1294 convert:windows
1295
1296 A list of features is printed, one per line, and the program exits with
1297 status 0.
1298
1299 The "input:" and "output:" features refer to -i and -o (input and
1300 output mode) options supported by this binary. The "convert:" features
1301 refer to guest types that this binary knows how to convert.
1302
1303 Secondly use the option in conjunction with other options to make the
1304 regular program output more machine friendly.
1305
1306 At the moment this means:
1307
1308 1. Progress bar messages can be parsed from stdout by looking for this
1309 regular expression:
1310
1311 ^[0-9]+/[0-9]+$
1312
1313 2. The calling program should treat messages sent to stdout (except
1314 for progress bar messages) as status messages. They can be logged
1315 and/or displayed to the user.
1316
1317 3. The calling program should treat messages sent to stderr as error
1318 messages. In addition, virt-v2v exits with a non-zero status code
1319 if there was a fatal error.
1320
1321 Virt-v2v ≤ 0.9.1 did not support the --machine-readable option at all.
1322 The option was added when virt-v2v was rewritten in 2014.
1323
1324 It is possible to specify a format string for controlling the output;
1325 see "ADVANCED MACHINE READABLE OUTPUT" in guestfs(3).
1326
1328 /usr/share/virtio-win
1329 (Optional)
1330
1331 If this directory is present, then virtio drivers for Windows
1332 guests will be found from this directory and installed in the guest
1333 during conversion.
1334
1336 "LIBGUESTFS_CACHEDIR"
1337 Location of the temporary directory used for the potentially large
1338 temporary overlay file. If not set, /var/tmp is used.
1339
1340 See the "Disk space" section above.
1341
1342 "VIRT_TOOLS_DATA_DIR"
1343 This can point to the directory containing data files used for
1344 Windows conversion.
1345
1346 Normally you do not need to set this. If not set, a compiled-in
1347 default will be used (something like /usr/share/virt-tools).
1348
1349 This directory may contain the following files:
1350
1351 rhsrvany.exe
1352 (Required when doing conversions of Windows guests)
1353
1354 This is the RHSrvAny Windows binary, used to install a
1355 "firstboot" script in the guest during conversion of Windows
1356 guests.
1357
1358 See also: "https://github.com/rwmjones/rhsrvany"
1359
1360 pvvxsvc.exe
1361 This is a Windows binary shipped with SUSE VMDP, used to
1362 install a "firstboot" script in Windows guests. It is required
1363 if you intend to use the --firstboot or --firstboot-command
1364 options with Windows guests.
1365
1366 rhev-apt.exe
1367 (Optional)
1368
1369 The RHV Application Provisioning Tool (RHEV APT). If this file
1370 is present, then RHEV APT will be installed in the Windows
1371 guest during conversion. This tool is a guest agent which
1372 ensures that the virtio drivers remain up to date when the
1373 guest is running on Red Hat Virtualization (RHV).
1374
1375 This file comes from Red Hat Virtualization (RHV), and is not
1376 distributed with virt-v2v.
1377
1378 "VIRTIO_WIN"
1379 This is where virtio drivers for Windows are searched for. It can
1380 be a directory or point to virtio-win.iso (CD ROM image containing
1381 drivers).
1382
1383 If unset, then we look for drivers in whichever of these paths is
1384 found first:
1385
1386 /usr/share/virtio-win/virtio-win.iso
1387 The ISO containing virtio drivers for Windows.
1388
1389 /usr/share/virtio-win
1390 The exploded tree of virtio drivers for Windows. This is
1391 usually incomplete, hence the ISO is preferred.
1392
1393 See "Enabling virtio".
1394
1395 For other environment variables, see "ENVIRONMENT VARIABLES" in
1396 guestfs(3).
1397
1399 virt-v2v-copy-to-local(1)
1400 There are some special cases where virt-v2v cannot directly access
1401 the remote hypervisor. In that case you have to use
1402 virt-v2v-copy-to-local(1) to make a local copy of the guest first,
1403 followed by running "virt-v2v -i libvirtxml" to perform the
1404 conversion.
1405
1406 engine-image-uploader(8)
1407 Variously called "engine-image-uploader", "ovirt-image-uploader" or
1408 "rhevm-image-uploader", this tool allows you to copy a guest from
1409 one oVirt or RHV Export Storage Domain to another. It only permits
1410 importing a guest that was previously exported from another
1411 oVirt/RHV instance.
1412
1413 import-to-ovirt.pl
1414 This script can be used to import guests that already run on KVM to
1415 oVirt or RHV. For more information, see this blog posting by the
1416 author of virt-v2v:
1417
1418 https://rwmj.wordpress.com/2015/09/18/importing-kvm-guests-to-ovirt-or-rhev/#content
1419
1421 virt-p2v(1), virt-customize(1), virt-df(1), virt-filesystems(1),
1422 virt-sparsify(1), virt-sysprep(1), guestfs(3), guestfish(1),
1423 qemu-img(1), virt-v2v-copy-to-local(1), virt-v2v-test-harness(1),
1424 engine-image-uploader(8), import-to-ovirt.pl, nbdkit(1),
1425 nbdkit-vddk-plugin(1), http://libguestfs.org/.
1426
1428 Matthew Booth
1429
1430 Cédric Bosdonnat
1431
1432 Tomáš Golembiovský
1433
1434 Shahar Havivi
1435
1436 Roman Kagan
1437
1438 Mike Latimer
1439
1440 Nir Soffer
1441
1442 Richard W.M. Jones
1443
1444 Pino Toscano
1445
1446 Tingting Zheng
1447
1449 Copyright (C) 2009-2020 Red Hat Inc.
1450
1452 This program is free software; you can redistribute it and/or modify it
1453 under the terms of the GNU General Public License as published by the
1454 Free Software Foundation; either version 2 of the License, or (at your
1455 option) any later version.
1456
1457 This program is distributed in the hope that it will be useful, but
1458 WITHOUT ANY WARRANTY; without even the implied warranty of
1459 MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
1460 General Public License for more details.
1461
1462 You should have received a copy of the GNU General Public License along
1463 with this program; if not, write to the Free Software Foundation, Inc.,
1464 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA.
1465
1467 To get a list of bugs against libguestfs, use this link:
1468 https://bugzilla.redhat.com/buglist.cgi?component=libguestfs&product=Virtualization+Tools
1469
1470 To report a new bug against libguestfs, use this link:
1471 https://bugzilla.redhat.com/enter_bug.cgi?component=libguestfs&product=Virtualization+Tools
1472
1473 When reporting a bug, please supply:
1474
1475 · The version of libguestfs.
1476
1477 · Where you got libguestfs (eg. which Linux distro, compiled from
1478 source, etc)
1479
1480 · Describe the bug accurately and give a way to reproduce it.
1481
1482 · Run libguestfs-test-tool(1) and paste the complete, unedited output
1483 into the bug report.
1484
1485
1486
1487virt-v2v-1.42.0 2020-04-16 virt-v2v(1)