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


相关推荐

  • 图形验证码的作用

    图形验证码的作用图形验证码是验证码的一种。验证码(CAPTCHA)是“CompletelyAutomatedPublicTuringtesttotellComputersandHumansApart”(全自动区分计算机和人类的图灵测试)的缩写,是一种区分用户是计算机还是人的公共全自动程序。可以防止:恶意激活成功教程密码、刷票、论坛灌水,有效防止某个黑客对某一个特定注册用户用特定程序暴力破…

    2022年7月14日
    20
  • goland 永久激活码【最新永久激活】

    (goland 永久激活码)JetBrains旗下有多款编译器工具(如:IntelliJ、WebStorm、PyCharm等)在各编程领域几乎都占据了垄断地位。建立在开源IntelliJ平台之上,过去15年以来,JetBrains一直在不断发展和完善这个平台。这个平台可以针对您的开发工作流进行微调并且能够提供…

    2022年4月2日
    209
  • android调用so文件_android加载大图

    android调用so文件_android加载大图原文地址点击打开链接一、前言Android中有时候为了效率以及平台开发库的支持,难免会用到NDK开发,那么都会产生一个so文件,通过native方法进行调用,开发和调用步骤很简单,这里就不多说了,本文主要来介绍,我们在使用so的时候总是会出现一些常见的问题,而现在插件化开发也很普遍了,有时候插件中也会包含一些so文件,需要加载,这时候也会出现一些问题。本文就来详细总

    2022年9月18日
    2
  • getElementById 使用

    getElementById 使用getElementById()方法可返回对拥有指定ID的第一个对象的引用里面跟着的必须是元素ID属性值,如果class的值是不可以的一个小demo<!DOCTYPEhtml><html> <head> <metacharset=”utf-8″> <title>菜鸟教程(runoob.com)&l…

    2022年7月15日
    14
  • 简单线性回归-最小二乘法推导过程

    简单线性回归-最小二乘法推导过程最近学习线性回归,自己推导了一下最小二乘法。 其他参考文章:https://blog.csdn.net/chasdmeng/article/details/38869941?utm_source=blogxgwz0https://blog.csdn.net/iterate7/article/details/78992015要是你在西安,感兴趣一起学习AIOPS,欢迎加入QQ群…

    2022年5月13日
    41
  • Hmily实现TCC事务控制

    Hmily实现TCC事务控制目标通过本案例的学习,掌握Hmily实现TCC事务控制的方法,掌握TCC事务控制的思想。Hmily介绍Hmily是一个高性能分布式事务TCC开源框架。基于Java语言来开发(JDK1.8),支持Dubbo,SpringCloud等RPC框架进行分布式事务。它目前支持以下特性:支持嵌套事务(Nestedtransactionsupport).采用disruptor框架进行事务日志的…

    2022年5月22日
    32

发表回复

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

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