Какова правильная цель для переменной окружения JAVA_HOME для дистрибутива Linux OpenJDK на базе Debian?
-
20-08-2019 - |
Вопрос
В 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.
Если я использую:
JAVA_HOME=/usr
Все приложения и скрипты, которые хотят использовать любой исполняемый файл Java, могут использовать стандартную процедуру
call $JAVA_HOME/bin/executable
.Однако, поскольку банки находятся в другом месте, они не всегда находятся (пример:в граалях, которые я получаюClassDefNotFound
дляnative2ascii
).С другой стороны, если я использую:
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
.Дополнительная информация: