Weblogicの各サーバーJVMごとに設定するカスタムプロパティが必要です。それを行うより良いアプローチは何ですか?
以下のように引数を指定できることはわかっています。
私の質問は、引数がどのように正確に定義されているのですか?そのJVM内にデプロイされるアプリケーション内でその引数を使用する方法。
編集
_-DMyArg=MyValue
_を指定し、コードでvalue=System.getproperty("MyValue");
を指定すると、これは機能するはずです。
編集:「-DMyArg = MyValue」を指定し、コードでvalue = System.getproperty( "MyValue");を指定した場合、これはうまくいくでしょう?
わずかな間違い、あなたは使うべきです
value=System.getProperty("MyArg");
ただし、これはNodeManagerが有効になっている場合にのみ機能します。そうでない場合は、startWeblogic.cmdでJava_Optionsの1つとして設定します。
さらに良いのは、次の行を含むsetDomainEnv.cmdです。
set EXTRA_Java_PROPERTIES=...
Binディレクトリの下でsetDomainEnv.sh
を編集して、次の行を見つけます。
USER_MEM_ARGS
環境変数が設定されている場合は、それを使用してALL MEM_ARGS
をオーバーライドし、以下の行を追加して、それに応じて値を変更します。
管理サーバーの場合
`if [ "${SERVER_NAME}" = "AdminServer" ] ; then
USER_MEM_ARGS="-Xms256m -Xmx256m -XX:MaxPermSize=256m"
MEM_ARGS="${USER_MEM_ARGS}"
export MEM_ARGS
fi`
管理対象サーバーの場合
`if [ "${SERVER_NAME}" != "AdminServer" ] ; then
USER_MEM_ARGS="-Xms512m -Xmx512m -XX:MaxPermSize=256m"
MEM_ARGS="${USER_MEM_ARGS}"
export MEM_ARGS
fi`
「customプロパティをweblogicの各サーバーJVMごとに設定する」必要がある場合、startWeblogic.cmdまたはsetDomainEnv.cmdを使用するだけでは不十分です。すべてのサーバーに同じ値を設定するためです。
NodeManagerが有効になっていない場合にできることの1つは、config.xmlファイルを手動で編集し、各サーバーの_<arguments>
_要素の下に_<server-start>
_要素を追加/編集することです。
ただし、これは推奨されません(ここを参照してください: http://docs.Oracle.com/cd/E23943_01/web.1111/e13716/config_files.htm )。 NodeMangerに依存し、説明した手順を使用する方がはるかに優れています。
それ以外は上記の答えvalue=System.getProperty("MyArg");
が正しいです。
私は通常、DOMAIN_HOMEの下にある各管理対象サーバーに対して単純な呼び出しスクリプトを作成します。これにより、/ binディレクトリの汎用起動スクリプトが呼び出されます。これは、WebLogicが管理サーバー用に自動的に作成するスクリプトのようなものです。この方法でメモリ引数をオーバーライドできることはわかっていますが、JVMを変更できると確信しています。
以下は、Windowsでテストされたスクリプトの例です。
cd bin
SET USER_MEM_ARGS=-Xms512m -Xmx512m
startManagedWebLogic.cmd new_ManagedServer_1 localhost:7001
uNIXではこれは次のようになると思います(bashスクリプトについてはあまり知りません)。
cd bin
export USER_MEM_ARGS="-Xms512m -Xmx512m"
./startManagedWebLogic.sh new_ManagedServer_1 localhost:7001
JVMを変更すると、次のようになります。
export Java_VENDOR="Oracle"
export USER_MEM_ARGS="-Xms512m –Xmx1g"
./startWebLogic.sh
これに関する誰かのフィードバックを聞いて興味がありますか?それが誰かを助けることを願っています。 。 。
これを行うには、次のファイルC:\ Oracle\Middleware\Oracle_Home\user_projects\domains\base_domain\bin\startWebLogic.cmdを変更します。
私の場合、それはドメインbase_domainです。
次の行を見つけて編集します。
@REM Java_OPTIONS - Java command-line options for running the server. (These
set "Java_OPTIONS=%Java_OPTIONS% -DyourVariable=value"
例
@ECHO OFF
@REM WARNING: This file is created by the Configuration Wizard.
@REM Any changes to this script may be lost when adding extensions to this configuration.
SETLOCAL
@REM --- Start Functions ---
GOTO :ENDFUNCTIONS
:stopAll
@REM We separate the stop commands into a function so we are able to use the trap command in Unix (calling a function) to stop these services
if NOT "X%ALREADY_STOPPED%"=="X" (
exit /b
)
@REM STOP DERBY (only if we started it)
if "%DERBY_FLAG%"=="true" (
echo Stopping Derby server...
call "%WL_HOME%\common\derby\bin\stopNetworkServer.cmd" >"%DOMAIN_HOME%\derbyShutdown.log" 2>&1
echo Derby server stopped.
)
set ALREADY_STOPPED=true
GOTO :EOF
:generateClassList
set Java_OPTIONS=%Java_OPTIONS% -Xshare:off -XX:+UnlockCommercialFeatures -XX:+IgnoreEmptyClassPaths -XX:DumpLoadedClassList=%APPCDS_CLASS_LIST% -XX:+UseAppCDS
GOTO :EOF
:useArchive
set Java_OPTIONS=%Java_OPTIONS% -XX:+UnlockCommercialFeatures -Xshare:auto -XX:+UseAppCDS -XX:+IgnoreEmptyClassPaths -XX:SharedArchiveFile=%APPCDS_ARCHIVE% -showversion
set USING_SHOWVERSION=true
GOTO :EOF
:ENDFUNCTIONS
ECHO HOLA.........................................................................
@REM --- End Functions ---
@REM *************************************************************************
@REM This script is used to start WebLogic Server for this domain.
@REM
@REM To create your own start script for your domain, you can initialize the
@REM environment by calling @USERDOMAINHOME\setDomainEnv.
@REM
@REM setDomainEnv initializes or calls commEnv to initialize the following variables:
@REM
@REM BEA_HOME - The BEA home directory of your WebLogic installation.
@REM Java_HOME - Location of the version of Java used to start WebLogic
@REM Server.
@REM Java_VENDOR - Vendor of the JVM (i.e. BEA, HP, IBM, Sun, etc.)
@REM PATH - JDK and WebLogic directories are added to system path.
@REM WEBLOGIC_CLASSPATH
@REM - Classpath needed to start WebLogic Server.
@REM PATCH_CLASSPATH - Classpath used for patches
@REM PATCH_LIBPATH - Library path used for patches
@REM PATCH_PATH - Path used for patches
@REM WEBLOGIC_EXTENSION_DIRS - Extension dirs for WebLogic classpath patch
@REM Java_VM - The Java arg specifying the VM to run. (i.e.
@REM - server, -hotspot, etc.)
@REM USER_MEM_ARGS - The variable to override the standard memory arguments
@REM passed to Java.
@REM PRODUCTION_MODE - The variable that determines whether Weblogic Server is started in production mode.
@REM DERBY_HOME - Derby home directory.
@REM DERBY_CLASSPATH
@REM - Classpath needed to start Derby.
@REM
@REM Other variables used in this script include:
@REM SERVER_NAME - Name of the weblogic server.
set "Java_OPTIONS=%Java_OPTIONS% -DUPLOAD_HOME=C:\files"
@REM Java_OPTIONS - Java command-line options for running the server. (These
@REM will be tagged on to the end of the Java_VM and
@REM MEM_ARGS)
@REM PROXY_SETTINGS - These are tagged on to the end of the Java_OPTIONS. This variable is deprecated and should not
@REM be used. Instead use Java_OPTIONS
@REM
@REM For additional information, refer to "Administering Server Startup and Shutdown for Oracle WebLogic Server"
@REM *************************************************************************
set SCRIPTPATH=%~dp0
set SCRIPTPATH=%SCRIPTPATH%
for %%i in ("%SCRIPTPATH%") do set SCRIPTPATH=%%~fsi
@REM Call setDomainEnv here.
set DOMAIN_HOME=C:\Oracle\Middleware\Oracle_Home\user_projects\domains\base_domain
for %%i in ("%DOMAIN_HOME%") do set DOMAIN_HOME=%%~fsi
call "%DOMAIN_HOME%\bin\setDomainEnv.cmd" %*
set SAVE_Java_OPTIONS=%Java_OPTIONS%
set SAVE_CLASSPATH=%CLASSPATH%
set TMP_UPDATE_SCRIPT=%TMP%\update.cmd
@REM Start Derby
set DERBY_DEBUG_LEVEL=0
if "%DERBY_FLAG%"=="true" (
call "%WL_HOME%\common\derby\bin\startNetworkServer.cmd" >"%DOMAIN_HOME%\derby.log" 2>&1
)
set Java_OPTIONS=%SAVE_Java_OPTIONS%
@REM In order to use resource consumption management policies or to get partition's resource consumption metrics, uncomment the following Java_OPTIONS
set #Java_OPTIONS=-XX:+UnlockCommercialFeatures -XX:+ResourceManagement -XX:+UseG1GC %SAVE_Java_OPTIONS%
set SAVE_Java_OPTIONS=
set CLASSPATH=%SAVE_CLASSPATH%
set SAVE_CLASSPATH=
if "%PRODUCTION_MODE%"=="true" (
set WLS_DISPLAY_MODE=Production
) else (
set WLS_DISPLAY_MODE=Development
)
if NOT "%WLS_USER%"=="" (
set Java_OPTIONS=%Java_OPTIONS% -Dweblogic.management.username=%WLS_USER%
)
if NOT "%WLS_PW%"=="" (
set Java_OPTIONS=%Java_OPTIONS% -Dweblogic.management.password=%WLS_PW%
)
if NOT "%MEDREC_WEBLOGIC_CLASSPATH%"=="" (
if NOT "%CLASSPATH%"=="" (
set CLASSPATH=%CLASSPATH%;%MEDREC_WEBLOGIC_CLASSPATH%
) else (
set CLASSPATH=%MEDREC_WEBLOGIC_CLASSPATH%
)
)
if "%GENERATE_CLASS_LIST%"=="true" (
CALL :generateClassList
)
if "%USE_ARCHIVE%"=="true" (
CALL :useArchive
)
echo .
echo .
echo Java Memory arguments: %MEM_ARGS%
echo .
echo CLASSPATH=%CLASSPATH%
echo .
echo PATH=%PATH%
echo .
echo ***************************************************
echo * To start WebLogic Server, use a username and *
echo * password assigned to an admin-level user. For *
echo * server administration, use the WebLogic Server *
echo * console at http:\\hostname:port\console *
echo ***************************************************
@REM START WEBLOGIC
if NOT "%USE_JVM_SYSTEM_LOADER%"=="true" (
set LAUNCH_ARGS=-cp %WL_HOME%\server\lib\weblogic-launcher.jar -Dlaunch.use.env.classpath=true
)
if "%USING_SHOWVERSION%"=="true" (
echo starting weblogic with Java version:
%Java_HOME%\bin\Java %Java_VM% -version
)
if "%WLS_REDIRECT_LOG%"=="" (
echo Starting WLS with line:
echo %Java_HOME%\bin\Java %Java_VM% %MEM_ARGS% %LAUNCH_ARGS% -Dweblogic.Name=%SERVER_NAME% -Djava.security.policy=%WLS_POLICY_FILE% %Java_OPTIONS% %PROXY_SETTINGS% %SERVER_CLASS%
%Java_HOME%\bin\Java %Java_VM% %MEM_ARGS% %LAUNCH_ARGS% -Dweblogic.Name=%SERVER_NAME% -Djava.security.policy=%WLS_POLICY_FILE% %Java_OPTIONS% %PROXY_SETTINGS% %SERVER_CLASS%
) else (
echo Redirecting output from WLS window to %WLS_REDIRECT_LOG%
%Java_HOME%\bin\Java %Java_VM% %MEM_ARGS% %LAUNCH_ARGS% -Dweblogic.Name=%SERVER_NAME% -Djava.security.policy=%WLS_POLICY_FILE% %Java_OPTIONS% %PROXY_SETTINGS% %SERVER_CLASS% >"%WLS_REDIRECT_LOG%" 2>&1
)
IF ERRORLEVEL 86 IF NOT ERRORLEVEL 87 (set shutDownStatus=86) ELSE (IF ERRORLEVEL 88 IF NOT ERRORLEVEL 89 ( set shutDownStatus=88 ) )
CALL :stopAll
popd
IF EXIST %TMP_UPDATE_SCRIPT% (set fileExists=true) ELSE (set fileExists=false)
if "%shutDownStatus%"=="86" (
if "%fileExists%"=="true" (
echo Calling %TMP_UPDATE_SCRIPT%
cd %TMP:~0,2%
cd %TMP%
call %TMP_UPDATE_SCRIPT%
IF ERRORLEVEL 42 IF NOT ERRORLEVEL 43 (set ustatus=42 )
@REM restoring the original env before unsetting Java_HOME
@REM in order to unset any Java_HOME that was passed in from domainEnv
if "%ustatus%"=="42" (
set Java_HOME=
)
) else (
echo ERROR! %TMP_UPDATE_SCRIPT% did not exist
)
@REM Call the same script path that was supplied in order to restart ourselves
@REM restoreOrigEnv will go here
call "%SCRIPTPATH%\startWebLogic.cmd"
) else (
if "%shutDownStatus%"=="88" (
@REM restoreOrigEnv will go here
call "%SCRIPTPATH%\startWebLogic.cmd"
)
)
@REM Exit this script only if we have been told to exit.
if "%doExitFlag%"=="true" (
exit
)
ENDLOCAL