
在进行交叉编译的时候遇到gawk: error while loading shared libraries: libreadline.so.4: cannot open shared object file: No such file or directory。 当前编译环境是x86_64, Ubuntu 20.04, 目标运行环境是mips32. 碰到这个问题,第一个想到的是安装这个lib.
在Ubuntu上我们可以用apt-file程序来查找这个库在哪个安装包里。如果系统没有安装apt-file, 则需要先安装apt-file。安装好后,运行如下:
$sudo apt-file update $sudo apt-file search libreadline.so.4 #find no results $sudo apt-file search libreadline.so #returns the following
lib32readline-dev: /usr/lib32/libreadline.so
lib32readline8: /lib32/libreadline.so.8
lib32readline8: /lib32/libreadline.so.8.0
libreadline-dev: /usr/lib/x86_64-linux-gnu/libreadline.so
libreadline-gplv2-dev: /usr/lib/x86_64-linux-gnu/libreadline.so
libreadline5: /lib/x86_64-linux-gnu/libreadline.so.5
libreadline5: /lib/x86_64-linux-gnu/libreadline.so.5.2
libreadline5-dbg: /usr/lib/debug/libreadline.so.5
libreadline5-dbg: /usr/lib/debug/libreadline.so.5.2
libreadline8: /lib/x86_64-linux-gnu/libreadline.so.8
libreadline8: /lib/x86_64-linux-gnu/libreadline.so.8.0
libreadline.so.4是一个很老的库,现在Ubuntu的库源上已经没有了,但是可以试试后面的版本。因为源码是在32位centos上开发编译的,所以要选择32bit的库:lib32readline8 。
运行如下:
$sudo apt install lib32readline8
安装完后,进入/lib32目录,可以看到libreadline.so.8和libreadline.so.8.0。
lrwxrwxrwx 1 root root 18 Feb 25 2020 /lib32/libreadline.so.8 -> libreadline.so.8.0 -rw-r--r-- 1 root root 311884 Feb 25 2020 /lib32/libreadline.so.8.0
然后运行:
$ sudo ln -sv /lib32/libreadline.so.8.0 /lib32/libreadline.so.4
再 $ls -l 可以看到这个symbolic link已经建立起来了。
但是,运行交叉编译任务还是报同样的错。在stack overflow上发布这个问题,有人在下面留言提醒我不是去解决libreadline.so.4,而是解决gawk版本太老的问题。
我运行$gawk 提示没有该命令,于是
$sudo apt install gawk
再$gawk --version查看其版本,返回
GNU Awk 5.0.1, API: 2.0 (GNU MPFR 4.0.2, GNU MP 6.2.0)
$whereis gawk查找其安装路径:
gawk: /usr/bin/gawk /usr/lib/x86_64-linux-gnu/gawk /usr/share/man/man1/gawk.1.gz
安装路径为/usr/bin。再次运行交叉编译任务还是报同样的错, 说明还有一个gawk安装在某个目录下,在运行交叉编译的时候这个目录首先被调用。而且这个目录不在$PATH中,或者即使在$PATH中,也是排在/usr/bin后面。
在需编译的源码中的配置文件里发现了可能的gawk的安装目录,cd到那个目录,运行$gawk,报同样的错误,就是这里了。运行如下命令:
$cp /usr/bin/gawk gawk
再次在当前目录下运行gawk,确认已更新为最新版本。
再次运行交叉编译,不报错,该问题已解决。