Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

Use the libvirt API to obtain domain IP address #40

Open
wants to merge 2 commits into
base: master
Choose a base branch
from

Conversation

flavio
Copy link
Contributor

@flavio flavio commented Apr 5, 2017

This is a complete revamp of #2.

The code has been changed to use the right API provided by the official libvirt-go bindings. The previous PR was using a different Go binding library.

@@ -1,4 +1,4 @@
default: build

build:
GOGC=off go build -i -o docker-machine-driver-kvm
GOGC=off go build -tags libvirt.1.2.14 -i -o docker-machine-driver-kvm
Copy link
Owner

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Unfortunately I don't have a physical ubuntu 14.04 box (or other older LTS distro) to try this out at the moment. Was this alone sufficient to have this all hold together where it both compiles and doesn't do something nasty at runtime when the underlying API isn't present? Maybe enough time has passed that we can ignore the older LTS distros, but I was hoping to keep this compatible for a while if possible.

Copy link
Contributor Author

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

I don't have access to such a machine. However latest Ubuntu LTS (xenial 16.04LTS) has version 1.3.1 available.

Personally I would ignore 14.04.

Copy link
Owner

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

I've been meaning to improve the build a bit... and this helped motivate me to get some extra build support in place to generate binaries for various host systems. f328c4b

I think we should be able to at least partially answer the compatibility question on this PR by seeing if it builds on ubuntu14.04. Then we could try to do a create in a container, which should fail due to the missing libvirt socket, but as long as it errors that way and not with some obscure C lib link problem, then I think we're good.

Copy link
Contributor Author

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

I rebased my changes against your master, this is the error I get when I try to build the code inside of 14.04:

# github.com/dhiltgen/docker-machine-kvm
./kvm.go:596: cannot use uint(libvirt.DOMAIN_INTERFACE_ADDRESSES_SRC_LEASE) (type uint) as type libvirt.DomainInterfaceAddressesSource in argument to d.VM.ListAllInterfaceAddresses

Do you think it's acceptable?

flavio added 2 commits May 1, 2017 08:54
Requires libvirt >= 1.2.6. The tag libvirt.1.2.14 is required by
libvirt-go to enable its use, since a wider range of libvirt versions
are supported there.

Initial patch provided by Casey Marshall <casey.marshall@canonical.com>
Changed the code to use the native libvirt API provided by the official
Go bindings.

Signed-off-by: Flavio Castelli <fcastelli@suse.com>
@flavio flavio force-pushed the libvirt-address-api branch from ccf9e5a to f720110 Compare May 1, 2017 06:55
Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
None yet
Projects
None yet
Development

Successfully merging this pull request may close these issues.

2 participants