From a4982851f151a095596aa211dadddffbd3438a19 Mon Sep 17 00:00:00 2001 From: Marc Nuri Date: Fri, 21 Jun 2024 13:21:04 +0200 Subject: [PATCH] feat(jkube-java): run java doesn't use container-limits --- jkube-java.yaml | 13 ++++--------- modules/jboss.container.openjdk.jdk/21/module.yaml | 2 +- scripts/test-jkube-java.sh | 14 ++++++-------- 3 files changed, 11 insertions(+), 18 deletions(-) diff --git a/jkube-java.yaml b/jkube-java.yaml index c010bf7..b9c5433 100644 --- a/jkube-java.yaml +++ b/jkube-java.yaml @@ -44,17 +44,12 @@ modules: - name: jboss.container.microdnf-bz-workaround - name: jboss.container.openjdk.jdk version: "21" - - name: jboss.container.maven - version: 8.2.3.8 - name: jboss.container.dnf - - name: jboss.container.java.s2i.bash - - name: jboss.container.java.run.bash - - name: jboss.container.jolokia - version: jkube-2.0.0 - - name: jboss.container.prometheus - version: jkube-0.20.0 + - name: org.eclipse.jkube.s2i.bash + version: 1.0.0 + - name: org.eclipse.jkube.jolokia + version: 2.0.0 - name: jboss.container.util.logging.bash - - name: jboss.container.java.jvm.bash.debug-options-override # Removes any other Java JDK that might have been downloaded by other packages (run last) - name: org.eclipse.jkube.jvm.singleton-jdk diff --git a/modules/jboss.container.openjdk.jdk/21/module.yaml b/modules/jboss.container.openjdk.jdk/21/module.yaml index 8f40ff7..745ea39 100644 --- a/modules/jboss.container.openjdk.jdk/21/module.yaml +++ b/modules/jboss.container.openjdk.jdk/21/module.yaml @@ -28,7 +28,7 @@ packages: modules: install: - - name: jboss.container.user + - name: org.eclipse.jkube.user execute: - script: configure.sh diff --git a/scripts/test-jkube-java.sh b/scripts/test-jkube-java.sh index c9a88b5..2faf8df 100755 --- a/scripts/test-jkube-java.sh +++ b/scripts/test-jkube-java.sh @@ -29,20 +29,19 @@ assertMatches "$maven_version" 'Apache Maven 3.8.[0-9]+' || reportError "Invalid # run-java dependent scripts (xxx.java.jvm.bash) jvm_tools="$(dockerRun 'ls -la /opt/jboss/container/java/jvm/')" -assertContains "$jvm_tools" "container-limits$" || reportError "container-limits not found" assertContains "$jvm_tools" "debug-options$" || reportError "debug-options not found" assertContains "$jvm_tools" "java-default-options$" || reportError "java-default-options not found" # java-default-options default java_default_options="$(dockerRunE '/opt/jboss/container/java/jvm/java-default-options')" || reportError "Failed to get java_default_options" -assertMatches "$java_default_options" '^-XX:MinHeapFreeRatio=10 -XX:MaxHeapFreeRatio=20 -XX:GCTimeRatio=4 -XX:AdaptiveSizePolicyWeight=90 -XX:\+ExitOnOutOfMemoryError$' \ +assertMatches "$java_default_options" '^-XX:MaxRAMPercentage=80.0 -XX:MinHeapFreeRatio=10 -XX:MaxHeapFreeRatio=20 -XX:GCTimeRatio=4 -XX:AdaptiveSizePolicyWeight=90 -XX:\+ExitOnOutOfMemoryError$' \ || reportError "Invalid java_default_options:\n\n$java_default_options" # java-default-options override with JAVA_DIAGNOSTICS java_default_options="$(dockerRunE /bin/bash -c 'JAVA_DIAGNOSTICS=true /opt/jboss/container/java/jvm/java-default-options')"|| reportError "Failed to get java_default_options" -assertMatches "$java_default_options" '^-XX:MinHeapFreeRatio=10 -XX:MaxHeapFreeRatio=20 -XX:GCTimeRatio=4 -XX:AdaptiveSizePolicyWeight=90 -Xlog:gc::utctime -XX:NativeMemoryTracking=summary -XX:\+ExitOnOutOfMemoryError$' \ +assertMatches "$java_default_options" '^-XX:MaxRAMPercentage=80.0 -XX:MinHeapFreeRatio=10 -XX:MaxHeapFreeRatio=20 -XX:GCTimeRatio=4 -XX:AdaptiveSizePolicyWeight=90 -Xlog:gc::utctime -XX:NativeMemoryTracking=summary -XX:\+ExitOnOutOfMemoryError$' \ || reportError "Invalid java_default_options (JAVA_DIAGNOSTICS):\n\n$java_default_options" # java-default-options override with blank GC_CONTAINER_OPTIONS env (Unsupported -XX:+UseParallelOldGC is listed) java_default_options="$(dockerRunE /bin/bash -c 'GC_CONTAINER_OPTIONS="" /opt/jboss/container/java/jvm/java-default-options')"|| reportError "Failed to get java_default_options" -assertMatches "$java_default_options" "^-XX:\+UseParallelOldGC -XX:MinHeapFreeRatio=10 -XX:MaxHeapFreeRatio=20 -XX:GCTimeRatio=4 -XX:AdaptiveSizePolicyWeight=90 -XX:\+ExitOnOutOfMemoryError$" \ +assertMatches "$java_default_options" "^-XX:MaxRAMPercentage=80.0 -XX:\+UseParallelGC -XX:MinHeapFreeRatio=10 -XX:MaxHeapFreeRatio=20 -XX:GCTimeRatio=4 -XX:AdaptiveSizePolicyWeight=90 -XX:\+ExitOnOutOfMemoryError$" \ || reportError "Invalid java_default_options (GC_CONTAINER_OPTIONS):\n\n$java_default_options" # debug-options-override @@ -52,11 +51,10 @@ assertContains "$debug_options" "[-]agentlib:jdwp=transport=dt_socket,server=y,s # Default run-java module (xxx.java.run.bash) run_java="$(dockerRun 'ls -la /opt/jboss/container/java/run/')" -assertContains "$run_java" "run-env.sh" || reportError "run-env.sh not found" assertContains "$run_java" "run-java.sh" || reportError "run-java.sh not found" # shellcheck disable=SC2016 run_java_exec="$(dockerRunE /bin/bash -c 'JAVA_APP_JAR=$JAVA_HOME/lib/jrt-fs.jar /opt/jboss/container/java/run/run-java.sh')" || reportError "Failed to get run_java_exec" -assertMatches "$run_java_exec" ".+java -XX:MinHeapFreeRatio=10 -XX:MaxHeapFreeRatio=20 -XX:GCTimeRatio=4 -XX:AdaptiveSizePolicyWeight=90 -XX:\+ExitOnOutOfMemoryError -cp \".\" -jar.+" \ +assertMatches "$run_java_exec" ".+java -XX:MaxRAMPercentage=80.0 -XX:MinHeapFreeRatio=10 -XX:MaxHeapFreeRatio=20 -XX:GCTimeRatio=4 -XX:AdaptiveSizePolicyWeight=90 -XX:\+ExitOnOutOfMemoryError -cp \".\" -jar.+" \ || reportError "Invalid run_java_exec:\n\n$run_java_exec" # Jolokia module @@ -82,9 +80,9 @@ assertContains "$(dockerRun 'cat /usr/local/s2i/assemble')" 'maven_s2i_build$' | s2i_run="$(dockerRunE /bin/bash -c 'JAVA_APP_JAR=$JAVA_HOME/lib/jrt-fs.jar /usr/local/s2i/run')" || reportError "Failed to get s2i_run" assertJolokia="-javaagent:/usr/share/java/jolokia-jvm-agent/jolokia-jvm.jar=config=/opt/jboss/container/jolokia/etc/jolokia.properties" assertPrometheus="-javaagent:/usr/share/java/prometheus-jmx-exporter/jmx_prometheus_javaagent.jar=9779:/opt/jboss/container/prometheus/etc/jmx-exporter-config.yaml" -assertJavaExec="-XX:MinHeapFreeRatio=10 -XX:MaxHeapFreeRatio=20 -XX:GCTimeRatio=4 -XX:AdaptiveSizePolicyWeight=90 -XX:\+ExitOnOutOfMemoryError -cp \".\" -jar" +assertJavaExec="-XX:MaxRAMPercentage=80.0 -XX:MinHeapFreeRatio=10 -XX:MaxHeapFreeRatio=20 -XX:GCTimeRatio=4 -XX:AdaptiveSizePolicyWeight=90 -XX:\+ExitOnOutOfMemoryError -cp \".\" -jar" assertMatches "$s2i_run" ".+java $assertJolokia $assertPrometheus $assertJavaExec.+" \ - || reportError "Invalid run_java_exec:\n\n$s2i_run" + || reportError "Invalid s2i_run:\n\n$s2i_run" # Generic environment variables assertContains "$env_variables" "DEPLOYMENTS_DIR=/deployments$" \