PostGIS 报错libcrypto[通俗易懂]

PostGIS 报错libcrypto[通俗易懂]说明在安装完Postgresql以后,打postgis扩展时,报错ERROR:couldnotloadlibrary”/usr/pgsql-12/lib/rtpostgis.so”:/usr/pgsql-12/lib/libpq.so.10:symbolX509_get_signature_nid,versionlibcrypto.so.10notdefinedinfilelibcrypto.so.10withlinktimereference出现问题环境

大家好,又见面了,我是你们的朋友全栈君。

说明

在安装完Postgresql以后,打postgis扩展时,报错

ERROR:  could not load library "/usr/pgsql-12/lib/rtpostgis.so": /usr/pgsql-12/lib/libpq.so.10: symbol X509_get_signature_nid, version libcrypto.so.10 not defined in file libcrypto.so.10 with link time reference

出现问题环境

centOS7.4
postgresql版本12,小版本号会随官方更新;遇到问题的是12.5
postgis2.5

推测原因

装机无数,postgis版本不变,而postgresql小版本会更新,所以推测是postgresql12.5版本引起的

查找问题

  1. 在rtpostgis报错路径下,可以找到文件
    在这里插入图片描述

  2. 百度大佬说和openssl有关,从openssl-1.0.1升级到1.0.2即可
    ** postgresql里用openssl来进行通讯加密 **

  3. 我从openssl入手,发现有该文件

find  / -name libcrypto.so.10

在这里插入图片描述

  1. 查看openssl版本,是1.0.2的(centOS7默认1.0.2)
openssl version     
  1. 再查看一下库中是否有1.0.2,有!这里就很奇怪了,不解之下,决定还是先按教程升级一下试试
rpm -q --provides openssl-libs | grep libcrypto.so.10

在这里插入图片描述

  1. 官网下载openssl-libs-1.0.2k
    官网
    在这里插入图片描述

  2. 执行安装rpm资源

rpm -ivh openssl-libs-1.0.2k-16.el7.x86_64.rpm    

这里可能因为有旧版本冲突,安装不上,这里可以执行强制安装

rpm -ivh openssl-libs-1.0.2k-16.el7.x86_64.rpm --force
  1. 添加运行权限
chmod +x /lib64/libcrypto.so.1.0.2k
  1. 到系统lib64下,执行查看libcrypto.so.10软连接(这里截图是配置完成后的,没配置前这里关联的是1.0.1)
ll libcry*     

在这里插入图片描述

  1. 重新设置软链接(前面关联到后面位置)
ln -s /usr/lib64/libcrypto.so.1.0.2k /usr/lib64/libcrypto.so.10
  1. 如果软连接提示已存在,则可以强制覆盖
ln -sf /usr/lib64/libcrypto.so.1.0.2k /usr/lib64/libcrypto.so.10

或者删除后再连接

rm -rf /lib64/libcrypto.so.10     
ln -s /usr/lib64/libcrypto.so.1.0.2k /usr/lib64/libcrypto.so.10
  1. 回到第8步验证,如果链接正确到1.0.2,再回到postgresql打postgis扩展即可

后话

虽然问题解决了,但这第一次遇到,没法确定是否是postgresql12.5版本造成的,留待后续装机时继续验证。

附:编译安装openssl方法

  1. 下载新版openssl的tar.gz格式,并解压
cd /usr/local/src     
wget https://www.openssl.org/source/openssl-1.1.1d.tar.gz   
tar xf openssl-1.1.1d.tar.gz   
  1. 编译
cd openssl-1.1.1d    
./config      
make && make install     
  1. 配置软连接
echo "usr/local/lib64/" >> /etc/ld.so.conf     --注册
ldconfig      
mv /usr/bin/openssl /usr/bin/openssl.old    --备份  
ln -sv /usr/local/bin/openssl /usr/bin/openssl     --软连接   
  1. 验证
openssl version
版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请联系我们举报,一经查实,本站将立刻删除。

发布者:全栈程序员-站长,转载请注明出处:https://javaforall.net/148850.html原文链接:https://javaforall.net

(0)
全栈程序员-站长的头像全栈程序员-站长


相关推荐

  • HTTP接口测试还可以这么玩[通俗易懂]

    HTTP接口测试还可以这么玩[通俗易懂]1、背景  随着H5在各行业领域的运用,无论是在APP内嵌入H5页面的hybrid应用还是直接在微信公众号或者轻应用中使用H5页面都是非常的常见(比如前端页面通过HTTP接口调用拉取数据进行交互,实现前后台分离)。而随着此类技术的应用和发展,作为一个测试人员,跟上时代的变化,除了保证前端页面UI的正确性,也要保证HTTP接口的正确性,从而保证了整个业务功能逻辑的正确性,而接口如果手工测

    2022年5月11日
    44
  • 3dmax建模前景_3d建模师未来发展前景

    3dmax建模前景_3d建模师未来发展前景简单来说,没前途。本来不想说这个话题的,但是想了好久,觉得还是来说两句。我本人是从事建筑表现效果图行业的,主要用的软件就是3DMAX+VRay+PS。正式从业到现在已经三年了,半路出家。3DMAX这个软件深入很多个行业,广告、影视、工业设计、建筑设计、三维动画、多媒体制作、游戏、以及工程可视化等。但其实没有哪个行业是只用这一款软件的,在不少行业3DMAX也逐步被更新的软件替代。MAX强大在它是一个平台,所以他的上限很高,比一般的软件都要高很多,但是下限也很高,不是那么容易上手。.

    2025年10月28日
    3
  • linux 查看当前所有环境变量的两种方法_Linux配置jdk环境变量

    linux 查看当前所有环境变量的两种方法_Linux配置jdk环境变量linux中查看环境变量有两种方法:第一种是看系统环境变量的配置文件:/etc/profile这个是环境变量配置文件,里面是应经配置号的环境变量。当你在Ubuntu上安装配置jdk的JAVA_HOME时,需要把路径配置在里面。例如:在bash下输入gedit/etc/profile#/etc/profile:system-wide.profilefilefortheBournes…

    2022年10月1日
    2
  • docker下载安装教程_docker安装macos

    docker下载安装教程_docker安装macos前言Docker提供轻量的虚拟化,你能够从Docker获得一个额外抽象层,你能够在单台机器上运行多个Docker微容器,而每个微容器里都有一个微服务或独立应用,例如你可以将Tomcat运行在一个D

    2022年7月31日
    5
  • Merge into用法总结

    Merge into用法总结简单的说就是,判断表中有没有符合on()条件中的数据,有了就更新数据,没有就插入数据。  有一个表T,有两个字段a、b,我们想在表T中做Insert/Update,如果条件满足,则更新T中b的值,否则在T中插入一条记录。在Microsoft的SQL语法中,很简单的一句判断就可以了,SQLServer中的语法如下:  ifexists(select1fromTwhere…

    2022年6月7日
    78
  • python读取excel单元格内容_python如何读取文件夹下的所有文件

    python读取excel单元格内容_python如何读取文件夹下的所有文件1.使用python内建的open()方法读取文本相对路径:example/ex2.txt,文件内容如下所示:测试内容,路径和内容,大家可根据自己心情设置。使用open()方法读取:print(‘—-使用python自带的open()读取文件—–‘)path=r’example/ex2.txt’frame=open(path)print(frame.readlines())此时,执行结果报错如下:我猜测open()方法的…

    2022年10月2日
    2

发表回复

您的邮箱地址不会被公开。 必填项已用 * 标注

关注全栈程序员社区公众号