引用Net::ZooKeeper这个包,可能会报这个错误
Can't load '/usr/local/lib64/perl5/auto/Net/ZooKeeper/ZooKeeper.so' for module Net::ZooKeeper: /usr/local/lib64/perl5/auto/Net/ZooKeeper/ZooKeeper.so: undefined symbol: ZOO_PERM_CREATE at /usr/lib64/perl5/XSLoader.pm line 70.
at /usr/local/lib64/perl5/Net/ZooKeeper.pm line 109. 查看XSLoader.pm的70行:
70 my $libref = dl_load_file($file, 0) or do {
71 require Carp;
72 Carp::croak("Can't load '$file' for module $module: " . dl_error());
73 }; 实际上是加载ZooKeeper.so这个动态链接库。我们objdump,看看这个缺少的符号到底有没有在这个链接库里面。
[zhangbin@localhost xoa2-perl]$ objdump -x /usr/local/lib64/perl5/auto/Net/ZooKeeper/ZooKeeper.so | grep ZOO
0000000000000000 *UND* 0000000000000000 ZOO_PERM_CREATE
0000000000000000 *UND* 0000000000000000 ZOO_READ_ACL_UNSAFE
0000000000000000 *UND* 0000000000000000 ZOO_PERM_WRITE
0000000000000000 *UND* 0000000000000000 ZOO_ASSOCIATING_STATE
0000000000000000 *UND* 0000000000000000 ZOO_CREATED_EVENT
0000000000000000 *UND* 0000000000000000 ZOO_CONNECTED_STATE
0000000000000000 *UND* 0000000000000000 ZOO_AUTH_FAILED_STATE
0000000000000000 *UND* 0000000000000000 ZOO_EPHEMERAL
0000000000000000 *UND* 0000000000000000 ZOO_SEQUENCE
0000000000000000 *UND* 0000000000000000 ZOO_PERM_READ
0000000000000000 *UND* 0000000000000000 ZOO_CREATOR_ALL_ACL
0000000000000000 *UND* 0000000000000000 ZOO_PERM_ALL
0000000000000000 *UND* 0000000000000000 ZOO_DELETED_EVENT
0000000000000000 *UND* 0000000000000000 ZOO_OPEN_ACL_UNSAFE
0000000000000000 *UND* 0000000000000000 ZOO_PERM_ADMIN
0000000000000000 *UND* 0000000000000000 ZOO_CONNECTING_STATE
0000000000000000 *UND* 0000000000000000 ZOO_EXPIRED_SESSION_STATE
0000000000000000 *UND* 0000000000000000 ZOO_NOTWATCHING_EVENT
0000000000000000 *UND* 0000000000000000 ZOO_PERM_DELETE
0000000000000000 *UND* 0000000000000000 ZOO_CHANGED_EVENT
0000000000000000 *UND* 0000000000000000 ZOO_CHILD_EVENT
0000000000000000 *UND* 0000000000000000 ZOO_SESSION_EVENT 标记为UND,说明这是一个外部符号,应该是需要引用其他库,估计是zookeeper库。但是lib包已经加入了LD_LIBRARY_PATH,非常奇怪。
尝试重新编译ZooKeeper.so(源码在zookeeper的contrib/zkperl下),发现发布包是用MakeMaker组织的,首先生成Makefile,获得下面的提示:
[zhangbin@localhost zkperl]$ perl Makefile.PL
Warning (mostly harmless): No library found for -lzookeeper_mt
Generating a Unix-style Makefile
Writing Makefile for Net::ZooKeeper
Writing MYMETA.yml and MYMETA.json 注意第一行的warning,这是解决问题的关键。Most harmless,but harm this time。查看 Makefile.PL的 第31行
31 GetOptions(
32 'zookeeper-include=s' => \@zk_inc_paths,
33 'zookeeper-lib=s' => \@zk_lib_paths
34 ); 可见第二个选项是必须的。
重新编译。
[zhangbin@localhost zkperl]$ perl Makefile.PL --zookeeper-lib=/home/zhangbin/env/lib
Checking if your kit is complete...
Looks good
Generating a Unix-style Makefile
Writing Makefile for Net::ZooKeeper
Writing MYMETA.yml and MYMETA.json 然后make && sudo make install。问题解决。
可能XSLoader没有自动从LD_LIBRARY_PATH寻找可用的库和符号表的机制。
运维网声明
1、欢迎大家加入本站运维交流群:群②:261659950 群⑤:202807635 群⑦870801961 群⑧679858003
2、本站所有主题由该帖子作者发表,该帖子作者与运维网 享有帖子相关版权
3、所有作品的著作权均归原作者享有,请您和我们一样尊重他人的著作权等合法权益。如果您对作品感到满意,请购买正版
4、禁止制作、复制、发布和传播具有反动、淫秽、色情、暴力、凶杀等内容的信息,一经发现立即删除。若您因此触犯法律,一切后果自负,我们对此不承担任何责任
5、所有资源均系网友上传或者通过网络收集,我们仅提供一个展示、介绍、观摩学习的平台,我们不对其内容的准确性、可靠性、正当性、安全性、合法性等负责,亦不承担任何法律责任
6、所有作品仅供您个人学习、研究或欣赏,不得用于商业或者其他用途,否则,一切后果均由您自己承担,我们对此不承担任何法律责任
7、如涉及侵犯版权等问题,请您及时通知我们,我们将立即采取措施予以解决
8、联系人Email:admin@iyunv.com 网址:www.yunweiku.com