GNU/Linux >> Linux の 問題 >  >> Linux

認識されないVMオプションMaxMetaspaceSize=256m –oxd-serverが起動に失敗しました[解決策]

最近、GluuのOpenIDconnectシングルサインオンプラグインを使用してSSOを試してみました。プラグインの前提条件の1つは、Oxdサーバーをインストールし、ポート8099で実行することです。Oxdサーバーのインストールはスムーズに進みましたが、デーモンを起動できませんでした。このチュートリアルでは、「認識されないVMオプションMaxMetaspaceSize」を修正する方法について説明します。 ‘oxdサーバーの起動を妨げたエラー。

root@opidclient:~# /etc/init.d/oxd-server start
 oxd-server is already running ...
 PID: [1370]

上記のスナップショットはoxd-serverと言っていますが 開始されましたが、開始されませんでした。また、標準出力とoxdサーバーのログファイルにもエラーメッセージなどはありませんでした。ただし、oxd-serverに関する情報は見つかりました。 '/etc/init.d/oxd-server status'による構成 コマンド。

root@opidclient:~# /etc/init.d/oxd-server status
oxd server NOT running
OXD_HOME = /opt/oxd-server
OXD_BASE = /opt/oxd-server
OXD_CONF =
OXD_PID_FILE = /var/run/oxd-server.pid
OXD_START = org.xdi.oxd.server.ServerLauncher
OXD_LOGS = /var/log/oxd-server
OXD_STATE = /opt/oxd-server/oxd-server.state
CLASSPATH =
JAVA = /usr/bin/java
JAVA_OPTIONS = -server -Xms256m -Xmx512m -XX:MaxMetaspaceSize=256m -XX:+Disab leExplicitGC -Doxd.server.config=/etc/oxd/oxd-server/oxd-conf.json -Dlog4j.confi guration=/etc/oxd/oxd-server/log4j.xml -cp /opt/oxd-server/lib/bcprov-jdk15on-1. 54.jar:/opt/oxd-server/lib/oxd-server-jar-with-dependencies.jar -Doxd.logging.di r=/var/log/oxd-server -Doxd.home=/opt/oxd-server -Doxd.base=/opt/oxd-server -Dja va.io.tmpdir=/tmp
OXD_ARGS = oxd-server.state=/opt/oxd-server/oxd-server.state
RUN_CMD = /usr/bin/java -server -Xms256m -Xmx512m -XX:MaxMetaspaceSize=256m -XX:+DisableExplicitGC -Doxd.server.config=/etc/oxd/oxd-server/oxd-conf.json -Dlog4j.configuration=/etc/oxd/oxd-server/log4j.xml -cp /opt/oxd-server/lib/bcp rov-jdk15on-1.54.jar:/opt/oxd-server/lib/oxd-server-jar-with-dependencies.jar -D oxd.logging.dir=/var/log/oxd-server -Doxd.home=/opt/oxd-server -Doxd.base=/opt/o xd-server -Djava.io.tmpdir=/tmp org.xdi.oxd.server.ServerLauncher oxd-server.state=/opt/oxd-server/oxd-server.state

上記の出力から、コマンド(RUN_CMD)を知ることができました。 )実際に起動するoxd-server デーモン。

コマンドを実行したところ、oxd-serverを妨げる問題が見つかりました 開始から。これがそのスナップショットです。

root@opidclient:~# /usr/bin/java -server -Xms256m -Xmx512m -XX:MaxMetaspaceSize=256m -XX:+DisableExplicitGC -Doxd.server.config=/etc/oxd/oxd-server/oxd-conf.json -Dlog4j.configuration=/etc/oxd/oxd-server/log4j.xml -cp /opt/oxd-server/lib/bcp rov-jdk15on-1.54.jar:/opt/oxd-server/lib/oxd-server-jar-with-dependencies.jar -D oxd.logging.dir=/var/log/oxd-server -Doxd.home=/opt/oxd-server -Doxd.base=/opt/o xd-server -Djava.io.tmpdir=/tmp org.xdi.oxd.server.ServerLauncher oxd-server.sta te=/opt/oxd-server/oxd-server.state
 Unrecognized VM option MaxMetaspaceSize=256m
 Error: Could not create the Java Virtual Machine.
 Error: A fatal exception has occurred. Program will exit.

