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

Bindings fail to run on libvirtd 1.3.1 with Go 1.7 #136

Open
simar7 opened this issue Oct 31, 2016 · 6 comments
Open

Bindings fail to run on libvirtd 1.3.1 with Go 1.7 #136

simar7 opened this issue Oct 31, 2016 · 6 comments
Labels

Comments

@simar7
Copy link

simar7 commented Oct 31, 2016

Hello,

I was testing out these binding in a environment running libvirtd 1.3.1 and QEMU 2.5.0 and observed the following behavior:

vagrant@localhost:/kvmhost$ ./main --domainName smoketestvm2

Connecting to unix:///var/run/libvirt/libvirt-sock
2016/10/31 13:50:28 failed to create domain object: xdr:DecodeUint: EOF while decoding 4 bytes - read: '[]'
vagrant@localhost:/kvmhost$ virsh list
 Id    Name                           State
----------------------------------------------------
 4     smoketestvm2                   running

Has anything changed significantly between libvirtd 1.2.{1,2} and/or QEMU versions that has broken the bindings?

Would appreciate any insight into this.

@benlemasurier
Copy link
Contributor

benlemasurier commented Oct 31, 2016

Hey @simar7,

Looks like you may have found a bug! Can you provide me with a snippet of code that will reproduce this on 1.2.{1,2}?

@simar7
Copy link
Author

simar7 commented Nov 1, 2016

@benlemasurier the bindings work fine on 1.2.{1,2}. The problem seems to be on 1.3.1. To reproduce this you could try the domain_details example here: https://github.com/digitalocean/go-qemu/blob/master/examples/domain_details/main.go

go run examples/domain_details/main.go --domainName testVM

@benlemasurier
Copy link
Contributor

Thanks, @simar7. I just ran this against 2 local versions, 1.3.2 and 2.2.0 without any issue. From the error, I believe this is a bug somewhere in the go-libvirt library. I'm going to get a 1.3.1 instance spun up, in the meantime, can you provide me with any further details on your libvirt configuration? Your libvirtd.conf would definitely help the debugging process. Can you also try the same command as root?

Thanks again!

@simar7
Copy link
Author

simar7 commented Nov 1, 2016

Hey @benlemasurier thanks for looking into this. Here's my libvirtd.conf and here's sample run output again.

To confirm again, I'm running the following versions:

root@localhost:~# libvirtd --version
libvirtd (libvirt) 1.3.1
root@localhost:~# qemu-system-x86_64 --version
QEMU emulator version 2.5.0 (Debian 1:2.5+dfsg-5ubuntu10.5), Copyright (c) 2003-2008 Fabrice Bellard

@simar7
Copy link
Author

simar7 commented Nov 1, 2016

I also tried talking to libvirt over TCP here's the stdout:

vagrant@localhost:/opt/software/rebox/bin$ sudo ./domain_details --address="localhost:16509" --network=tcp --domainName="smoketestvm2"

Connecting to tcp://localhost:16509
2016/11/01 11:27:33 failed to create domain object: xdr:DecodeUint: EOF while decoding 4 bytes - read: '[]'
vagrant@localhost:/opt/software/rebox/bin$ virsh list
 Id    Name                           State
----------------------------------------------------
 1     smoketestvm2                   running

@simar7
Copy link
Author

simar7 commented Nov 1, 2016

Ok so as I mentioned in the IRC channel, I've seem to notice the following behavior:

Scenario 1: Go bindings work when built within a Vagrantbox running Ubuntu Xenial, Go 1.6.

Scenario 2: Go binding do not work when built on a Mac OS X machine running Go 1.7 with GOOS=linux and GOARCH=amd64

Has anything changed between Go versions? My initial guess would be the xdr:DecodeUint bits that show up when doing scenario 2, causing the bindings to fail.

@simar7 simar7 changed the title Bindings fail to run on libvirtd 1.3.1 Bindings fail to run on libvirtd 1.3.1 with Go 1.7 Nov 1, 2016
suryatmodulus pushed a commit to suryatmodulus/go-qemu that referenced this issue Oct 1, 2022
This involves some additional changes to overcome breaking changes from
go-libvirt.

These are the new changes in this revision of go-libvirt since the last
release go-qemu has been using:

* remove invitation to empty IRC channel
* rpc_test: use Libvirt.addStream to add streams
* MockLibvirt: deep-copy response before adding ID
* monitor socket conn state in initLibvirtComms
* libvirttest: use atomic to read "serial"
* integration: wait for Disconnected before assert
* add CODEOWNERS
* Merge pull request digitalocean#152 from clarkwalcott/readme_update_rpc_link
* Docs: Update README with working link
* expose Libvirt.Disconnected method
* Add NetworkUpdateCompat
* update libvirt configuration step for new releases
* search generated include directory for header files
* ci updates (digitalocean#142)
* integration tests (digitalocean#141)
* take dialer as input instead of already existing connection (digitalocean#140)
* support authentication via polkit (digitalocean#138)
* fix some stream problems (digitalocean#137)
* Merge pull request digitalocean#136 from digitalocean/jenni/fix_potential_segfault
* write lock only needed for actual write
* rm unneeded nil'ing of reader and writer
* socket Disconnect close can race with nil of conn
* Merge pull request digitalocean#135 from digitalocean/jenni/update_cgo
* run go get golang.org/x/tools/go/internal/cgo@v0.1.1
* Merge pull request digitalocean#134 from digitalocean/jenni/add_socket_type
* change socket to pointer ref
* Merge branch 'master' of github.com:digitalocean/go-libvirt into jenni/add_socket_type
* Merge pull request digitalocean#133 from digitalocean/jenni/fix_event_unsubscribe_race
* reorder stream shutdown/delete
* fix race in disconnect of event stream cleanup
* add socket type to handle socket connection management
* Merge pull request digitalocean#132 from digitalocean/jenni/fix_client_deadlock
* fix typo and func conciseness
* move listen and cleanup into a func
* add timeout on waiting for disconnected
* move temporary read error check to a function
* Libvirt chan socketCleanupDone -> disconnected
* fix accidental go fmt of generated files
* add connect/disconnect to unit tests
* add tests for callback cleanup on connection disconnect
* fix rpc lookup test
* fix deadlocked clients on lack of libvirt response
* add more robust connection error checking
* Merge pull request digitalocean#131 from digitalocean/jenni/fix_invalid_test_data
* fix incorrect test data
* Merge pull request digitalocean#130 from digitalocean/jenni/stream_shutdown
* fix missing stream shutdown in lifecycle subscribe
* Merge pull request digitalocean#129 from digitalocean/geoff/vet-cleanup
* remove travis config file
* Clean up some linter errors
* Merge pull request digitalocean#125 from dmacvicar/dmacvicar_puberror
* Run generators against libvirt 7.2.0
* Unexport From* (ErrorDomain)
* golint
* go fmt
* libvirt.Error: expose only Code and Message
* Run generators against libvirt 7.1.0
* go fmt
* Make libvirtError public (libvirt.Error)
* github actions (digitalocean#128)
* internal/event/stream: fixes unsafe queue access (digitalocean#127)
* Merge pull request digitalocean#124 from sam-github/check-wrapped-errors
* Check wrapped errors for IsNotFound()
* Fix two race conditions related to Disconnect (digitalocean#120)
* Merge pull request digitalocean#119 from weizhouapache/readme-add-tls-port
* README: Add missing tls port in example
* README: Add example connect to libvirt via TLS over TCP (digitalocean#118)
* Add overload for Connect() to allow other libvirt drivers (digitalocean#117)
Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
Projects
None yet
Development

No branches or pull requests

3 participants