关于linux:编译curl后的路径问题

path issue after compiling curl

我使用以下命令克隆了repo后编译curl:

1
2
3
4
./buildconf
./configure --with-libssh2
make
sudo make install

但是,在sudo make install之后,如果

  • 我运行curl -V,我得到:bash:/usr/bin/curl: No such file or directory
  • 我运行/usr/local/bin/curl -V,我得到:/usr/local/bin/curl: symbol lookup error: /usr/local/bin/curl: undefined symbol: curl_mime_type

我尝试通过将curl / src的路径添加到我的PATH变量来解决这个问题,并使curl命令从终端为我的用户工作。 但是,如果我尝试安装php-curl,可以理解的是,apache看不到curl并安装另一个。

关于如何解决这个问题的任何想法?

编辑:评论中提到的另一篇文章是在编译后询问在哪里找到可执行文件。 那部分得到了解答。 但是如果没有在我的PATH变量中添加一个条目,我仍然无法使curl工作,这似乎不对。 这就是我现在要弄清楚的部分。


安装路径

如果不使用configure的--prefix选项,则默认安装将在/usr/local中进行,因此curl最终会在/usr/local/bin/curl处结束。

符号查找错误

它报告缺少的符号是libcurl的最新添加,它表示您正在调用一个新的curl工具来加载和使用较旧的libcurl - 即不是刚刚安装的那个,而是之前的(系统?)安装的一个。

您可以通过调用来验证卷曲加载哪个libcurl

1
$ ldd /usr/local/bin/curl | grep libcurl

您可以通过多种方式之一更改curl加载的libcurl,这两种方式都不是特定于curl的,所以我只是简单地提一下这里要进一步解释的方法:

  • 在调用curl之前,只需在shell中设置LD_LIBRARY_PATH即可
  • 编辑/etc/ld.so.conf并确保搜索路径的顺序使旧的libcurl在旧的libcurl之前找到。
  • 通过使用LDFLAGS=-Wl,-R/usr/local/ssl/lib ./configure ...之类的方法调用configure,将curl可执行文件与硬编码路径链接到新的libcurl
  • 更换系统库?

    通常不建议用自定义构建替换已安装的系统libcurl。主要是因为您可能有一个或两个应用程序依赖于该构建的细节。当您从源代码安装自己的libcurl时,通常最好将其安装在单独的路径中,以便它可以与已安装在系统中的路径共存。