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)
全栈程序员-站长的头像全栈程序员-站长


相关推荐

  • 软件架构 设计模式_几种常见软件架构

    软件架构 设计模式_几种常见软件架构什么是架构?  软件体系结构通常被称为架构,指可以预制和可重构的软件框架结构。架构尚处在发展期,对于其定义,学术界尚未形成一个统一的意见,而不同角度的视点也会造成软件体系结构的不同理解,以下是一些主流的标准观点。  ANSI/IEEE610.12-1990软件工程标准词汇对于体系结构定义是:“体系架构是以构件、构件之间的关系、构件与环境之间的关系为内容的某一系统的基本组织结构以及知道上述内容设计与演化的原理(principle)”。  MaryShaw和DavidGarlan认为软件体系结构是软件设

    2022年10月18日
    0
  • Xmind快捷键详解(思维导图版)

    Xmind快捷键详解(思维导图版)说明软件版本:XMind8Update7操作系统:Windows10剪切画:部分剪切画从外部导入快捷键

    2022年5月25日
    35
  • 动态规划背包问题(例题)

    动态规划背包问题(例题)发生的方式

    2022年7月26日
    12
  • Python 词频统计

    Python 词频统计

    2022年4月3日
    36
  • 最新SEO寄生虫排名

    最新SEO寄生虫排名黑帽SEO怎么做寄生虫这里说下寄生虫问题!需要的可以联系qQ325和056还有6854.对于小编来说!对寄生虫程序的选择没啥讲究!顺手好用就好!最近新出很多寄生虫!各种各样的,说得有多牛逼多牛逼的!其实都是骗人的、哪个在营销自己的产品的时候不把自己的产品说得好一些!难道会告诉大家垃圾吗?实际上市面上的虫子程序都是把原始版本改版过来的!有的把程序和菜刀软件二合一起来为了大家方便生成,看着简单易操作…

    2022年5月13日
    54
  • Thread.currentThread().getContextClassLoader()与Test.class.getClassLoader()区别

    Thread.currentThread().getContextClassLoader()与Test.class.getClassLoader()区别忘记以前有没有问过这个问题,总之我现在有看到几个地方有这个:Thread.currentThread().getContextClassLoader()我总是想不出在什么情况下会用这种方式获得一个ClassLoader,因为好像默认情况下,它返回的是和加载应用的ClassLoader是同一个,比如说在一个类Test中写ClassLoader cl = Thread.curren

    2022年6月6日
    30

发表回复

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

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