From f6f4fd6896904504cd73d6dc1f4c1632c79f55bb Mon Sep 17 00:00:00 2001 From: Ondro Mihalyi Date: Sat, 28 Dec 2024 10:13:27 +0100 Subject: [PATCH] Custom init.sh script, master/admin passwords via ENV vars Read content.md for description --- src/main/resources/Dockerfile | 13 ++++--- src/main/resources/docker-entrypoint.sh | 21 ++++++++++++ src/main/resources/docs/content.md | 45 +++++++++++++++++++++++++ 3 files changed, 74 insertions(+), 5 deletions(-) diff --git a/src/main/resources/Dockerfile b/src/main/resources/Dockerfile index 35d8f7b..6307599 100644 --- a/src/main/resources/Dockerfile +++ b/src/main/resources/Dockerfile @@ -34,8 +34,6 @@ ENV AS_USER=${AS_ADMIN_USER} \ PATH_GF_SERVER_LOG="${PATH_GF_HOME}/glassfish/domains/domain1/logs/server.log" ENV PATH="${PATH_GF_BIN}:${PATH}" -COPY docker-entrypoint.sh /usr/local/bin/docker-entrypoint.sh - RUN true \ && set -x \ && apt update \ @@ -74,12 +72,17 @@ RUN true \ && asadmin enable-secure-admin \ && asadmin stop-domain --kill \ && rm -f ${PATH_GF_SERVER_LOG} ${PATH_GF_PASSWORD_FILE_FOR_CHANGE} \ - && chown -R glassfish:glassfish "${PATH_GF_HOME}" \ - && chmod +x /usr/local/bin/docker-entrypoint.sh \ && mkdir ${PATH_GF_HOME}/autodeploy \ + && mkdir ${PATH_GF_HOME}/custom \ + && chown -R glassfish:glassfish "${PATH_GF_HOME}" \ && echo "Installation was successful." +COPY docker-entrypoint.sh /usr/local/bin/docker-entrypoint.sh +RUN chown glassfish:glassfish /usr/local/bin/docker-entrypoint.sh \ + && chmod +x /usr/local/bin/docker-entrypoint.sh +ENTRYPOINT ["docker-entrypoint.sh"] + USER glassfish WORKDIR ${PATH_GF_HOME} -ENTRYPOINT ["docker-entrypoint.sh"] + CMD ["startserv"] diff --git a/src/main/resources/docker-entrypoint.sh b/src/main/resources/docker-entrypoint.sh index 6320ae7..2ee36b4 100755 --- a/src/main/resources/docker-entrypoint.sh +++ b/src/main/resources/docker-entrypoint.sh @@ -1,6 +1,27 @@ #!/bin/bash set -e; +change_passwords () { + local PWD_FILE=/tmp/passwordfile + if [ x${AS_ADMIN_PASSWORD} != x ]; then + echo -e "AS_ADMIN_PASSWORD=admin\nAS_ADMIN_NEWPASSWORD=${AS_ADMIN_PASSWORD}" > $PWD_FILE + asadmin change-admin-password --passwordfile=${PWD_FILE} + rm -rf ${PWD_FILE} + echo "AS_ADMIN_PASSWORD=${AS_ADMIN_PASSWORD}" > "${AS_PASSWORD_FILE}" + fi + if [ x${AS_ADMIN_MASTERPASSWORD} != x ]; then + echo -e "AS_ADMIN_MASTERPASSWORD=changeit\nAS_ADMIN_NEWMASTERPASSWORD=${AS_ADMIN_MASTERPASSWORD}" > ${PWD_FILE} + asadmin change-master-password --passwordfile=${PWD_FILE} --savemasterpassword=true + rm -rf ${PWD_FILE} + fi +} + +change_passwords + +if [ -f custom/init.sh ]; then + /bin/bash custom/init.sh +fi + if [ "$1" != 'asadmin' -a "$1" != 'startserv' -a "$1" != 'runembedded' ]; then exec "$@" fi diff --git a/src/main/resources/docs/content.md b/src/main/resources/docs/content.md index 7bbfb0e..45ee144 100644 --- a/src/main/resources/docs/content.md +++ b/src/main/resources/docs/content.md @@ -63,6 +63,51 @@ To deploy an application, copy the application into the Docker image or mount th docker run -p 8080:8080 @docker.glassfish.repository@ runembedded myapp.war ``` +## Environment variables + +The following environment variables can be set to configure GlassFish Server: + +* `AS_ADMIN_MASTERPASSWORD` - to change the default master password +* `AS_ADMIN_PASSWORD` - to change the default admin password + +The following environment variables are read-only and can be used derived Docker images or scripts: + +* `AS_PASSWORD_FILE` - path to the password file with the admin password. It's applied by default to any asadmin command +* `AS_ADMIN_USER` - name of the admin user. It's applied by default to any asadmin command +* `PATH_GF_HOME` - directory of the GlassFish installation. Also the default working directory +* `PATH_GF_SERVER_LOG` - path to the server log file + +## Additional configuration + +It's possible to specify custom commands to run before GlassFish server starts. Just create a Bash script `${PATH_GF_HOME}/custom/init.sh` (`/opt/glassfish7/custom/init.sh`), it will be executed before GlassFish server starts. + +Within the `init.sh` script, you can run any asadmin command, with `asadmin COMMAND`. Most of the commands require that the server is running, so you'll need to start the server first, run the configuration commands, and then stop the server. If you need to run multiple commands, we recomment running asadmin commands in a single "multimode" asadmin execution to run them faster, with commands provided either on standard input or in a separate file via the `asadmin -f` option. + +For example, to start GlassFish, increase the maximum amount of threads, and then stop it, the `init.sh` script can contain: + +``` +echo "start-domain +set configs.config.server-config.thread-pools.thread-pool.http-thread-pool.max-thread-pool-size=1000 +stop-domain" | asadmin +``` + +You can provide the script by mounting its directory to the `/opt/glassfish7/custom` directory in the container when running the container: + +``` +docker run -v ./custom:/opt/glassfish7/custom -p 8080:8080 -ti @docker.glassfish.repository@ +``` + +However, it's recommended running any GlassFish asadmin configuration commands in a custom Docker image, to move the configuration to the image build time instead of runtime, which requires starting and stopping GlassFish, and starting it again. + +To do it, simply add `RUN instructions that run `asadmin` script with the usual arguments. For example, to move the example configuration from the `init.sh` script above to Dockerfile: + +``` +FROM @docker.glassfish.repository@ + +RUN printf "start-domain \n \ + set configs.config.server-config.thread-pools.thread-pool.http-thread-pool.max-thread-pool-size=1000 \n \ + stop-domain" | asadmin +``` ## Run an application with GlassFish in Docker