From 3c47bb4ec4f45440e48c918b99c231284613335d Mon Sep 17 00:00:00 2001 From: Lahiru Madushanka Date: Thu, 25 Jul 2024 11:42:59 +0530 Subject: [PATCH] Add RockyLinux images for MI 4.0.0 Add RockyLinux images for MI 4.0.0 --- dockerfiles/alpine/mi-dashboard/Dockerfile | 2 +- .../alpine/micro-integrator/Dockerfile | 2 +- .../alpine/streaming-integrator/Dockerfile | 2 +- dockerfiles/rocky/mi-dashboard/Dockerfile | 128 ++++++++++++++++++ dockerfiles/rocky/mi-dashboard/README.md | 66 +++++++++ .../rocky/mi-dashboard/docker-entrypoint.sh | 33 +++++ dockerfiles/rocky/micro-integrator/Dockerfile | 128 ++++++++++++++++++ dockerfiles/rocky/micro-integrator/README.md | 64 +++++++++ .../micro-integrator/docker-entrypoint.sh | 33 +++++ .../rocky/streaming-integrator/Dockerfile | 128 ++++++++++++++++++ .../rocky/streaming-integrator/Readme.md | 65 +++++++++ .../streaming-integrator/docker-entrypoint.sh | 37 +++++ dockerfiles/ubuntu/mi-dashboard/Dockerfile | 2 +- .../ubuntu/micro-integrator/Dockerfile | 2 +- .../ubuntu/streaming-integrator/Dockerfile | 2 +- 15 files changed, 688 insertions(+), 6 deletions(-) create mode 100644 dockerfiles/rocky/mi-dashboard/Dockerfile create mode 100644 dockerfiles/rocky/mi-dashboard/README.md create mode 100755 dockerfiles/rocky/mi-dashboard/docker-entrypoint.sh create mode 100644 dockerfiles/rocky/micro-integrator/Dockerfile create mode 100644 dockerfiles/rocky/micro-integrator/README.md create mode 100755 dockerfiles/rocky/micro-integrator/docker-entrypoint.sh create mode 100644 dockerfiles/rocky/streaming-integrator/Dockerfile create mode 100644 dockerfiles/rocky/streaming-integrator/Readme.md create mode 100755 dockerfiles/rocky/streaming-integrator/docker-entrypoint.sh diff --git a/dockerfiles/alpine/mi-dashboard/Dockerfile b/dockerfiles/alpine/mi-dashboard/Dockerfile index 1d09d4ff..8de93ea7 100755 --- a/dockerfiles/alpine/mi-dashboard/Dockerfile +++ b/dockerfiles/alpine/mi-dashboard/Dockerfile @@ -61,7 +61,7 @@ RUN echo Verifying install ... \ && echo Complete. LABEL maintainer="WSO2 Docker Maintainers " \ - com.wso2.docker.source="https://github.com/wso2/docker-ei/releases/tag/v4.0.0.6" + com.wso2.docker.source="https://github.com/wso2/docker-ei/releases/tag/v4.0.0.7" # set Docker image build arguments # build arguments for user/group configurations diff --git a/dockerfiles/alpine/micro-integrator/Dockerfile b/dockerfiles/alpine/micro-integrator/Dockerfile index 57349c23..18cb5080 100755 --- a/dockerfiles/alpine/micro-integrator/Dockerfile +++ b/dockerfiles/alpine/micro-integrator/Dockerfile @@ -61,7 +61,7 @@ RUN echo Verifying install ... \ && echo Complete. LABEL maintainer="WSO2 Docker Maintainers " \ - com.wso2.docker.source="https://github.com/wso2/docker-ei/releases/tag/v4.0.0.6" + com.wso2.docker.source="https://github.com/wso2/docker-ei/releases/tag/v4.0.0.7" # set Docker image build arguments # build arguments for user/group configurations diff --git a/dockerfiles/alpine/streaming-integrator/Dockerfile b/dockerfiles/alpine/streaming-integrator/Dockerfile index aed8765f..2f4df05d 100644 --- a/dockerfiles/alpine/streaming-integrator/Dockerfile +++ b/dockerfiles/alpine/streaming-integrator/Dockerfile @@ -61,7 +61,7 @@ RUN echo Verifying install ... \ && echo Complete. LABEL maintainer="WSO2 Docker Maintainers " \ - com.wso2.docker.source="https://github.com/wso2/docker-ei/releases/tag/v4.0.0.6" + com.wso2.docker.source="https://github.com/wso2/docker-ei/releases/tag/v4.0.0.7" # set Docker image build arguments # build arguments for user/group configurations diff --git a/dockerfiles/rocky/mi-dashboard/Dockerfile b/dockerfiles/rocky/mi-dashboard/Dockerfile new file mode 100644 index 00000000..93e4a132 --- /dev/null +++ b/dockerfiles/rocky/mi-dashboard/Dockerfile @@ -0,0 +1,128 @@ +# ------------------------------------------------------------------------ +# +# Copyright 2024 WSO2, LLC. (http://wso2.com) +# +# Licensed 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 +# +# ------------------------------------------------------------------------ + +# set base Docker image to RockyLinux Docker image +FROM rockylinux/rockylinux:8.10 + +ENV LANG='en_US.UTF-8' LANGUAGE='en_US:en' LC_ALL='en_US.UTF-8' + +# install JDK Dependencies +RUN yum install -y tzdata openssl ca-certificates fontconfig gzip tar \ + && yum clean all + +ENV JAVA_VERSION jdk-11.0.14+9 + +# install OpenJDK 11 +RUN set -eux; \ + ARCH="$(objdump="$(command -v objdump)" && objdump --file-headers "$objdump" | awk -F '[:,]+[[:space:]]+' '$1 == "architecture" { print $2 }')"; \ + case "${ARCH}" in \ + aarch64|arm64) \ + ESUM='0ba188a2a739733163cd0049344429d2284867e04ca452879be24f3b54320c9a'; \ + BINARY_URL='https://github.com/adoptium/temurin11-binaries/releases/download/jdk-11.0.14%2B9/OpenJDK11U-jdk_aarch64_linux_hotspot_11.0.14_9.tar.gz'; \ + ;; \ + ppc64el|powerpc:common64) \ + ESUM='91c63331faba8c842aef312d415b3e67aecf4f662a36c275f5cb278f7bce1410'; \ + BINARY_URL='https://github.com/adoptium/temurin11-binaries/releases/download/jdk-11.0.14%2B9/OpenJDK11U-jdk_ppc64le_linux_hotspot_11.0.14_9.tar.gz'; \ + ;; \ + amd64|i386:x86-64) \ + ESUM='1189bee178d11402a690edf3fbba0c9f2ada1d3a36ff78929d81935842ef24a9'; \ + BINARY_URL='https://github.com/adoptium/temurin11-binaries/releases/download/jdk-11.0.14%2B9/OpenJDK11U-jdk_x64_linux_hotspot_11.0.14_9.tar.gz'; \ + ;; \ + *) \ + echo "Unsupported arch: ${ARCH}"; \ + exit 1; \ + ;; \ + esac; \ + curl -LfsSo /tmp/openjdk.tar.gz ${BINARY_URL}; \ + echo "${ESUM} */tmp/openjdk.tar.gz" | sha256sum -c -; \ + mkdir -p /opt/java/openjdk; \ + cd /opt/java/openjdk; \ + tar -xf /tmp/openjdk.tar.gz --strip-components=1; \ + rm -rf /tmp/openjdk.tar.gz; + +ENV JAVA_HOME=/opt/java/openjdk \ + PATH="/opt/java/openjdk/bin:$PATH" + +# Verify Java installation +RUN echo Verifying install ... \ + && echo javac --version && javac --version \ + && echo java --version && java --version \ + && echo Complete. + +LABEL maintainer="WSO2 Docker Maintainers " \ + com.wso2.docker.source="https://github.com/wso2/docker-ei/releases/tag/v4.0.0.7" + +# set Docker image build arguments +# build arguments for user/group configurations +ARG USER=wso2carbon +ARG USER_ID=802 +ARG USER_GROUP=wso2 +ARG USER_GROUP_ID=802 +ARG USER_HOME=/home/${USER} +# build arguments for WSO2 product installation +ARG WSO2_SERVER_NAME=wso2mi-dashboard +ARG WSO2_SERVER_VERSION=4.0.0 +ARG WSO2_SERVER_REPOSITORY=micro-integrator +ARG WSO2_SERVER=${WSO2_SERVER_NAME}-${WSO2_SERVER_VERSION} +ARG WSO2_SERVER_HOME=${USER_HOME}/${WSO2_SERVER} +ARG WSO2_SERVER_DIST_URL=https://github.com/wso2/${WSO2_SERVER_REPOSITORY}/releases/download/v${WSO2_SERVER_VERSION}/${WSO2_SERVER}.zip +# build argument for MOTD +ARG MOTD="\n\ +Welcome to WSO2 Docker resources.\n\ +------------------------------------ \n\ +This Docker container comprises of a WSO2 product, running with its latest GA release \n\ +which is under the Apache License, Version 2.0. \n\ +Read more about Apache License, Version 2.0 here @ http://www.apache.org/licenses/LICENSE-2.0.\n" + +# create the non-root user and group and set MOTD login message +RUN \ + groupadd --system -g ${USER_GROUP_ID} ${USER_GROUP} \ + && useradd --system --create-home --home-dir ${USER_HOME} --no-log-init -g ${USER_GROUP_ID} -u ${USER_ID} ${USER} \ + && echo '[ ! -z "${TERM}" -a -r /etc/motd ] && cat /etc/motd' >> /etc/bash.bashrc; echo "${MOTD}" > /etc/motd + +# copy init script to user home +COPY --chown=wso2carbon:wso2 docker-entrypoint.sh ${USER_HOME}/ +# install required packages +RUN \ + yum -y update \ + && yum install -y \ + nc \ + unzip \ + wget \ + && rm -rf /var/cache/yum/* + +# add the WSO2 product distribution to user's home directory +RUN \ + wget -O ${WSO2_SERVER}.zip "${WSO2_SERVER_DIST_URL}" \ + && unzip -d ${USER_HOME} ${WSO2_SERVER}.zip \ + && rm -f ${WSO2_SERVER}.zip \ + && chown wso2carbon:wso2 -R ${WSO2_SERVER_HOME} + +# set the user and work directory +USER ${USER_ID} +WORKDIR ${USER_HOME} + +# set environment variables +ENV WORKING_DIRECTORY=${USER_HOME} \ + WSO2_SERVER_HOME=${WSO2_SERVER_HOME} + +# expose server ports +EXPOSE 9743 + +# initiate container and start WSO2 Carbon server +ENTRYPOINT ["/home/wso2carbon/docker-entrypoint.sh"] diff --git a/dockerfiles/rocky/mi-dashboard/README.md b/dockerfiles/rocky/mi-dashboard/README.md new file mode 100644 index 00000000..3667a4e2 --- /dev/null +++ b/dockerfiles/rocky/mi-dashboard/README.md @@ -0,0 +1,66 @@ +# Dockerfile for WSO2 Micro Integrator Dashboard + +This section defines the step-by-step instructions to build an [RockyLinux](https://hub.docker.com/_/rockylinux) Linux based Docker image for WSO2 Micro Integrator Dashboard 4.0.0. + +## Prerequisites + +* [Docker](https://www.docker.com/get-docker) v17.09.0 or above +* [Git](https://git-scm.com/book/en/v2/Getting-Started-Installing-Git) client + +## How to build an image and run + +##### 1. Checkout this repository into your local machine using the following Git client command. + +``` +git clone https://github.com/wso2/docker-ei.git +``` + +>The local copy of the `dockerfiles/rocky/monitoring-dashboard` directory will be referred to as `MONITORING_DASHBOARD_DOCKERFILE_HOME` from this point onwards. + +##### 2. Build the Docker image. + +- Navigate to `` directory.
+ Execute `docker build` command as shown below. + + `docker build -t wso2mi-dashboard:4.0.0-rocky .` + +> By default, the Docker image will prepackage the General Availability (GA) release version of the relevant WSO2 product. + +##### 3. Running the Docker image. + +- `docker run -p 9743:9743 -p 8290:8290 wso2mi-dashboard:4.0.0-rocky` + +## How to update configurations + +Configurations would lie on the Docker host machine and they can be volume mounted to the container.
+As an example, steps required to change the port offset using `deployment.toml` is as follows: + +##### 1. Stop the MI container if it's already running. + +In WSO2 Micro Integrator Monitoring Dashboard 4.0.0 product distribution, `deployment.toml` configuration file can be + found at `/conf/server`.
+Copy the file to some suitable location of the host machine, referred to as `/deployment.toml` and change the
+offset value (`[server]->offset`) to 11. + +##### 2. Grant read permission to `other` users for `/deployment.toml`. + +``` +chmod o+r /deployment.toml +``` + +##### 3. Run the image by mounting the file to container as follows: + +``` +docker run \ +-p 9744:9744 \ +--volume /deployment.toml:/deployment.toml \ +wso2mi-dashboard:4.0.0-rocky +``` + +> In here, refers to /home/wso2carbon/wso2mi-dashboard-4.0.0/conf/server folder of the +> container. + +## Docker command usage references + +* [Docker build command reference](https://docs.docker.com/engine/reference/commandline/build/) +* [Docker run command reference](https://docs.docker.com/engine/reference/run/) +* [Dockerfile reference](https://docs.docker.com/engine/reference/builder/) diff --git a/dockerfiles/rocky/mi-dashboard/docker-entrypoint.sh b/dockerfiles/rocky/mi-dashboard/docker-entrypoint.sh new file mode 100755 index 00000000..dbb53b4d --- /dev/null +++ b/dockerfiles/rocky/mi-dashboard/docker-entrypoint.sh @@ -0,0 +1,33 @@ +#!/bin/bash +# ------------------------------------------------------------------------ +# Copyright 2024 WSO2, LLC. (http://wso2.com) +# +# Licensed 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 +# ------------------------------------------------------------------------ + +set -e + +# volume mount +config_volume=${WORKING_DIRECTORY}/wso2-config-volume + +# check if the WSO2 non-root user home exists +test ! -d ${WORKING_DIRECTORY} && echo "WSO2 Docker non-root user home does not exist" && exit 1 + +# check if the WSO2 product home exists +test ! -d ${WSO2_SERVER_HOME} && echo "WSO2 Docker product home does not exist" && exit 1 + +# copy any configuration changes mounted to config_volume +test -d ${config_volume} && [[ "$(ls -A ${config_volume})" ]] && cp -RL ${config_volume}/* ${WSO2_SERVER_HOME}/ + +# start WSO2 server +sh ${WSO2_SERVER_HOME}/bin/dashboard.sh "$@" diff --git a/dockerfiles/rocky/micro-integrator/Dockerfile b/dockerfiles/rocky/micro-integrator/Dockerfile new file mode 100644 index 00000000..885b928c --- /dev/null +++ b/dockerfiles/rocky/micro-integrator/Dockerfile @@ -0,0 +1,128 @@ +# ------------------------------------------------------------------------ +# +# Copyright 2024 WSO2, LLC. (http://wso2.com) +# +# Licensed 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 +# +# ------------------------------------------------------------------------ + +# set base Docker image to RockyLinux Docker image +FROM rockylinux/rockylinux:8.10 + +ENV LANG='en_US.UTF-8' LANGUAGE='en_US:en' LC_ALL='en_US.UTF-8' + +# install JDK Dependencies +RUN yum install -y tzdata openssl ca-certificates fontconfig gzip tar \ + && yum clean all + +ENV JAVA_VERSION jdk-11.0.21+9 + +# install OpenJDK 11 +RUN set -eux; \ + ARCH="$(objdump="$(command -v objdump)" && objdump --file-headers "$objdump" | awk -F '[:,]+[[:space:]]+' '$1 == "architecture" { print $2 }')"; \ + case "${ARCH}" in \ + aarch64|arm64) \ + ESUM='8c3146035b99c55ab26a2982f4b9abd2bf600582361cf9c732539f713d271faf'; \ + BINARY_URL='https://github.com/adoptium/temurin11-binaries/releases/download/jdk-11.0.21%2B9/OpenJDK11U-jdk_aarch64_linux_hotspot_11.0.21_9.tar.gz'; \ + ;; \ + ppc64el|powerpc:common64) \ + ESUM='262ff98d6d88a7c7cc522cb4ec4129491a0eb04f5b17dcca0da57cfcdcf3830d'; \ + BINARY_URL='https://github.com/adoptium/temurin11-binaries/releases/download/jdk-11.0.21%2B9/OpenJDK11U-jdk_ppc64le_linux_hotspot_11.0.21_9.tar.gz'; \ + ;; \ + amd64|i386:x86-64) \ + ESUM='60ea98daa09834fdd3162ca91ddc8d92a155ab3121204f6f643176ee0c2d0d5e'; \ + BINARY_URL='https://github.com/adoptium/temurin11-binaries/releases/download/jdk-11.0.21%2B9/OpenJDK11U-jdk_x64_linux_hotspot_11.0.21_9.tar.gz'; \ + ;; \ + *) \ + echo "Unsupported arch: ${ARCH}"; \ + exit 1; \ + ;; \ + esac; \ + curl -LfsSo /tmp/openjdk.tar.gz ${BINARY_URL}; \ + echo "${ESUM} */tmp/openjdk.tar.gz" | sha256sum -c -; \ + mkdir -p /opt/java/openjdk; \ + cd /opt/java/openjdk; \ + tar -xf /tmp/openjdk.tar.gz --strip-components=1; \ + rm -rf /tmp/openjdk.tar.gz; + +ENV JAVA_HOME=/opt/java/openjdk \ + PATH="/opt/java/openjdk/bin:$PATH" + +# Verify Java installation +RUN echo Verifying install ... \ + && echo javac --version && javac --version \ + && echo java --version && java --version \ + && echo Complete. + +LABEL maintainer="WSO2 Docker Maintainers " \ + com.wso2.docker.source="https://github.com/wso2/docker-ei/releases/tag/v4.0.0.7" + +# set Docker image build arguments +# build arguments for user/group configurations +ARG USER=wso2carbon +ARG USER_ID=802 +ARG USER_GROUP=wso2 +ARG USER_GROUP_ID=802 +ARG USER_HOME=/home/${USER} +# build arguments for WSO2 product installation +ARG WSO2_SERVER_NAME=wso2mi +ARG WSO2_SERVER_VERSION=4.0.0 +ARG WSO2_SERVER_REPOSITORY=micro-integrator +ARG WSO2_SERVER=${WSO2_SERVER_NAME}-${WSO2_SERVER_VERSION} +ARG WSO2_SERVER_HOME=${USER_HOME}/${WSO2_SERVER} +ARG WSO2_SERVER_DIST_URL=https://github.com/wso2/${WSO2_SERVER_REPOSITORY}/releases/download/v${WSO2_SERVER_VERSION}/${WSO2_SERVER}.zip +# build argument for MOTD +ARG MOTD="\n\ +Welcome to WSO2 Docker resources.\n\ +------------------------------------ \n\ +This Docker container comprises of a WSO2 product, running with its latest GA release \n\ +which is under the Apache License, Version 2.0. \n\ +Read more about Apache License, Version 2.0 here @ http://www.apache.org/licenses/LICENSE-2.0.\n" + +# create the non-root user and group and set MOTD login message +RUN \ + groupadd --system -g ${USER_GROUP_ID} ${USER_GROUP} \ + && useradd --system --create-home --home-dir ${USER_HOME} --no-log-init -g ${USER_GROUP_ID} -u ${USER_ID} ${USER} \ + && echo '[ ! -z "${TERM}" -a -r /etc/motd ] && cat /etc/motd' >> /etc/bash.bashrc; echo "${MOTD}" > /etc/motd + +# copy init script to user home +COPY --chown=wso2carbon:wso2 docker-entrypoint.sh ${USER_HOME}/ +# install required packages +RUN \ + yum -y update \ + && yum install -y \ + nc \ + unzip \ + wget \ + && rm -rf /var/cache/yum/* + +# add the WSO2 product distribution to user's home directory +RUN \ + wget -O ${WSO2_SERVER}.zip "${WSO2_SERVER_DIST_URL}" \ + && unzip -d ${USER_HOME} ${WSO2_SERVER}.zip \ + && rm -f ${WSO2_SERVER}.zip \ + && chown wso2carbon:wso2 -R ${WSO2_SERVER_HOME} + +# set the user and work directory +USER ${USER_ID} +WORKDIR ${USER_HOME} + +# set environment variables +ENV WORKING_DIRECTORY=${USER_HOME} \ + WSO2_SERVER_HOME=${WSO2_SERVER_HOME} + +# expose server ports +EXPOSE 8290 8253 + +# initiate container and start WSO2 Carbon server +ENTRYPOINT ["/home/wso2carbon/docker-entrypoint.sh"] diff --git a/dockerfiles/rocky/micro-integrator/README.md b/dockerfiles/rocky/micro-integrator/README.md new file mode 100644 index 00000000..34bbdda6 --- /dev/null +++ b/dockerfiles/rocky/micro-integrator/README.md @@ -0,0 +1,64 @@ +# Dockerfile for WSO2 Micro Integrator + +This section defines the step-by-step instructions to build an [RockyLinux](https://hub.docker.com/_/rockylinux) based Docker image for WSO2 Micro Integrator 4.0.0. + +## Prerequisites + +* [Docker](https://www.docker.com/get-docker) v17.09.0 or above +* [Git](https://git-scm.com/book/en/v2/Getting-Started-Installing-Git) client + +## How to build an image and run + +##### 1. Checkout this repository into your local machine using the following Git client command. + +``` +git clone https://github.com/wso2/docker-ei.git +``` + +>The local copy of the `dockerfiles/rocky/micro-integrator` directory will be referred to as `MI_DOCKERFILE_HOME` from this point onwards. + +##### 2. Build the Docker image. + +- Navigate to `` directory.
+ Execute `docker build` command as shown below. + + `docker build -t wso2mi:4.0.0-rocky .` + +> By default, the Docker image will prepackage the General Availability (GA) release version of the relevant WSO2 product. + +##### 3. Running the Docker image. + +- `docker run -p 8253:8253 -p 8290:8290 wso2mi:4.0.0-rocky` + +## How to update configurations + +Configurations would lie on the Docker host machine and they can be volume mounted to the container.
+As an example, steps required to change the port offset using `deployment.toml` is as follows: + +##### 1. Stop the MI container if it's already running. + +In WSO2 MI 4.0.0 product distribution, `deployment.toml` configuration file can be found at `/conf`.
+Copy the file to some suitable location of the host machine, referred to as `/deployment.toml` and change the
+offset value (`[server]->offset`) to 11. + +##### 2. Grant read permission to `other` users for `/deployment.toml`. + +``` +chmod o+r /deployment.toml +``` + +##### 3. Run the image by mounting the file to container as follows: + +``` +docker run \ +-p 8254:8254 \ +--volume /deployment.toml:/deployment.toml \ +wso2mi:4.0.0-rocky +``` + +> In here, refers to /home/wso2carbon/wso2mi-4.0.0/conf folder of the container. + +## Docker command usage references + +* [Docker build command reference](https://docs.docker.com/engine/reference/commandline/build/) +* [Docker run command reference](https://docs.docker.com/engine/reference/run/) +* [Dockerfile reference](https://docs.docker.com/engine/reference/builder/) diff --git a/dockerfiles/rocky/micro-integrator/docker-entrypoint.sh b/dockerfiles/rocky/micro-integrator/docker-entrypoint.sh new file mode 100755 index 00000000..41bb79d4 --- /dev/null +++ b/dockerfiles/rocky/micro-integrator/docker-entrypoint.sh @@ -0,0 +1,33 @@ +#!/bin/bash +# ------------------------------------------------------------------------ +# Copyright 2024 WSO2, LLC. (http://wso2.com) +# +# Licensed 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 +# ------------------------------------------------------------------------ + +set -e + +# volume mount +config_volume=${WORKING_DIRECTORY}/wso2-config-volume + +# check if the WSO2 non-root user home exists +test ! -d ${WORKING_DIRECTORY} && echo "WSO2 Docker non-root user home does not exist" && exit 1 + +# check if the WSO2 product home exists +test ! -d ${WSO2_SERVER_HOME} && echo "WSO2 Docker product home does not exist" && exit 1 + +# copy any configuration changes mounted to config_volume +test -d ${config_volume} && [[ "$(ls -A ${config_volume})" ]] && cp -RL ${config_volume}/* ${WSO2_SERVER_HOME}/ + +# start WSO2 server +sh ${WSO2_SERVER_HOME}/bin/micro-integrator.sh "$@" diff --git a/dockerfiles/rocky/streaming-integrator/Dockerfile b/dockerfiles/rocky/streaming-integrator/Dockerfile new file mode 100644 index 00000000..496bf885 --- /dev/null +++ b/dockerfiles/rocky/streaming-integrator/Dockerfile @@ -0,0 +1,128 @@ +# ------------------------------------------------------------------------ +# +# Copyright 2024 WSO2, LLC. (http://wso2.com) +# +# Licensed 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 +# +# ------------------------------------------------------------------------ + +# set base Docker image to RockyLinux Docker image +FROM rockylinux/rockylinux:8.10 + +ENV LANG='en_US.UTF-8' LANGUAGE='en_US:en' LC_ALL='en_US.UTF-8' + +# install JDK Dependencies +RUN yum install -y tzdata openssl ca-certificates fontconfig gzip tar \ + && yum clean all + +ENV JAVA_VERSION jdk-11.0.14+9 + +# install OpenJDK 11 +RUN set -eux; \ + ARCH="$(objdump="$(command -v objdump)" && objdump --file-headers "$objdump" | awk -F '[:,]+[[:space:]]+' '$1 == "architecture" { print $2 }')"; \ + case "${ARCH}" in \ + aarch64|arm64) \ + ESUM='0ba188a2a739733163cd0049344429d2284867e04ca452879be24f3b54320c9a'; \ + BINARY_URL='https://github.com/adoptium/temurin11-binaries/releases/download/jdk-11.0.14%2B9/OpenJDK11U-jdk_aarch64_linux_hotspot_11.0.14_9.tar.gz'; \ + ;; \ + ppc64el|powerpc:common64) \ + ESUM='91c63331faba8c842aef312d415b3e67aecf4f662a36c275f5cb278f7bce1410'; \ + BINARY_URL='https://github.com/adoptium/temurin11-binaries/releases/download/jdk-11.0.14%2B9/OpenJDK11U-jdk_ppc64le_linux_hotspot_11.0.14_9.tar.gz'; \ + ;; \ + amd64|i386:x86-64) \ + ESUM='1189bee178d11402a690edf3fbba0c9f2ada1d3a36ff78929d81935842ef24a9'; \ + BINARY_URL='https://github.com/adoptium/temurin11-binaries/releases/download/jdk-11.0.14%2B9/OpenJDK11U-jdk_x64_linux_hotspot_11.0.14_9.tar.gz'; \ + ;; \ + *) \ + echo "Unsupported arch: ${ARCH}"; \ + exit 1; \ + ;; \ + esac; \ + curl -LfsSo /tmp/openjdk.tar.gz ${BINARY_URL}; \ + echo "${ESUM} */tmp/openjdk.tar.gz" | sha256sum -c -; \ + mkdir -p /opt/java/openjdk; \ + cd /opt/java/openjdk; \ + tar -xf /tmp/openjdk.tar.gz --strip-components=1; \ + rm -rf /tmp/openjdk.tar.gz; + +ENV JAVA_HOME=/opt/java/openjdk \ + PATH="/opt/java/openjdk/bin:$PATH" + +# Verify Java installation +RUN echo Verifying install ... \ + && echo javac --version && javac --version \ + && echo java --version && java --version \ + && echo Complete. + +LABEL maintainer="WSO2 Docker Maintainers " \ + com.wso2.docker.source="https://github.com/wso2/docker-ei/releases/tag/v4.0.0.7" + +# set Docker image build arguments +# build arguments for user/group configurations +ARG USER=wso2carbon +ARG USER_ID=802 +ARG USER_GROUP=wso2 +ARG USER_GROUP_ID=802 +ARG USER_HOME=/home/${USER} +# build arguments for WSO2 product installation +ARG WSO2_SERVER_NAME=wso2si +ARG WSO2_SERVER_VERSION=4.0.0 +ARG WSO2_SERVER_REPOSITORY=streaming-integrator +ARG WSO2_SERVER=${WSO2_SERVER_NAME}-${WSO2_SERVER_VERSION} +ARG WSO2_SERVER_HOME=${USER_HOME}/${WSO2_SERVER} +ARG WSO2_SERVER_DIST_URL=https://github.com/wso2/${WSO2_SERVER_REPOSITORY}/releases/download/v${WSO2_SERVER_VERSION}/${WSO2_SERVER}.zip +# build argument for MOTD +ARG MOTD="\n\ +Welcome to WSO2 Docker resources.\n\ +------------------------------------ \n\ +This Docker container comprises of a WSO2 product, running with its latest GA release \n\ +which is under the Apache License, Version 2.0. \n\ +Read more about Apache License, Version 2.0 here @ http://www.apache.org/licenses/LICENSE-2.0.\n" + +# create the non-root user and group and set MOTD login message +RUN \ + groupadd --system -g ${USER_GROUP_ID} ${USER_GROUP} \ + && useradd --system --create-home --home-dir ${USER_HOME} --no-log-init -g ${USER_GROUP_ID} -u ${USER_ID} ${USER} \ + && echo '[ ! -z "${TERM}" -a -r /etc/motd ] && cat /etc/motd' >> /etc/bash.bashrc; echo "${MOTD}" > /etc/motd + +# copy init script to user home +COPY --chown=wso2carbon:wso2 docker-entrypoint.sh ${USER_HOME}/ +# install required packages +RUN \ + yum -y update \ + && yum install -y \ + nc \ + unzip \ + wget \ + && rm -rf /var/cache/yum/* + +# add the WSO2 product distribution to user's home directory +RUN \ + wget -O ${WSO2_SERVER}.zip "${WSO2_SERVER_DIST_URL}" \ + && unzip -d ${USER_HOME} ${WSO2_SERVER}.zip \ + && rm -f ${WSO2_SERVER}.zip \ + && chown wso2carbon:wso2 -R ${WSO2_SERVER_HOME} + +# set the user and work directory +USER ${USER_ID} +WORKDIR ${USER_HOME} + +# set environment variables +ENV WORKING_DIRECTORY=${USER_HOME} \ + WSO2_SERVER_HOME=${WSO2_SERVER_HOME} + +# expose server ports +EXPOSE 9711 9611 7711 7611 9090 9443 + +# initiate container and start WSO2 Carbon server +ENTRYPOINT ["/home/wso2carbon/docker-entrypoint.sh"] diff --git a/dockerfiles/rocky/streaming-integrator/Readme.md b/dockerfiles/rocky/streaming-integrator/Readme.md new file mode 100644 index 00000000..f477ea30 --- /dev/null +++ b/dockerfiles/rocky/streaming-integrator/Readme.md @@ -0,0 +1,65 @@ +# Dockerfile for WSO2 Streaming Integrator + +This section defines the step-by-step instructions to build an [RockyLinux](https://hub.docker.com/_/rockylinux) based Docker image +for WSO2 Streaming Integrator 4.0.0. + +## Prerequisites + +* [Docker](https://www.docker.com/get-docker) v17.09.0 or above +* [Git](https://git-scm.com/book/en/v2/Getting-Started-Installing-Git) client + +## How to build an image and run + +##### 1. Checkout this repository into your local machine using the following Git client command. + +``` +git clone https://github.com/wso2/docker-ei.git +``` + +>The local copy of the `dockerfiles/rocky/streaming-integrator` directory will be referred to as `SI_DOCKERFILE_HOME` from this point onwards. + +##### 2. Build the Docker image. + +- Navigate to `` directory.
+ Execute `docker build` command as shown below. + + `docker build -t wso2si:4.0.0-rocky .` + +> By default, the Docker image will prepackage the General Availability (GA) release version of the relevant WSO2 product. + +##### 3. Running the Docker image. + +- `docker run -p 9443:9443 wso2si:4.0.0-rocky` + +## How to update configurations + +Configurations would lie on the Docker host machine and they can be volume mounted to the container.
+As an example, steps required to change the port offset using `deployment.yaml` is as follows: + +##### 1. Stop the SI container if it's already running. + +In SI product distribution, `deployment.yaml` configuration file can be found at `/conf/server`. +Copy the file to some suitable location of the host machine, referred to as `/server/deployment.yaml` and +increase the offset value under ports by 1. + +##### 2. Grant read permission to `other` users for `/server/deployment.yaml`. + +``` +chmod o+r /server/deployment.yaml +``` + +##### 3. Run the image by mounting the file to container as follows: + +``` +docker run \ +-p 9443:9443 \ +--volume /server/deployment.yaml:/deployment.yaml \ +wso2si:4.0.0-rocky +``` + +>In here, refers to /home/wso2carbon/wso2si-4.0.0/conf folder of the container. + +## Docker command usage references + +* [Docker build command reference](https://docs.docker.com/engine/reference/commandline/build/) +* [Docker run command reference](https://docs.docker.com/engine/reference/run/) +* [Dockerfile reference](https://docs.docker.com/engine/refere diff --git a/dockerfiles/rocky/streaming-integrator/docker-entrypoint.sh b/dockerfiles/rocky/streaming-integrator/docker-entrypoint.sh new file mode 100755 index 00000000..2c5c929b --- /dev/null +++ b/dockerfiles/rocky/streaming-integrator/docker-entrypoint.sh @@ -0,0 +1,37 @@ +#!/bin/bash +# ------------------------------------------------------------------------ +# Copyright 2024 WSO2, LLC. (http://wso2.com) +# +# Licensed 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 +# ------------------------------------------------------------------------ + +set -e + +# volume mounts +config_volume=${WORKING_DIRECTORY}/wso2-config-volume +artifact_volume=${WORKING_DIRECTORY}/wso2-artifact-volume + +# check if the WSO2 non-root user home exists +test ! -d ${WORKING_DIRECTORY} && echo "WSO2 Docker non-root user home does not exist" && exit 1 + +# check if the WSO2 product home exists +test ! -d ${WSO2_SERVER_HOME} && echo "WSO2 Docker product home does not exist" && exit 1 + +# copy any configuration changes mounted to config_volume +test -d ${config_volume} && [[ "$(ls -A ${config_volume})" ]] && cp -RL ${config_volume}/* ${WSO2_SERVER_HOME}/ +# copy any artifact changes mounted to artifact_volume +test -d ${artifact_volume} && [[ "$(ls -A ${artifact_volume})" ]] && cp -RL ${artifact_volume}/* ${WSO2_SERVER_HOME}/ + +# start WSO2 server +sh ${WSO2_SERVER_HOME}/bin/server.sh "$@" + diff --git a/dockerfiles/ubuntu/mi-dashboard/Dockerfile b/dockerfiles/ubuntu/mi-dashboard/Dockerfile index f69e4f58..9dfaa74a 100644 --- a/dockerfiles/ubuntu/mi-dashboard/Dockerfile +++ b/dockerfiles/ubuntu/mi-dashboard/Dockerfile @@ -76,7 +76,7 @@ RUN echo Verifying install ... \ && echo Complete. LABEL maintainer="WSO2 Docker Maintainers " \ - com.wso2.docker.source="https://github.com/wso2/docker-ei/releases/tag/v4.0.0.6" + com.wso2.docker.source="https://github.com/wso2/docker-ei/releases/tag/v4.0.0.7" # set Docker image build arguments # build arguments for user/group configurations diff --git a/dockerfiles/ubuntu/micro-integrator/Dockerfile b/dockerfiles/ubuntu/micro-integrator/Dockerfile index 713d74b2..c79cf89e 100644 --- a/dockerfiles/ubuntu/micro-integrator/Dockerfile +++ b/dockerfiles/ubuntu/micro-integrator/Dockerfile @@ -76,7 +76,7 @@ RUN echo Verifying install ... \ && echo Complete. LABEL maintainer="WSO2 Docker Maintainers " \ - com.wso2.docker.source="https://github.com/wso2/docker-ei/releases/tag/v4.0.0.6" + com.wso2.docker.source="https://github.com/wso2/docker-ei/releases/tag/v4.0.0.7" # set Docker image build arguments # build arguments for user/group configurations diff --git a/dockerfiles/ubuntu/streaming-integrator/Dockerfile b/dockerfiles/ubuntu/streaming-integrator/Dockerfile index e90baebe..790c87d8 100644 --- a/dockerfiles/ubuntu/streaming-integrator/Dockerfile +++ b/dockerfiles/ubuntu/streaming-integrator/Dockerfile @@ -76,7 +76,7 @@ RUN echo Verifying install ... \ && echo Complete. LABEL maintainer="WSO2 Docker Maintainers " \ - com.wso2.docker.source="https://github.com/wso2/docker-ei/releases/tag/v4.0.0.6" + com.wso2.docker.source="https://github.com/wso2/docker-ei/releases/tag/v4.0.0.7" # set Docker image build arguments # build arguments for user/group configurations