Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/enrico204/ovf-export
OVF/OVA export tool for libvirt
https://github.com/enrico204/ovf-export
libvirt ovf ovftool
Last synced: about 2 months ago
JSON representation
OVF/OVA export tool for libvirt
- Host: GitHub
- URL: https://github.com/enrico204/ovf-export
- Owner: Enrico204
- License: mit
- Created: 2022-01-21T18:23:25.000Z (almost 3 years ago)
- Default Branch: master
- Last Pushed: 2022-07-27T11:17:34.000Z (over 2 years ago)
- Last Synced: 2023-03-01T10:52:20.873Z (almost 2 years ago)
- Topics: libvirt, ovf, ovftool
- Language: Go
- Homepage:
- Size: 33.2 KB
- Stars: 2
- Watchers: 2
- Forks: 0
- Open Issues: 0
-
Metadata Files:
- Readme: README.md
- License: LICENSE
Awesome Lists containing this project
README
# ovf-export for libvirt
`ovf-export` generates OVF/OVA files from libvirt domains. Generated OVA/OVF
files can be imported in other hypervisors, like VirtualBox or VMware
Player/Workstation/ESXi.Also, `ovf` package can be used for serializing custom OVF files.
De-serializing is not supported at the moment. See "known issues" for details.**Beta software**: this code works for me, but it may not work in your system.
At the moment, the code is not tested with different environments. Feel free to
propose patches.## Usage
Requirements:
* `qemu-img`
* `tar` (only when generating OVA files)## Installation
```shell
$ go install gitlab.com/Enrico204/ovf-export/cmd/ovf-export@latest
```If you want to use this tool as library:
```shell
# Inside the project dir
$ go get gitlab.com/Enrico204/ovf-export
```## Usage
```shell
$ ovf-export -list
UUID Name
--------------------------------------------------------
0962a56e96144bdd99bd83418c3e425a debian10
61290c324b744d9095c6023520ddf72d openindiana
e7904362d30b4179977804d073f070b4 win10$ ovf-export -id 0962a56e96144bdd99bd83418c3e425a -output ~/debian10ovf -ova
```Libvirt URL can be specified via env variable `LIBVIRT_URL` or using the
command line flag `-libvirt-url`. It can be the path for the local socket, or
`hostname:port` for TCP connection. The default value is `/var/run/libvirt/libvirt-sock`.Use `-help` to list all command line flags:
```shell
$ ovf-export -help
-cdrom
Include CDROM/ISO images
-id string
Domain ID to export
-libvirt-url string
Libvirt URL
-list
List all inactive libvirt-utils domains (a.k.a. VMs)
-no-manifest
Skip generating manifest
-output string
OVF destination directory
-ova
Generate OVA after OVF
```## Known issues
* When exporting a domain with an IDE controller, VMware Workstation refuses to
import the OVA/OVF file due to "mismatch hash" for the VMDK (even if the hash
matches). A workaround is remove the manifest before importing the image.
* De-serializing a OVF file is not supported, and probably won't be supported
soon due a [limit in Go `encoding/xml` handling namespaced XML prefixes](https://github.com/golang/go/issues/9519).
* Currently, the program should be in the same machine as the `libvirt` daemon.
* `virtio` disk bus is not supported. Use SATA or IDE.# LICENSE
This code is released under MIT license. See [LICENSE](LICENSE) for details.