zoukankan      html  css  js  c++  java
  • 分析并解决Linux发行版的自带OpenJdk和自己安装的OracleJdk新旧版本冲突问题

    解决办法:

    从Oraclejdk 目录里可执行文件链接都复制到自己的LINK目录,然后IDE使用LINK变量下的命令

     本文没有具体解决方法,只有探索思路................................

    如果想替换系统openjdk,请参考:

    Linux(Deepin)下配置java8 - L141210113的专栏 - CSDN博客(不过官网jdk8现在需要登录才能下载,jdk11、12不用登录)

    以下为过程思路:

    发行版系统:Deepin15.9 (为什么?漂亮不折腾)

    一直知道这个情况,但使用正常就没去理他,直到今天:

    VSCode给我报了个错误 

     

    1 cd "/home/××/Documents/0vscode/java/" && javac -encoding UTF-8 MidiDance1.java && java MidiDance1
    2 
    3 Picked up _JAVA_OPTIONS:   -Dawt.useSystemAAFontSettings=gasp
    4 Picked up _JAVA_OPTIONS:   -Dawt.useSystemAAFontSettings=gasp
    5 Error: LinkageError occurred while loading main class MidiDance1
    6         java.lang.UnsupportedClassVersionError: MidiDance1 has been compiled by a more recent version of the Java Runtime (class file version 55.0), this version of the Java Runtime only recognizes class file versions up to 54.0
    报错

     所以解决它...

     百分百确定是Openjdk自带的jre和Oracle的冲突,看这里:

    $ sudo update-alternatives --config java
    [sudo] ×× 的密码:
    链接组 java (提供 /usr/bin/java)中只有一个候选项:/usr/lib/jvm/java-10-openjdk-amd64/bin/java
    无需配置。

    $ ls /usr/lib/jvm/
    default-java   java-10-openjdk-amd64    java-1.10.0-openjdk-amd64    jdk-11.0.2

    其中jdk-11.0.2 是我自己装的OracleJdk目录

    可知系统是默认配置一个openjdk的jre环境了

    // 问题应该在这个目录,进去看看
    $ cd /usr/lib/jvm/

    // default这个目录有点默认使用的意味,ls详细看看

    $ ls -l default-java/bin/ 总用量 216 -rwxr-xr-x 1 root root 10520 5月 6 2018 java -rwxr-xr-x 1 root root 10600 5月 6 2018 jjs -rwxr-xr-x 1 root root 10560 5月 6 2018 keytool -rwxr-xr-x 1 root root 10608 5月 6 2018 orbd -rwxr-xr-x 1 root root 10560 5月 6 2018 pack200 -rwxr-xr-x 1 root root 10552 5月 6 2018 rmid -rwxr-xr-x 1 root root 10560 5月 6 2018 rmiregistry -rwxr-xr-x 1 root root 10560 5月 6 2018 servertool -rwxr-xr-x 1 root root 10616 5月 6 2018 tnameserv -rwxr-xr-x 1 root root 107920 5月 6 2018 unpack200

    文件权限之后的数字代表类型,1是link文件链接类型,

    也就是说系统默认使用了这个链接,所以也就印证了VSCode里调用的报错。

     那更改java链接就行了?等等,看清楚点比较好

    $ ls -l default-java
    lrwxrwxrwx 1 root root 25 5月   1  2018 default-java -> java-1.10.0-openjdk-amd64

    原来这个default-java才是一个链接

    $ ls -l java-1.10.0-openjdk-amd64
    lrwxrwxrwx 1 root root 21 5月   6  2018 java-1.10.0-openjdk-amd64 -> java-10-openjdk-amd64

    等等....这....看来得把所有主要目录都列出来

    $ ls -l 
    总用量 8
    lrwxrwxrwx 1 root root   25 5月   1  2018 default-java -> java-1.10.0-openjdk-amd64
    drwxr-xr-x 7 root root 4096 1月  24 15:41 java-10-openjdk-amd64
    lrwxrwxrwx 1 root root   21 5月   6  2018 java-1.10.0-openjdk-amd64 -> java-10-openjdk-amd64
    drwxr-xr-x 8  668  668 4096 1月  22 10:47 jdk-11.0.2

    所以看懂了,为什么这么蛋疼的链接呢?那肯定是为了兼容性,查了一下: jdk10 也叫 jdk1.10   (目前 jdkxx 都叫 jdk1.xx)

     Ps. 闲的没事多 ls -l 会有很多发现

    然后找出 全局可执行命令“java” 的位置 

    $ type java
    java 是 /usr/bin/java
    
    $ which java
    /usr/bin/java
    
    $ whereis java
    java: /usr/bin/java /etc/java /usr/share/java /usr/lib/jvm/jdk-11.0.2/bin/java /usr/share/man/man1/java.1.gz
    
    $ whereis -b java
    java: /usr/bin/java /etc/java /usr/share/java /usr/lib/jvm/jdk-11.0.2/bin/java
    

     得出位置是/usr/bin/ ,那ls一下

    $ ls -l /usr/bin/ | grep java
    lrwxrwxrwx 1 root root          22 1月  24 15:43 java -> /etc/alternatives/java

    蛋疼得受不了了,继续ls

    $ ls -l | grep java
    lrwxrwxrwx 1 root root  43 1月  24 15:43 java -> /usr/lib/jvm/java-10-openjdk-amd64/bin/java
    lrwxrwxrwx 1 root root  53 1月  24 15:43 java.1.gz -> /usr/lib/jvm/java-10-openjdk-amd64/man/man1/java.1.gz
    lrwxrwxrwx 1 root root  44 1月  24 15:43 jexec -> /usr/lib/jvm/java-10-openjdk-amd64/lib/jexec
    lrwxrwxrwx 1 root root  49 1月  24 15:43 jexec-binfmt -> /usr/lib/jvm/java-10-openjdk-amd64/lib/jar.binfmt
    lrwxrwxrwx 1 root root  42 1月  24 15:43 jjs -> /usr/lib/jvm/java-10-openjdk-amd64/bin/jjs
    lrwxrwxrwx 1 root root  52 1月  24 15:43 jjs.1.gz -> /usr/lib/jvm/java-10-openjdk-amd64/man/man1/jjs.1.gz
    lrwxrwxrwx 1 root root  46 1月  24 15:43 keytool -> /usr/lib/jvm/java-10-openjdk-amd64/bin/keytool
    lrwxrwxrwx 1 root root  56 1月  24 15:43 keytool.1.gz -> /usr/lib/jvm/java-10-openjdk-amd64/man/man1/keytool.1.gz
    lrwxrwxrwx 1 root root  43 1月  24 15:43 orbd -> /usr/lib/jvm/java-10-openjdk-amd64/bin/orbd
    lrwxrwxrwx 1 root root  53 1月  24 15:43 orbd.1.gz -> /usr/lib/jvm/java-10-openjdk-amd64/man/man1/orbd.1.gz
    lrwxrwxrwx 1 root root  46 1月  24 15:43 pack200 -> /usr/lib/jvm/java-10-openjdk-amd64/bin/pack200
    lrwxrwxrwx 1 root root  56 1月  24 15:43 pack200.1.gz -> /usr/lib/jvm/java-10-openjdk-amd64/man/man1/pack200.1.gz
    lrwxrwxrwx 1 root root  43 1月  24 15:43 rmid -> /usr/lib/jvm/java-10-openjdk-amd64/bin/rmid
    lrwxrwxrwx 1 root root  53 1月  24 15:43 rmid.1.gz -> /usr/lib/jvm/java-10-openjdk-amd64/man/man1/rmid.1.gz
    lrwxrwxrwx 1 root root  50 1月  24 15:43 rmiregistry -> /usr/lib/jvm/java-10-openjdk-amd64/bin/rmiregistry
    lrwxrwxrwx 1 root root  60 1月  24 15:43 rmiregistry.1.gz -> /usr/lib/jvm/java-10-openjdk-amd64/man/man1/rmiregistry.1.gz
    lrwxrwxrwx 1 root root  49 1月  24 15:43 servertool -> /usr/lib/jvm/java-10-openjdk-amd64/bin/servertool
    lrwxrwxrwx 1 root root  59 1月  24 15:43 servertool.1.gz -> /usr/lib/jvm/java-10-openjdk-amd64/man/man1/servertool.1.gz
    lrwxrwxrwx 1 root root  48 1月  24 15:43 tnameserv -> /usr/lib/jvm/java-10-openjdk-amd64/bin/tnameserv
    lrwxrwxrwx 1 root root  58 1月  24 15:43 tnameserv.1.gz -> /usr/lib/jvm/java-10-openjdk-amd64/man/man1/tnameserv.1.gz
    lrwxrwxrwx 1 root root  48 1月  24 15:43 unpack200 -> /usr/lib/jvm/java-10-openjdk-amd64/bin/unpack200
    lrwxrwxrwx 1 root root  58 1月  24 15:43 unpack200.1.gz -> /usr/lib/jvm/java-10-openjdk-amd64/man/man1/unpack200.1.gz

    原来bin路径下都是链接,我....

    赶紧必应搜索多几下

    linux中如何查看命令所在目录_百度经验



    原因找到了,那我们就.... Linux不太可能给你集成你用不到的功能,所以Openjdk应该和系统相关,不能卸载作死...

    解决方案:

    我们只是用IDE编程时运行一下,还是在IDE里改吧,

    先看一下自己安装的jdk目录

    :/usr/lib/jvm/jdk-11.0.2/bin$ ls -l
    总用量 508
    -rwxr-xr-x 1 668 668  12952 1月  18 13:36 jaotc
    -rwxr-xr-x 1 668 668   8736 1月  18 13:36 jar
    -rwxr-xr-x 1 668 668   8736 1月  18 13:36 jarsigner
    -rwxr-xr-x 1 668 668   8672 1月  18 13:36 java
    -rwxr-xr-x 1 668 668   8784 1月  18 13:36 javac
    -rwxr-xr-x 1 668 668   8784 1月  18 13:36 javadoc
    -rwxr-xr-x 1 668 668   8736 1月  18 13:36 javap
    -rwxr-xr-x 1 668 668   8736 1月  18 13:36 jcmd
    -rwxr-xr-x 1 668 668  12888 1月  18 13:36 jconsole
    -rwxr-xr-x 1 668 668   8736 1月  18 13:36 jdb
    -rwxr-xr-x 1 668 668   8736 1月  18 13:36 jdeprscan
    -rwxr-xr-x 1 668 668   8736 1月  18 13:36 jdeps
    -rwxr-xr-x 1 668 668   8736 1月  18 13:36 jhsdb
    -rwxr-xr-x 1 668 668   8736 1月  18 13:36 jimage
    -rwxr-xr-x 1 668 668  12880 1月  18 13:36 jinfo
    -rwxr-xr-x 1 668 668   8784 1月  18 13:36 jjs
    -rwxr-xr-x 1 668 668   8784 1月  18 13:36 jlink
    -rwxr-xr-x 1 668 668  12880 1月  18 13:36 jmap
    -rwxr-xr-x 1 668 668   8736 1月  18 13:36 jmod
    -rwxr-xr-x 1 668 668   8736 1月  18 13:36 jps
    -rwxr-xr-x 1 668 668   8792 1月  18 13:36 jrunscript
    -rwxr-xr-x 1 668 668   8736 1月  18 13:36 jshell
    -rwxr-xr-x 1 668 668  12880 1月  18 13:36 jstack
    -rwxr-xr-x 1 668 668   8736 1月  18 13:36 jstat
    -rwxr-xr-x 1 668 668   8736 1月  18 13:36 jstatd
    -rwxr-xr-x 1 668 668   8736 1月  18 13:36 keytool
    -rwxr-xr-x 1 668 668   8736 1月  18 13:36 pack200
    -rwxr-xr-x 1 668 668   8736 1月  18 13:36 rmic
    -rwxr-xr-x 1 668 668   8736 1月  18 13:36 rmid
    -rwxr-xr-x 1 668 668   8744 1月  18 13:36 rmiregistry
    -rwxr-xr-x 1 668 668   8736 1月  18 13:36 serialver
    -rwxr-xr-x 1 668 668 117704 1月  18 13:36 unpack200

    和系统Openjdk结构差不多,bin目录下都是可执行文件的链接

    Linux下的softlink和hardlink - yasaken - CSDN博客

    具体解决方案:

    从安装的Oraclejdk 目录里找可执行文件链接所在的bin目录,把bin目录下的链接文件copy到自己的javaLinkBin目录下

    把可执行链接都复制到自己的目录:

    /usr/lib/jvm/jdk-11.0.2$  cp bin/* /home/xx/Documents/javaLinkBin/

    然后把IDE里调用jdk的命令都加上完整路径,

    修改IDE里的运行命令如:

    java    改为   /home/xx/Document/javaLinkBin/java

    javac    改为   /home/xx/Document/javaLinkBin/javac

    当然更好的方法是设置一个变量,例如

    MY_JDKLINK="/home/xx/Document/javaLinkBin/"

    然后IDE配置写 $MY_JDKLINK/java即可

             -End-

    Ps.最近百度挺讨厌的,还我必应主域名,不还就用官方第二域名:https://www2.bing.com     https://www4.bing.com

    --------蓝天上的云_转载请注明出处.
  • 相关阅读:
    HDU 4924 Football Manager(状压DP)
    android 为图片去灰
    关于invalidate和postInvalidate
    有点感想人月神话
    ObjectiveC语法快速参考
    Paint类 主要方法介绍
    关于游戏开发中的碰撞检测(转)
    两集合求交集的算法比较(转)
    Java编程中“为了性能”需做的26件事(转)
    android WebView总结(转)
  • 原文地址:https://www.cnblogs.com/yucloud/p/Open-Oracle_Linux.html
Copyright © 2011-2022 走看看