Какова правильная цель для переменной окружения JAVA_HOME для дистрибутива Linux OpenJDK на базе Debian?

StackOverflow https://stackoverflow.com/questions/663658

Вопрос

В Windows, JAVA_HOME должен указывать на папку установки JDK (чтобы JAVA_HOME/bin содержит все исполняемые файлы и JAVA_HOME/libs содержит все значения по умолчанию jar библиотеки).

Если я скачаю пакет JDK от Sun и установлю его в Linux, это будет та же процедура.

Однако мне нужно использовать пакет OpenJDK от Kubuntu по умолчанию.Проблема в том, что все исполняемые файлы помещены в /usr/bin.Но банки помещены в /usr/share/java.Поскольку они не находятся под одним и тем же JAVA_HOME папка У меня возникли проблемы с Grails, и, возможно, возникнут проблемы с другими приложениями, которые ожидают стандартную структуру Java.

  1. Если я использую:

    JAVA_HOME=/usr
    

    Все приложения и скрипты, которые хотят использовать любой исполняемый файл Java, могут использовать стандартную процедуру call $JAVA_HOME/bin/executable.Однако, поскольку банки находятся в другом месте, они не всегда находятся (пример:в граалях, которые я получаю ClassDefNotFound для native2ascii).

  2. С другой стороны, если я использую:

    JAVA_HOME=/usr/share/java
    

    Ни один из исполняемых файлов Java (java, javac, и т.д.) можно найти.

Итак, каков правильный способ обращения с JAVA_HOME переменная в Linux на базе Debian?

Спасибо за твою помощь, Луис

Это было полезно?

Решение

То, что в конечном итоге сработало для меня (теперь Grails работает без сбоев), работает почти так же, как Стив Б.указал:

JAVA_HOME=/usr/lib/jvm/default-java

Таким образом, если пользователь меняет JDK по умолчанию для системы, JAVA_HOME до сих пор работает.

default-java является символической ссылкой на текущую JVM.

Другие советы

Если вы используете альтернативы для управления несколькими версиями Java, вы можете установить JAVA_HOME на основе символической ссылки Java (или Javac), например:

export JAVA_HOME=$(readlink -f /usr/bin/java | sed "s:bin/java::")

Стандартная установка Ubuntu, похоже, помещает различные версии Java в /usr/lib/jvm.Тот Самый javac, java, которую вы найдете в вашем path, будет программной ссылкой на это.

Нет никаких проблем с установкой вашей собственной версии Java в любом месте, где вам нравится, при условии, что вы установили JAVA_HOME переменная окружения и убедитесь, что у вас есть новая Java bin на твоем пути.

Простой способ сделать это - создать Java home в виде программной ссылки, так что, если вы хотите обновить или переключить версии, вам нужно только изменить каталог, на который это указывает, например:

/usr/bin/java --> /opt/jdk/bin/java,

/opt/jdk --> /opt/jdk1.6.011

Обычно у меня нет переменной среды JAVA_HOME.Java может настроить его самостоятельно.Внутри Java должно быть доступно системное свойство java.home.

Попробуйте также установить переменную JAVA_LIB.

Насколько я помню, я использовал скрипт update-java-alternatives вместо update-alternatives.И он правильно установил JAVA_HOME для меня.

Если у вас есть проблемы с тем, что файлы JAR не найдены, я бы также позаботился о том, чтобы в вашем ПУТИ К КЛАССУ было указано расположение этих файлов.Однако я обнаружил, что ПУТЬ К КЛАССУ часто необходимо устанавливать по-разному для разных программ, и часто в конечном итоге это что-то уникальное для отдельных программ.

Обновленный ответ, который решит вашу проблему, а также простое общее руководство по установке Oracle Java 7 в Ubuntu можно найти здесь: http://www.wikihow.com/Install-Oracle-Java-on-Ubuntu-Linux

Я обнаружил аналогичные проблемы с пакетами openjdk-6-jre и openjdk-6-jre-headless в Ubuntu.

Моя проблема была решена путем очистки пакетов openjdk-6-jre и openjdk-6-jre-headless и их повторной установки.Альтернативы обновляются только при новой установке пакетов openjdk-6-jre и openjdk-6-jre-headless.