エラー「認識されないVMオプションMaxMetaspaceSize=256m 」により、Java仮想マシンの作成が妨げられました。

認識されないVMオプションMaxMetaspaceSize=256mを修正する方法

Oxd-serverデーモンはJavaに依存しています。以下のコマンドを使用してJavaのバージョンを確認しましょう。

root@opidclient:~# java -version
 java version "1.7.0_181"
 OpenJDK Runtime Environment (IcedTea 2.6.14) (7u181-2.6.14-0ubuntu0.1)
 OpenJDK 64-Bit Server VM (build 24.181-b01, mixed mode)

Javaバージョン1.7.0は、VMオプションMaxMetaspaceSizeを認識しません 、代わりにMaxPermSize 使用すべきです。ただし、MaxMetaspaceSize Javaバージョン8(つまり、Java 1.8)でサポートされています。それでは、以下に示すようにOracleJavaバージョン8をインストールしましょう。

$ sudo add-apt-repository ppa:webupd8team/java
$ sudo apt-get update 
$ sudo apt-get install oracle-java8-installer
$ sudo apt-get install oracle-java8-set-default

Javaのバージョンを確認しましょう:

root@opidclient:~# java -version
 java version "1.8.0_171"
 Java(TM) SE Runtime Environment (build 1.8.0_171-b11)
 Java HotSpot(TM) 64-Bit Server VM (build 25.171-b11, mixed mode)

ここで、oxd-serverを起動してみました そしてそれはうまくいきました。

root@opidclient:~# /etc/init.d/oxd-server start
 Starting oxd-server:
 Checking logs for possible errors:
 PID: [3797]
 OK Thu Jun 28 07:27:22 UTC 2018
 root@opidclient:~# ps -aef|grep oxd
 jetty 3797 1 51 07:27 ? 00:00:04 /usr/bin/java -server -Xms256m -Xmx512m -XX:MaxMetaspaceSize=256m -XX:+DisableExplicitGC -Doxd.server.config=/etc/oxd/oxd-server/oxd-conf.json -Dlog4j.configuration=/etc/oxd/oxd-server/log4j.xml -cp /opt/oxd-server/lib/bcprov-jdk15on-1.54.jar:/opt/oxd-server/lib/oxd-server-jar-with-dependencies.jar -Doxd.logging.dir=/var/log/oxd-server -Doxd.home=/opt/oxd-server -Doxd.base=/opt/oxd-server -Djava.io.tmpdir=/tmp org.xdi.oxd.server.ServerLauncher oxd-server.state=/opt/oxd-server/oxd-server.state start-log-file=/var/log/oxd-server/start.log
 root 3827 1581 0 07:27 pts/0 00:00:00 grep --color=auto oxd
root@opidclient:~# telnet 0 8099
 Trying 0.0.0.0...
 Connected to 0.
 Escape character is '^]'.

それでおしまい!。それが困っている人に役立つことを願っています。


Linux
  1. LinuxでTomcatサーバーを起動するには?

  2. MySQL データベース サーバーの停止:mysqld に失敗しました

  3. Node.js スクリプトが systemctl で開始できませんでした

  1. PostgreSQLデータベースサーバーの起動に失敗しました–UNIXプロセス用の未登録の認証エージェント[解決済み]

  2. Thesql Community Server(5.7)の起動に失敗しましたか?

  3. サーバーで lsof の実行が非常に遅い

  1. GlusterFSアレイで障害が発生したサーバーから回復する

  2. Java ProcessBuilder:結果のプロセスがハングする

  3. Androidエミュレーターの起動に失敗しました:プログラムを実行できません