This is an automated email from the ASF dual-hosted git repository.

jamesnetherton pushed a commit to branch main
in repository https://gitbox.apache.org/repos/asf/camel-quarkus-examples.git

commit d948d9519b5ccf3a4564715f307b1a7c74fe21ca
Author: Lukas Lowinger <[email protected]>
AuthorDate: Tue Feb 17 15:27:04 2026 +0100

    Add dockerfiles to Observability example project
---
 observability/pom.xml                              |   8 ++
 observability/src/main/docker/Dockerfile.jvm       | 116 +++++++++++++++++++++
 .../src/main/docker/Dockerfile.legacy-jar          | 112 ++++++++++++++++++++
 observability/src/main/docker/Dockerfile.native    |  45 ++++++++
 .../src/main/docker/Dockerfile.native-micro        |  48 +++++++++
 5 files changed, 329 insertions(+)

diff --git a/observability/pom.xml b/observability/pom.xml
index d73689c4..c7c64633 100644
--- a/observability/pom.xml
+++ b/observability/pom.xml
@@ -213,6 +213,10 @@
                         </excludes>
                         <mapping>
                             <java>SLASHSTAR_STYLE</java>
+                            <jvm>CAMEL_PROPERTIES_STYLE</jvm>
+                            <legacy-jar>CAMEL_PROPERTIES_STYLE</legacy-jar>
+                            <native>CAMEL_PROPERTIES_STYLE</native>
+                            <native-micro>CAMEL_PROPERTIES_STYLE</native-micro>
                             <properties>CAMEL_PROPERTIES_STYLE</properties>
                             <kt>SLASHSTAR_STYLE</kt>
                         </mapping>
@@ -381,6 +385,10 @@
                                 </excludes>
                                 <mapping>
                                     <java>SLASHSTAR_STYLE</java>
+                                    <jvm>CAMEL_PROPERTIES_STYLE</jvm>
+                                    
<legacy-jar>CAMEL_PROPERTIES_STYLE</legacy-jar>
+                                    <native>CAMEL_PROPERTIES_STYLE</native>
+                                    
<native-micro>CAMEL_PROPERTIES_STYLE</native-micro>
                                     
<properties>CAMEL_PROPERTIES_STYLE</properties>
                                     <kt>SLASHSTAR_STYLE</kt>
                                 </mapping>