Ниже приведен пример установки после продувки:

aptitude purge openjdk-6-jre openjdk-6-jre-headless # to ensure no configuration exists
aptitude install --without-recommends openjdk-6-jre # Installing without some extras
Reading package lists... Done
Building dependency tree
Reading state information... Done
Reading extended state information
Initializing package states... Done
The following NEW packages will be installed:
  ca-certificates-java{a} java-common{a} libavahi-client3{a} libavahi-common-data{a} libavahi-common3{a} libcups2{a} libflac8{a} libgif4{a} libnspr4-0d{a} libnss3-1d{a} libogg0{a} libpulse0{a} libsndfile1{a} libvorbis0a{a} libvorbisenc2{a} libxi6{a} libxtst6{a}
  openjdk-6-jre openjdk-6-jre-headless{a} openjdk-6-jre-lib{a} tzdata-java{a}
The following packages are RECOMMENDED but will NOT be installed:
  icedtea-6-jre-cacao icedtea-netx ttf-dejavu-extra
0 packages upgraded, 21 newly installed, 0 to remove and 119 not upgraded.
Need to get 0B/34.5MB of archives. After unpacking 97.6MB will be used.
Do you want to continue? [Y/n/?]
Writing extended state information... Done
Selecting previously deselected package openjdk-6-jre-lib.
(Reading database ... 62267 files and directories currently installed.)
Unpacking openjdk-6-jre-lib (from .../openjdk-6-jre-lib_6b24-1.11.5-0ubuntu1~10.04.2_all.deb) ...
...
Processing triggers for man-db ...
Setting up tzdata-java (2012e-0ubuntu0.10.04) ...
...
Setting up openjdk-6-jre-headless (6b24-1.11.5-0ubuntu1~10.04.2) ...
update-alternatives: using /usr/lib/jvm/java-6-openjdk/jre/bin/java to provide /usr/bin/java (java) in auto mode.
update-alternatives: using /usr/lib/jvm/java-6-openjdk/jre/bin/keytool to provide /usr/bin/keytool (keytool) in auto mode.
update-alternatives: using /usr/lib/jvm/java-6-openjdk/jre/bin/pack200 to provide /usr/bin/pack200 (pack200) in auto mode.
update-alternatives: using /usr/lib/jvm/java-6-openjdk/jre/bin/rmid to provide /usr/bin/rmid (rmid) in auto mode.
update-alternatives: using /usr/lib/jvm/java-6-openjdk/jre/bin/rmiregistry to provide /usr/bin/rmiregistry (rmiregistry) in auto mode.
update-alternatives: using /usr/lib/jvm/java-6-openjdk/jre/bin/unpack200 to provide /usr/bin/unpack200 (unpack200) in auto mode.
update-alternatives: using /usr/lib/jvm/java-6-openjdk/jre/bin/orbd to provide /usr/bin/orbd (orbd) in auto mode.
update-alternatives: using /usr/lib/jvm/java-6-openjdk/jre/bin/servertool to provide /usr/bin/servertool (servertool) in auto mode.
update-alternatives: using /usr/lib/jvm/java-6-openjdk/jre/bin/tnameserv to provide /usr/bin/tnameserv (tnameserv) in auto mode.
update-alternatives: using /usr/lib/jvm/java-6-openjdk/jre/lib/jexec to provide /usr/bin/jexec (jexec) in auto mode.
Setting up openjdk-6-jre (6b24-1.11.5-0ubuntu1~10.04.2) ...
update-alternatives: using /usr/lib/jvm/java-6-openjdk/jre/bin/policytool to provide /usr/bin/policytool (policytool) in auto mode.
...

Вы можете видеть это выше update-alternatives запускается для настройки ссылок на различные двоичные файлы Java.

После этой установки также появятся ссылки в /usr/bin, ссылки в /etc/alternatives, и файлы для каждого двоичного файла в /var/lib/dpkg/alternatives.

