本周做一个小项目,使用curl中的接口实现https协议,调用了openssl库,编译通过后执行报错./curl:symbol lookup error:./curl:undefined symbol:SSL_COMP_free_compression_methods,这种问题通常是调用的接口没有找到函数的实现接口,运行中没有找到依赖的库文件。
第一眼的想法就觉得不应该存在这个问题,因为在调用这些库接口前,就使用了libcurl编译出来的curl进程进行使用,能够正常使用,不应该存在这一问题。
接着进行下一步的分析。首先使用nm命令查看了依赖的动态库是否存在这个接口,确认了这个接口是存在于这个库里面的,可以确认使用的这个库是OK的。
对于引用动态库,如果编译时不报错,说明编译时的路径是对的,那现在这个情况,就只有一种可能,执行时调用的库路径不正确。就使用ldd命令查看了编译生成的可执行文件依赖的三方库,发现库的路径不准确。找到错误的库的路径,发现编译器上已经装了一个openssl库,才使得我调用curl进程时能够正常运行。既然找到原因了,就尝试去解决。先修改LD_PRELOAD环境变量为我依赖库所在的路径,执行就能够通过了。
以前总认为编译和执行都是用的同一个路径下的库文件,经过这个问题后才知道编译时用的库和执行时用的库不是同一个,执行时是在LD_PRELOAD环境变量下的库逐级查找依赖的库,最后通过修改环境变量解决了这个问题