为什么会出现 Unable to load library ‘virt’
很多人在使用 libvirt Java API 时可能都会遇到这个错误,直观来说就是:无法加载‘virt’库。
Java 虚拟机会抛出一个 UnsatisfiedLinkError 错误。
java.lang.UnsatisfiedLinkError: Unable to load library 'virt': libvirt.so: cannot open shared object file: No such file or directory at com.sun.jna.NativeLibrary.loadLibrary(NativeLibrary.java:194) ~[jna-3.5.0.jar!/:3.5.0 (b0)] at com.sun.jna.NativeLibrary.getInstance(NativeLibrary.java:283) ~[jna-3.5.0.jar!/:3.5.0 (b0)] at com.sun.jna.Library$Handler.<init>(Library.java:142) ~[jna-3.5.0.jar!/:3.5.0 (b0)] at com.sun.jna.Native.loadLibrary(Native.java:368) ~[jna-3.5.0.jar!/:3.5.0 (b0)] at com.sun.jna.Native.loadLibrary(Native.java:353) ~[jna-3.5.0.jar!/:3.5.0 (b0)] at org.libvirt.jna.Libvirt.<clinit>(Unknown Source) ~[libvirt-0.5.1.jar!/:na] at org.libvirt.Library.<clinit>(Unknown Source) ~[libvirt-0.5.1.jar!/:na] at org.libvirt.Connect.<init>(Unknown Source) ~[libvirt-0.5.1.jar!/:na] at com.jm.controller.LibvirtCtrl.test(LibvirtCtrl.java:42) ~[classes!/:na] at sun.reflect.NativeMethodAccessorImpl.invoke0(Native Method) ~[na:1.8.0_131] at sun.reflect.NativeMethodAccessorImpl.invoke(NativeMethodAccessorImpl.java:62) ~[na:1.8.0_131] ......在 Ubuntu 16.04 下的错误内容如图所示。
之所以出现这个错误是由于你的程序所在的服务器没有安装 libvirt 动态链接库所致。
解决 Unable to load library ‘virt’在 Java 微服务程序所在的服务器安装 libvirt 的动态链接库,如在 Ubuntu 16.04 下使用 APT 源安装 libvirt-dev 包的命令如下所示。
sudo apt-get install -y libvirt-dev或者使用如下命令安装 libvirt-bin。
sudo apt-get install -y libvirt-binlibvirt-dev 和 libvirt-bin 的区别在于 libvirt-dev 是libvirt-bin 的简化版,功能少,体积小,方便移植到 Docker 容器。