ls -l /usr/bin/java /etc/alternatives/java /var/lib/dpkg/alternatives/java
lrwxrwxrwx 1 root root  40 2013-01-16 14:44 /etc/alternatives/java -> /usr/lib/jvm/java-6-openjdk/jre/bin/java
lrwxrwxrwx 1 root root  22 2013-01-16 14:44 /usr/bin/java -> /etc/alternatives/java
-rw-r--r-- 1 root root 158 2013-01-16 14:44 /var/lib/dpkg/alternatives/java

Давайте сравним это с установкой без очистки.

aptitude remove openjdk-6-jre
aptitude install --without-recommends openjdk-6-jre
Reading package lists... Done
Building dependency tree
Reading state information... Done
Reading extended state information
Initializing package states... Done
The following NEW packages will be installed:
  ca-certificates-java{a} java-common{a} libavahi-client3{a} libavahi-common-data{a} libavahi-common3{a} libcups2{a} libflac8{a} libgif4{a} libnspr4-0d{a} libnss3-1d{a} libogg0{a} libpulse0{a} libsndfile1{a} libvorbis0a{a} libvorbisenc2{a} libxi6{a} libxtst6{a}
  openjdk-6-jre openjdk-6-jre-headless{a} openjdk-6-jre-lib{a} tzdata-java{a}
The following packages are RECOMMENDED but will NOT be installed:
  icedtea-6-jre-cacao icedtea-netx ttf-dejavu-extra
0 packages upgraded, 21 newly installed, 0 to remove and 119 not upgraded.
Need to get 0B/34.5MB of archives. After unpacking 97.6MB will be used.
Do you want to continue? [Y/n/?]
Writing extended state information... Done
Selecting previously deselected package openjdk-6-jre-lib.
(Reading database ... 62293 files and directories currently installed.)
Unpacking openjdk-6-jre-lib (from .../openjdk-6-jre-lib_6b24-1.11.5-0ubuntu1~10.04.2_all.deb) ...
...
Processing triggers for man-db ...
...
Setting up openjdk-6-jre-headless (6b24-1.11.5-0ubuntu1~10.04.2) ...

Setting up openjdk-6-jre (6b24-1.11.5-0ubuntu1~10.04.2) ...
...

Как видишь, update-alternatives не запускается.

После этой установки в папке нет файлов двоичных файлов Java. /var/lib/dpkg/alternatives, ссылок нет /etc/alternatives, и никаких ссылок в /usr/bin.

Удаление файлов в /var/lib/dpkg/alternatives также ломается update-java-alternatives.

Ubuntu 12.04 это работает...

JAVA_HOME=/usr/lib/jvm/java-6-openjdk-i386/jre

В качестве обновления для пользователя Fedora, альтернативы установили текущий каталог Java в/usr/java/default

поэтому вам нужно установить для JAVA_HOME значение /usr/java/default, чтобы всегда иметь текущий выбор альтернатив в вашем пути к классам.

ХТХ!

Моей правильной целью всегда было загрузить его с Sun и просто установить таким образом.Тогда вы точно знаете, в каком каталоге все находится.

Но если вы предпочитаете использовать странный способ установки Debian, я лучше всего предполагаю, что это родительский каталог чуть выше места, где расположены двоичные файлы java и javac.

(С тех пор, как вы указываете это на своем пути, это $ $ java_home/bin) (так что в вашем случае это было бы ...$JAVA_HOME/share и $JAVA_HOME будут /usr ?)

Эх, это звучит не так...

Мне тоже интересно услышать ответ на этот вопрос!

Посмотрите, пожалуйста, что делает команда update-alternatives (хороший человек у нее...).

Вкратце — что происходит, когда у вас есть java-sun-1.4 и java-opensouce-1.0…какой из них берет «Java»?В Debian "/usr/bin/java" является символической ссылкой, а "/usr/bin/java-sun-1.4" является альтернативой "/usr/bin/java".

Редактировать:Как сказал Ричард, update-alternatives недостаточно.Вам действительно нужно использовать update-java-alternatives.Дополнительная информация:

https://help.ubuntu.com/community/Java

Лицензировано под: CC-BY-SA с атрибуция
Не связан с StackOverflow
scroll top