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


相关推荐

  • smtp服务器组件,本机搭建虚拟SMTP服务器教程[通俗易懂]

    smtp服务器组件,本机搭建虚拟SMTP服务器教程[通俗易懂]该楼层疑似违规已被系统折叠隐藏此楼查看此楼Windows2000用户安装设置服务端WindowsXP和2000本身就拥有构件SMTP服务器的功能,只是一般还没有安装。选择“控制面板→添加/删除程序→添加/删除Windows组件”,弹出“Windows组件向导”对话框,在其中双击“Internet信息服务(IIS)”项,就会打开详细选择项,选中“SMTPService”,按“确定”,插入…

    2022年10月3日
    3
  • order by case when执行优先级_sql case语句

    order by case when执行优先级_sql case语句MySQL语句中执行优先级——and比or高例:select*fromtablewhere条件1AND条件2OR条件3等价于select*fromtablewhere(条件1AND条件2)OR条件3select*fromtablewhere条件1AND条件2OR条件3AND条件4等价于select*fromtablewhere(条件1AND条件2)OR(条件3AND条件4)sql执行顺序

    2025年8月26日
    5
  • 十天征服单片机百度云_郭天祥十天征服单片机视频下载地址

    十天征服单片机百度云_郭天祥十天征服单片机视频下载地址高级教材《十天学会单片机和C语言编程》ed2k://|file|[十天学会单片机和C语言编程].Lesson1.rar|449712628|262b8896ad6828cd33ed7189fe94cb2d|h=76MXIF34BFV3VUPLLBN3ASNOVCACHTO3|7b&Y0}8J9w,P0E:|-}’Oed2k://|file|[十天学会单片机和C语言编程]…

    2022年5月2日
    34
  • Scrapy安装_Scrapy

    Scrapy安装_ScrapyScrapy安装步骤:1.python-2.7.9.msi  2.pywin32-221.win32-py2.7.exe3. lxml-3.4.2.win32-py2.7.exe4. VCForPython27.msi  

    2022年9月18日
    4
  • MySqlConnector连接选项「建议收藏」

    MySqlConnector连接选项「建议收藏」MySqlConnectorMySqlConnectorhttps://mysqlconnector.net/connection-options/连接选项MySqlConnector支持大多

    2022年7月1日
    53
  • C++11新特性之线程操作

    C++11之前没有对并发编程提供语言级别的支持,这使得我们在编写可移植的并发程序时,存在诸多的不便。现在C++11增加了线程以及线程相关的类,很方便地支持了并发编程,使得编写的多线程程序的可移植性得到

    2021年12月28日
    39

发表回复

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

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