LD_DEBUG 加 rpm -qf 帮你快速找到 undefined symbol 符号所在的动态库及 rpm 包

14 篇文章 3 订阅

问题描述

从某发行版仓库下载 rsyslogd 的 rpm 包,手动解压升级后,运行 rsyslogd 报符号未定义的错误。错误信息:

rsyslogd: symbol lookup error: rsyslogd: undefined symbol: fjson_global_do_case_sensitive_comparison

问题分析

使用 ldd 查看 rsyslogd 缺库情况,确认没有缺库。那只存在一种可能,就是依赖的某个库的版本不一致,低版本缺乏相应的符号,需要找到这个符号是由哪个 so 提供的,进而找到这个 so 归属的 rpm 包。

解决方法

安装发行版,在安装好的系统中设置 LD_DEBUG 变量,运行 rsyslogd 并检索 fjson_global_do_case_sensitive_comparison 符号从哪个 so 中找到。

命令示例:


[root@localhost ~]# LD_DEBUG='symbols' /usr/sbin/rsyslogd 2>&1 |grep fjson_global_do_case_sen
      3434:     symbol=fjson_global_do_case_sensitive_comparison;  lookup in file=/usr/sbin/rsyslogd [0]
      3434:     symbol=fjson_global_do_case_sensitive_comparison;  lookup in file=/lib64/libz.so.1 [0]
      3434:     symbol=fjson_global_do_case_sensitive_comparison;  lookup in file=/lib64/libpthread.so.0 [0]
      3434:     symbol=fjson_global_do_case_sensitive_comparison;  lookup in file=/lib64/libdl.so.2 [0]
      3434:     symbol=fjson_global_do_case_sensitive_comparison;  lookup in file=/lib64/librt.so.1 [0]
      3434:     symbol=fjson_global_do_case_sensitive_comparison;  lookup in file=/lib64/libestr.so.0 [0]
      3434:     symbol=fjson_global_do_case_sensitive_comparison;  lookup in file=/lib64/libfastjson.so.4 [0]

上述输出表明此符号由 /lib64/libfastjson.so.4 文件提供。

找到提供这个库的 rpm 包

使用 rpm -qf 参数可以找到系统安装目录中指定文件归属的 rpm 包,执行示例:

[root@localhost ~]# rpm -qf /lib64/libfastjson.so.4
libfastjson-0.99.8-3.oe1.x86_64

相关的 rpm 包为 libfastjson-0.99.8-3.oe1.x86_64,下载此包并安装,问题得到解决!

一点点引申

我在 man ld.so 的翻译 这篇文章中有描述过 LD_DEBUG 变量的功能,它除了 symbols 外,还有其它参数,在定位一些动态库问题时非常有用。

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
下面是我 运行终端代码后的返回,请我解释下:shenhaibo@bogon webAssembly % emcc add.c -s WASM=1 -o add.wasm wasm-ld: error: /opt/homebrew/Cellar/emscripten/3.1.40/libexec/cache/sysroot/lib/wasm32-emscripten/libstandalonewasm-nocatch.a(__main_void.o): undefined symbol: main emcc: error: '/opt/homebrew/Cellar/emscripten/3.1.40/libexec/llvm/bin/wasm-ld -o add.wasm /var/folders/hd/zkctfvz128366gcjfw9pgslr0000gn/T/emscripten_temp_0gmz58hs/add_0.o -L/opt/homebrew/Cellar/emscripten/3.1.40/libexec/cache/sysroot/lib/wasm32-emscripten /opt/homebrew/Cellar/emscripten/3.1.40/libexec/cache/sysroot/lib/wasm32-emscripten/crt1.o -lGL -lal -lhtml5 -lstandalonewasm-nocatch -lstubs-debug -lc-debug -ldlmalloc -lcompiler_rt -lc++-noexcept -lc++abi-debug-noexcept -lsockets -mllvm -combiner-global-alias-analysis=false -mllvm -enable-emscripten-sjlj -mllvm -disable-lsr /var/folders/hd/zkctfvz128366gcjfw9pgslr0000gn/T/tmp6m8wb6r0libemscripten_js_symbols.so --strip-debug --export-if-defined=__start_em_asm --export-if-defined=__stop_em_asm --export-if-defined=__start_em_lib_deps --export-if-defined=__stop_em_lib_deps --export-if-defined=__start_em_js --export-if-defined=__stop_em_js --export=emscripten_stack_get_end --export=emscripten_stack_get_free --export=emscripten_stack_get_base --export=emscripten_stack_get_current --export=emscripten_stack_init --export=stackSave --export=stackRestore --export=stackAlloc --export=__errno_location --export-table -z stack-size=65536 --initial-memory=16777216 --max-memory=16777216 --stack-first' failed (returned 1) shenhaibo@bogon webAssembly %
06-07
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值