diff --git a/observability/src/main/docker/Dockerfile.jvm 
b/observability/src/main/docker/Dockerfile.jvm
new file mode 100644
index 00000000..42ede85d
--- /dev/null
+++ b/observability/src/main/docker/Dockerfile.jvm
@@ -0,0 +1,116 @@
+## ---------------------------------------------------------------------------
+## Licensed to the Apache Software Foundation (ASF) under one or more
+## contributor license agreements.  See the NOTICE file distributed with
+## this work for additional information regarding copyright ownership.
+## The ASF licenses this file to You under the Apache License, Version 2.0
+## (the "License"); you may not use this file except in compliance with
+## the License.  You may obtain a copy of the License at
+##
+##      http://www.apache.org/licenses/LICENSE-2.0
+##
+## Unless required by applicable law or agreed to in writing, software
+## distributed under the License is distributed on an "AS IS" BASIS,
+## WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
+## See the License for the specific language governing permissions and
+## limitations under the License.
+## ---------------------------------------------------------------------------
+####
+# This Dockerfile is used in order to build a container that runs the Quarkus 
application in JVM mode
+#
+# Before building the container image run:
+#
+# ./mvnw package
+#
+# Then, build the image with:
+#
+# docker build -f src/main/docker/Dockerfile.jvm -t quarkus/observability-jvm .
+#
+# Then run the container using:
+#
+# docker run -i --rm -p 8080:8080 quarkus/observability-jvm
+#
+# If you want to include the debug port into your docker image
+# you will have to expose the debug port (default 5005 being the default) like 
this :  EXPOSE 8080 5005.
+# Additionally you will have to set -e JAVA_DEBUG=true and -e 
JAVA_DEBUG_PORT=*:5005
+# when running the container
+#
+# Then run the container using :
+#
+# docker run -i --rm -p 8080:8080 quarkus/observability-jvm
+#
+# This image uses the `run-java.sh` script to run the application.
+# This scripts computes the command line to execute your Java application, and
+# includes memory/GC tuning.
+# You can configure the behavior using the following environment properties:
+# - JAVA_OPTS: JVM options passed to the `java` command (example: 
"-verbose:class") - Be aware that this will override
+# the default JVM options, use `JAVA_OPTS_APPEND` to append options
+# - JAVA_OPTS_APPEND: User specified Java options to be appended to generated 
options
+#   in JAVA_OPTS (example: "-Dsome.property=foo")
+# - JAVA_MAX_MEM_RATIO: Is used when no `-Xmx` option is given in JAVA_OPTS. 
This is
+#   used to calculate a default maximal heap memory based on a containers 
restriction.
+#   If used in a container without any memory constraints for the container 
then this
+#   option has no effect. If there is a memory constraint then `-Xmx` is set 
to a ratio
+#   of the container available memory as set here. The default is `50` which 
means 50%
+#   of the available memory is used as an upper boundary. You can skip this 
mechanism by
+#   setting this value to `0` in which case no `-Xmx` option is added.
+# - JAVA_INITIAL_MEM_RATIO: Is used when no `-Xms` option is given in 
JAVA_OPTS. This
+#   is used to calculate a default initial heap memory based on the maximum 
heap memory.
+#   If used in a container without any memory constraints for the container 
then this
+#   option has no effect. If there is a memory constraint then `-Xms` is set 
to a ratio
+#   of the `-Xmx` memory as set here. The default is `25` which means 25% of 
the `-Xmx`
+#   is used as the initial heap size. You can skip this mechanism by setting 
this value
+#   to `0` in which case no `-Xms` option is added (example: "25")
+# - JAVA_MAX_INITIAL_MEM: Is used when no `-Xms` option is given in JAVA_OPTS.
+#   This is used to calculate the maximum value of the initial heap memory. If 
used in
+#   a container without any memory constraints for the container then this 
option has
+#   no effect. If there is a memory constraint then `-Xms` is limited to the 
value set
+#   here. The default is 4096MB which means the calculated value of `-Xms` 
never will
+#   be greater than 4096MB. The value of this variable is expressed in MB 
(example: "4096")
+# - JAVA_DIAGNOSTICS: Set this to get some diagnostics information to standard 
output
+#   when things are happening. This option, if set to true, will set
+#  `-XX:+UnlockDiagnosticVMOptions`. Disabled by default (example: "true").
+# - JAVA_DEBUG: If set remote debugging will be switched on. Disabled by 
default (example:
+#    true").
+# - JAVA_DEBUG_PORT: Port used for remote debugging. Defaults to 5005 
(example: "8787").
+# - CONTAINER_CORE_LIMIT: A calculated core limit as described in
+#   https://www.kernel.org/doc/Documentation/scheduler/sched-bwc.txt. 
(example: "2")
+# - CONTAINER_MAX_MEMORY: Memory limit given to the container (example: 
"1024").
+# - GC_MIN_HEAP_FREE_RATIO: Minimum percentage of heap free after GC to avoid 
expansion.
+#   (example: "20")
+# - GC_MAX_HEAP_FREE_RATIO: Maximum percentage of heap free after GC to avoid 
shrinking.
+#   (example: "40")
+# - GC_TIME_RATIO: Specifies the ratio of the time spent outside the garbage 
collection.
+#   (example: "4")
+# - GC_ADAPTIVE_SIZE_POLICY_WEIGHT: The weighting given to the current GC time 
versus
+#   previous GC times. (example: "90")
+# - GC_METASPACE_SIZE: The initial metaspace size. (example: "20")
+# - GC_MAX_METASPACE_SIZE: The maximum metaspace size. (example: "100")
+# - GC_CONTAINER_OPTIONS: Specify Java GC to use. The value of this variable 
should
+#   contain the necessary JRE command-line options to specify the required GC, 
which
+#   will override the default of `-XX:+UseParallelGC` (example: -XX:+UseG1GC).
+# - HTTPS_PROXY: The location of the https proxy. (example: 
"[email protected]:8080")
+# - HTTP_PROXY: The location of the http proxy. (example: 
"[email protected]:8080")
+# - NO_PROXY: A comma separated lists of hosts, IP addresses or domains that 
can be
+#   accessed directly. (example: "foo.example.com,bar.example.com")
+#
+# You can find more information about the UBI base runtime images and their 
configuration here:
+# https://rh-openjdk.github.io/redhat-openjdk-containers/
+###
+FROM registry.access.redhat.com/ubi9/openjdk-21-runtime:1.24
+
+ENV LANGUAGE='en_US:en'
+
+
+# We make four distinct layers so if there are application changes the library 
layers can be re-used
+COPY --chown=185 target/quarkus-app/lib/ /deployments/lib/
+COPY --chown=185 target/quarkus-app/*.jar /deployments/
+COPY --chown=185 target/quarkus-app/app/ /deployments/app/
+COPY --chown=185 target/quarkus-app/quarkus/ /deployments/quarkus/
+
+EXPOSE 8080
+USER 185
+ENV JAVA_OPTS_APPEND="-Dquarkus.http.host=0.0.0.0 
-Djava.util.logging.manager=org.jboss.logmanager.LogManager"
+ENV JAVA_APP_JAR="/deployments/quarkus-run.jar"
+
+ENTRYPOINT [ "/opt/jboss/container/java/run/run-java.sh" ]
+
diff --git a/observability/src/main/docker/Dockerfile.legacy-jar 
b/observability/src/main/docker/Dockerfile.legacy-jar
new file mode 100644
index 00000000..7e33b627
--- /dev/null
+++ b/observability/src/main/docker/Dockerfile.legacy-jar
@@ -0,0 +1,112 @@
+## ---------------------------------------------------------------------------
+## Licensed to the Apache Software Foundation (ASF) under one or more
+## contributor license agreements.  See the NOTICE file distributed with
+## this work for additional information regarding copyright ownership.
+## The ASF licenses this file to You under the Apache License, Version 2.0
+## (the "License"); you may not use this file except in compliance with
+## the License.  You may obtain a copy of the License at
+##
+##      http://www.apache.org/licenses/LICENSE-2.0
+##
+## Unless required by applicable law or agreed to in writing, software
+## distributed under the License is distributed on an "AS IS" BASIS,
+## WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
+## See the License for the specific language governing permissions and
+## limitations under the License.
+## ---------------------------------------------------------------------------
+####
+# This Dockerfile is used in order to build a container that runs the Quarkus 
application in JVM mode
+#
+# Before building the container image run:
+#
+# ./mvnw package -Dquarkus.package.jar.type=legacy-jar
+#
+# Then, build the image with:
+#
+# docker build -f src/main/docker/Dockerfile.legacy-jar -t 
quarkus/observability-legacy-jar .
+#
+# Then run the container using:
+#
+# docker run -i --rm -p 8080:8080 quarkus/observability-legacy-jar
+#
+# If you want to include the debug port into your docker image
+# you will have to expose the debug port (default 5005 being the default) like 
this :  EXPOSE 8080 5005.
+# Additionally you will have to set -e JAVA_DEBUG=true and -e 
JAVA_DEBUG_PORT=*:5005
+# when running the container
+#
+# Then run the container using :
+#
+# docker run -i --rm -p 8080:8080 quarkus/observability-legacy-jar
+#
+# This image uses the `run-java.sh` script to run the application.
+# This scripts computes the command line to execute your Java application, and
+# includes memory/GC tuning.
+# You can configure the behavior using the following environment properties:
+# - JAVA_OPTS: JVM options passed to the `java` command (example: 
"-verbose:class") - Be aware that this will override
+# the default JVM options, use `JAVA_OPTS_APPEND` to append options
+# - JAVA_OPTS_APPEND: User specified Java options to be appended to generated 
options
+#   in JAVA_OPTS (example: "-Dsome.property=foo")
+# - JAVA_MAX_MEM_RATIO: Is used when no `-Xmx` option is given in JAVA_OPTS. 
This is
+#   used to calculate a default maximal heap memory based on a containers 
restriction.
+#   If used in a container without any memory constraints for the container 
then this
+#   option has no effect. If there is a memory constraint then `-Xmx` is set 
to a ratio
+#   of the container available memory as set here. The default is `50` which 
means 50%
+#   of the available memory is used as an upper boundary. You can skip this 
mechanism by
+#   setting this value to `0` in which case no `-Xmx` option is added.
+# - JAVA_INITIAL_MEM_RATIO: Is used when no `-Xms` option is given in 
JAVA_OPTS. This
+#   is used to calculate a default initial heap memory based on the maximum 
heap memory.
+#   If used in a container without any memory constraints for the container 
then this
+#   option has no effect. If there is a memory constraint then `-Xms` is set 
to a ratio
+#   of the `-Xmx` memory as set here. The default is `25` which means 25% of 
the `-Xmx`
+#   is used as the initial heap size. You can skip this mechanism by setting 
this value
+#   to `0` in which case no `-Xms` option is added (example: "25")
+# - JAVA_MAX_INITIAL_MEM: Is used when no `-Xms` option is given in JAVA_OPTS.
+#   This is used to calculate the maximum value of the initial heap memory. If 
used in
+#   a container without any memory constraints for the container then this 
option has
+#   no effect. If there is a memory constraint then `-Xms` is limited to the 
value set
+#   here. The default is 4096MB which means the calculated value of `-Xms` 
never will
+#   be greater than 4096MB. The value of this variable is expressed in MB 
(example: "4096")
+# - JAVA_DIAGNOSTICS: Set this to get some diagnostics information to standard 
output
+#   when things are happening. This option, if set to true, will set
+#  `-XX:+UnlockDiagnosticVMOptions`. Disabled by default (example: "true").
+# - JAVA_DEBUG: If set remote debugging will be switched on. Disabled by 
default (example:
+#    true").
+# - JAVA_DEBUG_PORT: Port used for remote debugging. Defaults to 5005 
(example: "8787").
+# - CONTAINER_CORE_LIMIT: A calculated core limit as described in
+#   https://www.kernel.org/doc/Documentation/scheduler/sched-bwc.txt. 
(example: "2")
+# - CONTAINER_MAX_MEMORY: Memory limit given to the container (example: 
"1024").
+# - GC_MIN_HEAP_FREE_RATIO: Minimum percentage of heap free after GC to avoid 
expansion.
+#   (example: "20")
+# - GC_MAX_HEAP_FREE_RATIO: Maximum percentage of heap free after GC to avoid 
shrinking.
+#   (example: "40")
+# - GC_TIME_RATIO: Specifies the ratio of the time spent outside the garbage 
collection.
+#   (example: "4")
+# - GC_ADAPTIVE_SIZE_POLICY_WEIGHT: The weighting given to the current GC time 
versus
+#   previous GC times. (example: "90")
+# - GC_METASPACE_SIZE: The initial metaspace size. (example: "20")
+# - GC_MAX_METASPACE_SIZE: The maximum metaspace size. (example: "100")
+# - GC_CONTAINER_OPTIONS: Specify Java GC to use. The value of this variable 
should
+#   contain the necessary JRE command-line options to specify the required GC, 
which
+#   will override the default of `-XX:+UseParallelGC` (example: -XX:+UseG1GC).
+# - HTTPS_PROXY: The location of the https proxy. (example: 
"[email protected]:8080")
+# - HTTP_PROXY: The location of the http proxy. (example: 
"[email protected]:8080")
+# - NO_PROXY: A comma separated lists of hosts, IP addresses or domains that 
can be
+#   accessed directly. (example: "foo.example.com,bar.example.com")
+#
+# You can find more information about the UBI base runtime images and their 
configuration here:
+# https://rh-openjdk.github.io/redhat-openjdk-containers/
+###
+FROM registry.access.redhat.com/ubi9/openjdk-21-runtime:1.24
+
+ENV LANGUAGE='en_US:en'
+
+
+COPY target/lib/* /deployments/lib/
+COPY target/*-runner.jar /deployments/quarkus-run.jar
+
+EXPOSE 8080
+USER 185
+ENV JAVA_OPTS_APPEND="-Dquarkus.http.host=0.0.0.0 
-Djava.util.logging.manager=org.jboss.logmanager.LogManager"
+ENV JAVA_APP_JAR="/deployments/quarkus-run.jar"
+
+ENTRYPOINT [ "/opt/jboss/container/java/run/run-java.sh" ]
diff --git a/observability/src/main/docker/Dockerfile.native 
b/observability/src/main/docker/Dockerfile.native
new file mode 100644
index 00000000..b944e616
--- /dev/null
+++ b/observability/src/main/docker/Dockerfile.native
@@ -0,0 +1,45 @@
+## ---------------------------------------------------------------------------
+## Licensed to the Apache Software Foundation (ASF) under one or more
+## contributor license agreements.  See the NOTICE file distributed with
+## this work for additional information regarding copyright ownership.
+## The ASF licenses this file to You under the Apache License, Version 2.0
+## (the "License"); you may not use this file except in compliance with
+## the License.  You may obtain a copy of the License at
+##
+##      http://www.apache.org/licenses/LICENSE-2.0
+##
+## Unless required by applicable law or agreed to in writing, software
+## distributed under the License is distributed on an "AS IS" BASIS,
+## WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
+## See the License for the specific language governing permissions and
+## limitations under the License.
+## ---------------------------------------------------------------------------
+####
+# This Dockerfile is used in order to build a container that runs the Quarkus 
application in native (no JVM) mode.
+#
+# Before building the container image run:
+#
+# ./mvnw package -Dnative
+#
+# Then, build the image with:
+#
+# docker build -f src/main/docker/Dockerfile.native -t quarkus/observability .
+#
+# Then run the container using:
+#
+# docker run -i --rm -p 8080:8080 quarkus/observability
+#
+# The ` registry.access.redhat.com/ubi9/ubi-minimal:9.7` base image is based 
on UBI 9.
+# To use UBI 8, switch to `quay.io/ubi8/ubi-minimal:8.10`.
+###
+FROM registry.access.redhat.com/ubi9/ubi-minimal:9.7
+WORKDIR /work/
+RUN chown 1001 /work \
+    && chmod "g+rwX" /work \
+    && chown 1001:root /work
+COPY --chown=1001:root --chmod=0755 target/*-runner /work/application
+
+EXPOSE 8080
+USER 1001
+
+ENTRYPOINT ["./application", "-Dquarkus.http.host=0.0.0.0"]
diff --git a/observability/src/main/docker/Dockerfile.native-micro 
b/observability/src/main/docker/Dockerfile.native-micro
new file mode 100644
index 00000000..4c292a3a
--- /dev/null
+++ b/observability/src/main/docker/Dockerfile.native-micro
@@ -0,0 +1,48 @@
+## ---------------------------------------------------------------------------
+## Licensed to the Apache Software Foundation (ASF) under one or more
+## contributor license agreements.  See the NOTICE file distributed with
+## this work for additional information regarding copyright ownership.
+## The ASF licenses this file to You under the Apache License, Version 2.0
+## (the "License"); you may not use this file except in compliance with
+## the License.  You may obtain a copy of the License at
+##
+##      http://www.apache.org/licenses/LICENSE-2.0
+##
+## Unless required by applicable law or agreed to in writing, software
+## distributed under the License is distributed on an "AS IS" BASIS,
+## WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
+## See the License for the specific language governing permissions and
+## limitations under the License.
+## ---------------------------------------------------------------------------
+####
+# This Dockerfile is used in order to build a container that runs the Quarkus 
application in native (no JVM) mode.
+# It uses a micro base image, tuned for Quarkus native executables.
+# It reduces the size of the resulting container image.
+# Check https://quarkus.io/guides/quarkus-runtime-base-image for further 
information about this image.
+#
+# Before building the container image run:
+#
+# ./mvnw package -Dnative
+#
+# Then, build the image with:
+#
+# docker build -f src/main/docker/Dockerfile.native-micro -t 
quarkus/observability .
+#
+# Then run the container using:
+#
+# docker run -i --rm -p 8080:8080 quarkus/observability
+#
+# The `quay.io/quarkus/ubi9-quarkus-micro-image:2.0` base image is based on 
UBI 9.
+# To use UBI 8, switch to `quay.io/quarkus/quarkus-micro-image:2.0`.
+###
+FROM quay.io/quarkus/ubi9-quarkus-micro-image:2.0
+WORKDIR /work/
+RUN chown 1001 /work \
+    && chmod "g+rwX" /work \
+    && chown 1001:root /work
+COPY --chown=1001:root --chmod=0755 target/*-runner /work/application
+
+EXPOSE 8080
+USER 1001
+
+ENTRYPOINT ["./application", "-Dquarkus.http.host=0.0.0.0"]

Reply via email to