web-3/wildfly/bin/common.ps1

479 lines
16 KiB
PowerShell
Raw Normal View History

2024-11-26 02:32:07 +03:00
if($PSVersionTable.PSVersion.Major -lt 2) {
Write-Warning "This script requires PowerShell 2.0 or better; you have version $($Host.Version)."
return
}
$SCRIPTS_HOME = (Get-ChildItem $MyInvocation.MyCommand.Path).Directory.FullName
$RESOLVED_JBOSS_HOME = (Get-ChildItem $MyInvocation.MyCommand.Path).Directory.Parent.FullName
# A collection of functions that are used by the other scripts
Function Set-Env {
$key = $args[0]
$value = $args[1]
Set-Content -Path env:$key -Value $value
}
Function Get-Env {
$key = $args[0]
if( Test-Path env:$key ) {
return (Get-ChildItem env:$key).Value
}
return $args[1]
}
Function Get-Env-Boolean{
$key = $args[0]
if( Test-Path env:$key ) {
return (Get-ChildItem env:$key).Value -eq 'true'
}
return $args[1]
}
$COMMOM_CONF_FILE = $SCRIPTS_HOME + '\common.conf.ps1'
$COMMOM_CONF_FILE = Get-Env COMMON_CONF $COMMOM_CONF_FILE
if ([System.IO.File]::Exists($COMMOM_CONF_FILE)) {
. $COMMOM_CONF_FILE
} else {
if (Test-Path env:COMMON_CONF) {
Write-Output "Config file not found $env:COMMON_CONF"
}
}
$global:SECMGR = Get-Env-Boolean SECMGR $false
$global:DEBUG_MODE=Get-Env DEBUG $false
$global:DEBUG_PORT=Get-Env DEBUG_PORT 8787
$global:RUN_IN_BACKGROUND=$false
$GC_LOG=Get-Env GC_LOG
#module opts that are passed to jboss modules
$global:MODULE_OPTS = @()
Function Get-String {
$value = ''
foreach($k in $args) {
$value += $k
}
return $value
}
Function String-To-Array($value) {
$res = @()
if (!$value){
return $res
}
$tmpArr = $value.split()
foreach ($str in $tmpArr) {
if ($str) {
$res += $str
}
}
return $res
}
Function Display-Environment {
Param(
[string[]]$javaOpts
) #end param
if (-Not $javaOpts){
$javaOpts = Get-Java-Opts
}
# Display our environment
Write-Host "================================================================================="
Write-Host ""
Write-Host " JBoss Bootstrap Environment"
Write-Host ""
Write-Host " JBOSS_HOME: $JBOSS_HOME"
Write-Host ""
Write-Host " JAVA: $JAVA"
Write-Host ""
Write-Host " MODULE_OPTS: $MODULE_OPTS"
Write-Host ""
Write-Host " JAVA_OPTS: $javaOpts"
Write-Host ""
Write-Host "================================================================================="
Write-Host ""
}
#todo: bit funky at the moment, should probably be done via global variable
Function Get-Java-Opts {
if($PRESERVE_JAVA_OPTS -ne 'true') { # if not perserve, then check for enviroment variable and use that
if( (Test-Path env:JAVA_OPTS)) {
$ops = Get-Env JAVA_OPTS
# This is Powershell, so split the incoming string on a space into array
return String-To-Array -value $ops
Write-Host "JAVA_OPTS already set in environment; overriding default settings with values: $JAVA_OPTS"
}
}
return $JAVA_OPTS
}
Function SetPackageAvailable($packageName) {
# java -version actually writes what we all read in our terminals to stderr, not stdout!
# So we redirect it to stdout with 2>&1 before piping to Out-String and Select-String
$PACKAGE_AVAILABLE = !(& $JAVA "--add-opens=$packageName=ALL-UNNAMED" -version 2>&1 | Out-String -Stream | Select-String 'WARNING' -SimpleMatch -Quiet)
return $PACKAGE_AVAILABLE
}
Function SetEnhancedSecurityManager {
$ENHANCED_SM = $false
& $JAVA "-Djava.security.manager=allow" -version >$null 2>&1
if ($LastExitCode -eq 0){
$ENHANCED_SM = $true
}
return $ENHANCED_SM
}
Function Get-Security-Manager-Default {
Param(
[bool]$enhancedSM
) #end param
if($PRESERVE_JAVA_OPTS -eq 'true') {
return $null
}
$SECURITY_MANAGER_CONFIG_OPTION = @()
if ($enhancedSM) {
# Needed to be able to install Security Manager dynamically since JDK18
$SECURITY_MANAGER_CONFIG_OPTION += "-Djava.security.manager=allow"
}
return $SECURITY_MANAGER_CONFIG_OPTION
}
Function SetModularJDK {
$MODULAR_JDK = $false
& $JAVA --add-modules java.se -version >$null 2>&1
if ($LastExitCode -eq 0){
$MODULAR_JDK = $true
}
return $MODULAR_JDK
}
Function Get-Default-Modular-Jvm-Options {
Param(
[string[]]$opts,
[bool]$modularJDK
) #end param
if($PRESERVE_JAVA_OPTS -eq 'true') {
return $null
}
$DEFAULT_MODULAR_JVM_OPTIONS = @()
if ($modularJDK) {
if ($opts -ne $null) {
for($i=0; $i -lt $opts.Count; $i++) {
$arg = $opts[$i]
if ($arg -contains "--add-modules") {
return $DEFAULT_MODULAR_JVM_OPTIONS
}
}
}
# Set default modular jdk options
# Needed by the iiop-openjdk subsystem
$DEFAULT_MODULAR_JVM_OPTIONS += "--add-exports=java.desktop/sun.awt=ALL-UNNAMED"
# Needed to instantiate the default InitialContextFactory implementation used by the
# Elytron subsystem dir-context and core management ldap-connection resources
$DEFAULT_MODULAR_JVM_OPTIONS += "--add-exports=java.naming/com.sun.jndi.ldap=ALL-UNNAMED"
$DEFAULT_MODULAR_JVM_OPTIONS += "--add-exports=java.naming/com.sun.jndi.url.ldap=ALL-UNNAMED"
$DEFAULT_MODULAR_JVM_OPTIONS += "--add-exports=java.naming/com.sun.jndi.url.ldaps=ALL-UNNAMED"
# Needed by Netty
$DEFAULT_MODULAR_JVM_OPTIONS += "--add-exports=jdk.naming.dns/com.sun.jndi.dns=ALL-UNNAMED"
# Needed by WildFly Elytron Extension
$packageName = "java.base/com.sun.net.ssl.internal.ssl"
$PACKAGE_AVAILABLE = setPackageAvailable($packageName)
if($PACKAGE_AVAILABLE) {
$DEFAULT_MODULAR_JVM_OPTIONS += "--add-opens=$packageName=ALL-UNNAMED"
}
# Needed if Hibernate applications use Javassist
$DEFAULT_MODULAR_JVM_OPTIONS += "--add-opens=java.base/java.lang=ALL-UNNAMED"
# Needed by the MicroProfile REST Client subsystem
$DEFAULT_MODULAR_JVM_OPTIONS += "--add-opens=java.base/java.lang.invoke=ALL-UNNAMED"
# Needed for marshalling of proxies
$DEFAULT_MODULAR_JVM_OPTIONS += "--add-opens=java.base/java.lang.reflect=ALL-UNNAMED"
# Needed by JBoss Marshalling
$DEFAULT_MODULAR_JVM_OPTIONS += "--add-opens=java.base/java.io=ALL-UNNAMED"
# Needed by WildFly Http Client
$DEFAULT_MODULAR_JVM_OPTIONS += "--add-opens=java.base/java.net=ALL-UNNAMED"
# Needed by WildFly Security Manager
$DEFAULT_MODULAR_JVM_OPTIONS += "--add-opens=java.base/java.security=ALL-UNNAMED"
# Needed for marshalling of collections
$DEFAULT_MODULAR_JVM_OPTIONS += "--add-opens=java.base/java.util=ALL-UNNAMED"
# Needed for marshalling of concurrent collections
$DEFAULT_MODULAR_JVM_OPTIONS += "--add-opens=java.base/java.util.concurrent=ALL-UNNAMED"
# EE integration with sar mbeans requires deep reflection in javax.management
$DEFAULT_MODULAR_JVM_OPTIONS += "--add-opens=java.management/javax.management=ALL-UNNAMED"
# InitialContext proxy generation requires deep reflection in javax.naming
$DEFAULT_MODULAR_JVM_OPTIONS += "--add-opens=java.naming/javax.naming=ALL-UNNAMED"
}
return $DEFAULT_MODULAR_JVM_OPTIONS
}
Function Display-Array($array){
for ($i=0; $i -lt $array.length; $i++) {
$v = "$i " + $array[$i]
Write-Host $v
}
}
Function Get-Java-Arguments {
Param(
[Parameter(Mandatory=$true)]
[string]$entryModule,
[string]$logFileProperties = "$JBOSS_CONFIG_DIR/logging.properties",
[string]$logFile = "$JBOSS_LOG_DIR/server.log",
[string[]]$serverOpts
) #end param
$MODULAR_JDK = SetModularJDK
$JAVA_OPTS = Get-Java-Opts #takes care of looking at defind settings and/or using env:JAVA_OPTS
$DEFAULT_MODULAR_JVM_OPTS = Get-Default-Modular-Jvm-Options -opts $JAVA_OPTS -modularJDK $MODULAR_JDK
$ENHANCED_SM = SetEnhancedSecurityManager
$SECURITY_MANAGER_CONFIG_OPT = Get-Security-Manager-Default -enhancedSM $ENHANCED_SM
$PROG_ARGS = @()
if ($JAVA_OPTS -ne $null){
$PROG_ARGS += $JAVA_OPTS
}
if ($DEFAULT_MODULAR_JVM_OPTS -ne $null){
$PROG_ARGS += $DEFAULT_MODULAR_JVM_OPTS
}
if ($SECURITY_MANAGER_CONFIG_OPT -ne $null){
$PROG_ARGS += $SECURITY_MANAGER_CONFIG_OPT
}
if ($logFile){
$PROG_ARGS += "-Dorg.jboss.boot.log.file=$logFile"
}
if ($logFileProperties){
$PROG_ARGS += "-Dlogging.configuration=file:$logFileProperties"
}
$PROG_ARGS += "-Djboss.home.dir=$JBOSS_HOME"
$PROG_ARGS += "-Djboss.server.base.dir=$global:JBOSS_BASE_DIR"
$PROG_ARGS += "-Djboss.server.config.dir=$global:JBOSS_CONFIG_DIR"
if ($GC_LOG -eq $true){
$dir = New-Item $JBOSS_LOG_DIR -type directory -ErrorAction SilentlyContinue
if ($PROG_ARGS -notmatch "-Xlog:?gc"){
Rotate-GC-Logs
& $JAVA -Xverbosegclog:"$JBOSS_LOG_DIR\gc.log" java.se -version >$null 2>&1
if ($LastExitCode -eq 0){
$PROG_ARGS += "-Xverbosegclog:`\`"$JBOSS_LOG_DIR\gc.log`\`""
}elseif ($MODULAR_JDK -eq $true)
{
$PROG_ARGS += "-Xlog:gc*:file=`\`"$JBOSS_LOG_DIR\gc.log`\`":time,uptimemillis:filecount=5,filesize=3M"
} else {
$PROG_ARGS += "-verbose:gc"
$PROG_ARGS += "-XX:+PrintGCDetails"
$PROG_ARGS += "-XX:+PrintGCDateStamps"
$PROG_ARGS += "-XX:+UseGCLogFileRotation"
$PROG_ARGS += "-XX:NumberOfGCLogFiles=5"
$PROG_ARGS += "-XX:GCLogFileSize=3M"
$PROG_ARGS += "-XX:-TraceClassUnloading"
$PROG_ARGS += "-Xloggc:$JBOSS_LOG_DIR\gc.log"
}
}
}
$global:FINAL_JAVA_OPTS = $PROG_ARGS
$PROG_ARGS += "-jar"
$PROG_ARGS += "$JBOSS_HOME\jboss-modules.jar"
if ($MODULE_OPTS -ne $null){
$PROG_ARGS += $MODULE_OPTS
}
$PROG_ARGS += "-mp"
$PROG_ARGS += "$JBOSS_MODULEPATH"
$PROG_ARGS += $entryModule
if ($serverOpts -ne $null){
$PROG_ARGS += $serverOpts
}
return $PROG_ARGS
}
Function Process-Script-Parameters {
Param(
[Parameter(Mandatory=$false)]
[string[]]$Params
) #end param
$res = @()
for($i=0; $i -lt $Params.Count; $i++){
$arg = $Params[$i]
if ($arg -eq '--debug'){
$global:DEBUG_MODE=$true
if ($args[$i+1] -match '\d+'){ #port number can only follow --debug
$global:DEBUG_PORT = $Params[$i+1]
$i++
continue
}
}elseif ($arg -contains '-Djava.security.manager'){
Write-Warning "ERROR: The use of -Djava.security.manager has been removed. Please use the -secmgr command line argument or SECMGR=true environment variable."
exit
}elseif ($arg -eq '-secmgr'){
$global:SECMGR = $true
}elseif ($arg -eq '--background'){
$global:RUN_IN_BACKGROUND = $true
}else{
$res+=$arg
}
}
return $res
}
Function Process-Java-Opts-Parameters {
Param(
[Parameter(Mandatory=$false)]
[string[]]$Params
) #end param
$res = @()
for($i=0; $i -lt $Params.Count; $i++){
$arg = $Params[$i]
if ($arg -contains '-Djava.security.manager'){
Write-Warning "ERROR: The use of -Djava.security.manager has been removed. Please use the -secmgr command line argument or SECMGR=true environment variable."
exit
}else{
$res+=$arg
}
}
return $res
}
Function Start-WildFly-Process {
Param(
[Parameter(Mandatory=$true)]
[string[]] $programArguments,
[boolean] $runInBackground = $false,
[string] $logFileProperties = "$global:JBOSS_CONFIG_DIR\logging.properties",
[string] $logFile = "$global:JBOSS_LOG_DIR\server.log"
) #end param
if(($JBOSS_PIDFILE -ne '') -and (Test-Path $JBOSS_PIDFILE)) {
$processId = gc $JBOSS_PIDFILE
if ($processId -ne $null){
$proc = Get-Process -Id $processId -ErrorAction SilentlyContinue
}
if ($proc -ne $null){
Write-Warning "Looks like a server process is already running. If it isn't then, remove the $JBOSS_PIDFILE and try again"
return
}else{
Remove-Item $JBOSS_PIDFILE
}
}
if($runInBackground) {
$process = Start-Process -FilePath $JAVA -ArgumentList $programArguments -NoNewWindow -RedirectStandardOutput $global:CONSOLE_LOG -WorkingDirectory $JBOSS_HOME -PassThru
$processId = $process.Id;
echo "Started process in background, process id: $processId"
if ($JBOSS_PIDFILE -ne $null){
$processId >> $JBOSS_PIDFILE
}
} else {
try{
pushd $JBOSS_HOME
& $JAVA $programArguments
if ($LastExitCode -eq 10){ # :shutdown(restart=true) was called
Write-Host "INFO: Restarting..."
Start-WildFly-Process -programArguments $programArguments
} elseif ($LastExitCode -eq 20) { # :shutdown(perform-installation=true) was called
Write-Host "INFO: Starting Candidate Server installation using Management CLI Installer script"
$instMgrOutFile="$JBOSS_LOG_DIR\management-cli-installer-out.log"
& "$JBOSS_HOME\bin\installation-manager.ps1" -installationHome "$JBOSS_HOME" -instMgrLogProperties "$logFileProperties" -instMgrLogFile "$logFile" *>&1 | Out-File -FilePath $instMgrOutFile -Append -Encoding UTF8
if ($LastExitCode -eq 0) {
Write-Host "INFO: Candidate Server installation completed successfully."
} else {
Write-Host "ERROR: Candidate Server installation failed. Check Management CLI Installer script log file for more information: $instMgrOutFile"
}
Write-Host "INFO: Restarting..."
Start-WildFly-Process -programArguments $programArguments
}
}finally{
popd
}
}
Env-Clean-Up
}
Function Set-Global-Variables {
PARAM(
[Parameter(Mandatory=$true)]
[string]$baseDir
)
# determine the default base dir, if not set
$global:JBOSS_BASE_DIR = $baseDir;
# determine the default log dir, if not set
$global:JBOSS_LOG_DIR = Get-Env JBOSS_LOG_DIR $JBOSS_BASE_DIR\log
# determine the default configuration dir, if not set
$global:JBOSS_CONFIG_DIR = Get-Env JBOSS_CONFIG_DIR $JBOSS_BASE_DIR\configuration
$global:CONSOLE_LOG = $JBOSS_LOG_DIR + '\console.log'
}
Function Set-Global-Variables-Standalone {
$dir = Get-Env JBOSS_BASE_DIR $JBOSS_HOME\standalone
Set-Global-Variables -baseDir $dir
}
Function Set-Global-Variables-Domain {
$dir = Get-Env JBOSS_BASE_DIR $JBOSS_HOME\domain
Set-Global-Variables -baseDir $dir
}
Function Env-Clean-Up {
[Environment]::SetEnvironmentVariable("JBOSS_HOME", $PRE_JBOSS_HOME, "Process")
}
Function Rotate-GC-Logs {
mv -ErrorAction SilentlyContinue $JBOSS_LOG_DIR/gc.log $JBOSS_LOG_DIR/backupgc.log
mv -ErrorAction SilentlyContinue $JBOSS_LOG_DIR/gc.log.0 $JBOSS_LOG_DIR/backupgc.log.0
mv -ErrorAction SilentlyContinue $JBOSS_LOG_DIR/gc.log.1 $JBOSS_LOG_DIR/backupgc.log.1
mv -ErrorAction SilentlyContinue $JBOSS_LOG_DIR/gc.log.2 $JBOSS_LOG_DIR/backupgc.log.2
mv -ErrorAction SilentlyContinue $JBOSS_LOG_DIR/gc.log.3 $JBOSS_LOG_DIR/backupgc.log.3
mv -ErrorAction SilentlyContinue $JBOSS_LOG_DIR/gc.log.4 $JBOSS_LOG_DIR/backupgc.log.4
mv -ErrorAction SilentlyContinue $JBOSS_LOG_DIR/gc.log.*.current $JBOSS_LOG_DIR/backupgc.log.current
}
# Setup JBOSS_HOME
if((Test-Path env:JBOSS_HOME) -and (Test-Path (Get-Item env:JBOSS_HOME))) {# checks if env variable jboss is set and is valid folder
$SANITIZED_JBOSS_HOME = (Get-Item env:JBOSS_HOME).FullName
if($SANITIZED_JBOSS_HOME -ne $RESOLVED_JBOSS_HOME) {
echo "WARNING JBOSS_HOME may be pointing to a different installation - unpredictable results may occur."
echo ""
}
$JBOSS_HOME=$SANITIZED_JBOSS_HOME
} else {
# get the full path (without any relative bits)
$JBOSS_HOME=$RESOLVED_JBOSS_HOME
}
# Setup the JVM
if (!(Test-Path env:JAVA)) {
if( Test-Path env:JAVA_HOME) {
$JAVA_HOME = (Get-ChildItem env:JAVA_HOME).Value
$JAVA = $JAVA_HOME + "\bin\java.exe"
} else {
$JAVA = 'java'
}
}
# determine the default module path, if not set
$JBOSS_MODULEPATH = Get-Env JBOSS_MODULEPATH $JBOSS_HOME\modules
Set-Global-Variables-Standalone
# Determine the default JBoss PID file
$JBOSS_PIDFILE = Get-Env JBOSS_PIDFILE $SCRIPTS_HOME\process.pid
# Set the PRE_JBOSS_HOME variable as the $env:JBOSS_HOME or $null, used in function: Env-Clean-Up
$PRE_JBOSS_HOME = Get-Env JBOSS_HOME $null
[Environment]::SetEnvironmentVariable("JBOSS_HOME", $JBOSS_HOME, "Process")