1. 絮絮叨叨

  • 最近,在完成集群部署后,发现服务没有成功启动,在启动日志中发现如下报错信息

    java: error while loading shared libraries: libjli.so: cannot open shared object file: No such file or directory 
    
  • 使用了这么多年的Java,自己也是第一次遇到这样的问题 😂

  • 能咋办,遇到问题就解决呗;解决不了,就搜一搜呗

  • 找到一篇看似靠谱的博客(实际也确实靠谱):配置linux的jdk报错error while loading shared libraries: libjli.so

2. 解决办法

2.1 设置java软链接

  • 通过java -version确定JDK版本(如果存在多个JDK版本),自己的是jdk1.8.0_192

  • 通过export命令,确定JAVA_HOME

    JAVA_HOME="/usr/java/jdk1.8.0_192/"
    
  • 查看是否存在/usr/bin/java指向/usr/java/jdk1.8.0_192/bin/java的软链接,如果指向不正确可以通过rm命令进行删除

     ls -l /usr/bin/java
     # 删除软链接
     rm -rf /usr/bin/java
    
  • 重新设置软链接,使其指向对应版本的java

    ln -s /usr/java/jdk1.8.0_192/bin/java /usr/bin/java
    

2.2 更新ld_path

  • 通过find命令,找到libjli.so

    find / -name libjli.so
    # 凭借自己的经验,认为可以直接搜索/usr目录的
    find /usr  -name libjli.so
    
  • 自己这里有两个路径,都存在libjli.so
    在这里插入图片描述

  • 随便选择其中一个路径,追加到/etc/ld.so.conf文件中

    /usr/java/jdk1.8.0_192/lib/amd64/jli/libjli.so
    
  • 通过ldconfig命令使/etc/ld.so.conf生效

  • 若出现报错信息,可以先删除报错信息中的.py文件,再重新执行ldconfig

    ldconfig: /usr/local/lib64/libstdc++.so.6.0.22-gdb.py is not an ELF file - it has the wrong magic bytes at the start.
    
  • 至此,再次重新启动服务,发现服务成功启动!完美 👍 👍 👍

Logo

为开发者提供学习成长、分享交流、生态实践、资源工具等服务,帮助开发者快速成长。

更多推荐