问题描述:
用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