问题描述
用pyinstaller打包一个调用了xgboost的项目,打包时没有报错,但是运行打包生成的可执行文件时
报出了如下错误,但xxx/libxgboost.so这个文件确实存在。
error message(s): ["failed to load dynlib/dll 'xxx/libxgboost.so'. most likely this dynlib/dll was not found when the application was frozen."]
原因分析
经过排查:
发现是libxgboost.so的一个依赖库没有找到,进而导致了加载错误。
具体而言:
libxgboost.so要依赖libgomp-a34b3233.so.1.0.0这个库,但该库在系统中的名称为libgomp.so.1.0.0。
解决方法
将libgomp.so.1.0.0复制项目目录,并重命名为libgomp-a34b3233.so.1.0.0即可。
疑惑
直接运行未打包的python项目时,并不会触发上述错误,原因是什么呢?
猜测
不报错的原因是,python项目加载动态库时,用的是ctypes.cdll.loadlibrary函数,可能该函数的加载机制与pyinstaller生成的可执行文件的加载机制不同?
相关命令
- 查询一个动态库的依赖库:
objdump -x filename.so | grep needed
- 查询一个动态库是否存在:
ldconfig -p | grep libpthread
总结
以上为个人经验,希望能给大家一个参考,也希望大家多多支持代码网。
发表评论