diff --git a/Dockerfiles/server-pgsql/alpine/docker-entrypoint.sh b/Dockerfiles/server-pgsql/alpine/docker-entrypoint.sh index d3d13ca91..ba08deb16 100755 --- a/Dockerfiles/server-pgsql/alpine/docker-entrypoint.sh +++ b/Dockerfiles/server-pgsql/alpine/docker-entrypoint.sh @@ -87,16 +87,20 @@ update_config_var() { echo -n "** Updating '$config_path' parameter \"$var_name\": '$var_value'..." fi - # Remove configuration parameter definition in case of unset parameter value + # Remove configuration parameter definition in case of unset or empty parameter value if [ -z "$var_value" ]; then sed -i -e "/^$var_name=/d" "$config_path" echo "removed" return fi - # Remove value from configuration parameter in case of double quoted parameter value - if [ "$var_value" == '""' ]; then - sed -i -e "/^$var_name=/s/=.*/=/" "$config_path" + # Remove value from configuration parameter in case of set to double quoted parameter value + if [[ "$var_value" == '""' ]]; then + if [ "$(grep -E "^$var_name=" $config_path)" ]; then + sed -i -e "/^$var_name=/s/=.*/=/" "$config_path" + else + sed -i -e "/^[#;] $var_name=/s/.*/&\n$var_name=/" "$config_path" + fi echo "undefined" return fi @@ -154,12 +158,12 @@ file_process_from_env() { # Check prerequisites for PostgreSQL database check_variables_postgresql() { + : ${DB_SERVER_HOST="postgres-server"} + : ${DB_SERVER_PORT:="5432"} + file_env POSTGRES_USER file_env POSTGRES_PASSWORD - : ${DB_SERVER_HOST:="postgres-server"} - : ${DB_SERVER_PORT:="5432"} - DB_SERVER_ROOT_USER=${POSTGRES_USER:-"postgres"} DB_SERVER_ROOT_PASS=${POSTGRES_PASSWORD:-""} @@ -171,12 +175,24 @@ check_variables_postgresql() { DB_SERVER_DBNAME=${POSTGRES_DB:-"zabbix"} : ${POSTGRES_USE_IMPLICIT_SEARCH_PATH:="false"} + + if [ -n "${DB_SERVER_HOST}" ]; then + psql_connect_args="--host ${DB_SERVER_HOST} --port ${DB_SERVER_PORT}" + else + DB_SERVER_HOST='""' + psql_connect_args="--port ${DB_SERVER_PORT}" + fi } check_db_connect_postgresql() { echo "********************" - echo "* DB_SERVER_HOST: ${DB_SERVER_HOST}" - echo "* DB_SERVER_PORT: ${DB_SERVER_PORT}" + if [[ "$DB_SERVER_HOST" != '""' ]]; then + echo "* DB_SERVER_HOST: ${DB_SERVER_HOST}" + echo "* DB_SERVER_PORT: ${DB_SERVER_PORT}" + else + echo "* DB_SERVER_HOST: Using DB socket" + echo "* DB_SERVER_PORT: ${DB_SERVER_PORT}" + fi echo "* DB_SERVER_DBNAME: ${DB_SERVER_DBNAME}" echo "* DB_SERVER_SCHEMA: ${DB_SERVER_SCHEMA}" if [ "${DEBUG_MODE,,}" == "true" ]; then @@ -206,8 +222,8 @@ check_db_connect_postgresql() { while true : do - psql --host ${DB_SERVER_HOST} --port ${DB_SERVER_PORT} --username ${DB_SERVER_ROOT_USER} --list --quiet 1>/dev/null 2>&1 && break - psql --host ${DB_SERVER_HOST} --port ${DB_SERVER_PORT} --username ${DB_SERVER_ROOT_USER} --list --dbname ${DB_SERVER_DBNAME} --quiet 1>/dev/null 2>&1 && break + psql $psql_connect_args --username ${DB_SERVER_ROOT_USER} --list --quiet 1>/dev/null 2>&1 && break + psql $psql_connect_args --username ${DB_SERVER_ROOT_USER} --list --dbname ${DB_SERVER_DBNAME} --quiet 1>/dev/null 2>&1 && break echo "**** PostgreSQL server is not available. Waiting $WAIT_TIMEOUT seconds..." sleep $WAIT_TIMEOUT @@ -244,7 +260,7 @@ psql_query() { export PGSSLKEY=${ZBX_DBTLSKEYFILE} fi - result=$(psql --no-align --quiet --tuples-only --host "${DB_SERVER_HOST}" --port "${DB_SERVER_PORT}" \ + result=$(psql --no-align --quiet --tuples-only $psql_connect_args \ --username "${DB_SERVER_ROOT_USER}" --command "$query" --dbname "$db" 2>/dev/null); unset PGPASSWORD @@ -284,7 +300,7 @@ exec_sql_file() { fi $command $sql_script | psql --quiet \ - --host "${DB_SERVER_HOST}" --port "${DB_SERVER_PORT}" \ + $psql_connect_args \ --username "${DB_SERVER_ZBX_USER}" --dbname "${DB_SERVER_DBNAME}" 1>/dev/null || exit 1 unset PGPASSWORD @@ -318,7 +334,7 @@ create_db_database_postgresql() { export PGSSLKEY=${ZBX_DBTLSKEYFILE} fi - createdb --host "${DB_SERVER_HOST}" --port "${DB_SERVER_PORT}" --username "${DB_SERVER_ROOT_USER}" \ + createdb $psql_connect_args --username "${DB_SERVER_ROOT_USER}" \ --owner "${DB_SERVER_ZBX_USER}" --lc-ctype "en_US.utf8" --lc-collate "en_US.utf8" "${DB_SERVER_DBNAME}" unset PGPASSWORD diff --git a/Dockerfiles/server-pgsql/centos/docker-entrypoint.sh b/Dockerfiles/server-pgsql/centos/docker-entrypoint.sh index d3d13ca91..ba08deb16 100755 --- a/Dockerfiles/server-pgsql/centos/docker-entrypoint.sh +++ b/Dockerfiles/server-pgsql/centos/docker-entrypoint.sh @@ -87,16 +87,20 @@ update_config_var() { echo -n "** Updating '$config_path' parameter \"$var_name\": '$var_value'..." fi - # Remove configuration parameter definition in case of unset parameter value + # Remove configuration parameter definition in case of unset or empty parameter value if [ -z "$var_value" ]; then sed -i -e "/^$var_name=/d" "$config_path" echo "removed" return fi - # Remove value from configuration parameter in case of double quoted parameter value - if [ "$var_value" == '""' ]; then - sed -i -e "/^$var_name=/s/=.*/=/" "$config_path" + # Remove value from configuration parameter in case of set to double quoted parameter value + if [[ "$var_value" == '""' ]]; then + if [ "$(grep -E "^$var_name=" $config_path)" ]; then + sed -i -e "/^$var_name=/s/=.*/=/" "$config_path" + else + sed -i -e "/^[#;] $var_name=/s/.*/&\n$var_name=/" "$config_path" + fi echo "undefined" return fi @@ -154,12 +158,12 @@ file_process_from_env() { # Check prerequisites for PostgreSQL database check_variables_postgresql() { + : ${DB_SERVER_HOST="postgres-server"} + : ${DB_SERVER_PORT:="5432"} + file_env POSTGRES_USER file_env POSTGRES_PASSWORD - : ${DB_SERVER_HOST:="postgres-server"} - : ${DB_SERVER_PORT:="5432"} - DB_SERVER_ROOT_USER=${POSTGRES_USER:-"postgres"} DB_SERVER_ROOT_PASS=${POSTGRES_PASSWORD:-""} @@ -171,12 +175,24 @@ check_variables_postgresql() { DB_SERVER_DBNAME=${POSTGRES_DB:-"zabbix"} : ${POSTGRES_USE_IMPLICIT_SEARCH_PATH:="false"} + + if [ -n "${DB_SERVER_HOST}" ]; then + psql_connect_args="--host ${DB_SERVER_HOST} --port ${DB_SERVER_PORT}" + else + DB_SERVER_HOST='""' + psql_connect_args="--port ${DB_SERVER_PORT}" + fi } check_db_connect_postgresql() { echo "********************" - echo "* DB_SERVER_HOST: ${DB_SERVER_HOST}" - echo "* DB_SERVER_PORT: ${DB_SERVER_PORT}" + if [[ "$DB_SERVER_HOST" != '""' ]]; then + echo "* DB_SERVER_HOST: ${DB_SERVER_HOST}" + echo "* DB_SERVER_PORT: ${DB_SERVER_PORT}" + else + echo "* DB_SERVER_HOST: Using DB socket" + echo "* DB_SERVER_PORT: ${DB_SERVER_PORT}" + fi echo "* DB_SERVER_DBNAME: ${DB_SERVER_DBNAME}" echo "* DB_SERVER_SCHEMA: ${DB_SERVER_SCHEMA}" if [ "${DEBUG_MODE,,}" == "true" ]; then @@ -206,8 +222,8 @@ check_db_connect_postgresql() { while true : do - psql --host ${DB_SERVER_HOST} --port ${DB_SERVER_PORT} --username ${DB_SERVER_ROOT_USER} --list --quiet 1>/dev/null 2>&1 && break - psql --host ${DB_SERVER_HOST} --port ${DB_SERVER_PORT} --username ${DB_SERVER_ROOT_USER} --list --dbname ${DB_SERVER_DBNAME} --quiet 1>/dev/null 2>&1 && break + psql $psql_connect_args --username ${DB_SERVER_ROOT_USER} --list --quiet 1>/dev/null 2>&1 && break + psql $psql_connect_args --username ${DB_SERVER_ROOT_USER} --list --dbname ${DB_SERVER_DBNAME} --quiet 1>/dev/null 2>&1 && break echo "**** PostgreSQL server is not available. Waiting $WAIT_TIMEOUT seconds..." sleep $WAIT_TIMEOUT @@ -244,7 +260,7 @@ psql_query() { export PGSSLKEY=${ZBX_DBTLSKEYFILE} fi - result=$(psql --no-align --quiet --tuples-only --host "${DB_SERVER_HOST}" --port "${DB_SERVER_PORT}" \ + result=$(psql --no-align --quiet --tuples-only $psql_connect_args \ --username "${DB_SERVER_ROOT_USER}" --command "$query" --dbname "$db" 2>/dev/null); unset PGPASSWORD @@ -284,7 +300,7 @@ exec_sql_file() { fi $command $sql_script | psql --quiet \ - --host "${DB_SERVER_HOST}" --port "${DB_SERVER_PORT}" \ + $psql_connect_args \ --username "${DB_SERVER_ZBX_USER}" --dbname "${DB_SERVER_DBNAME}" 1>/dev/null || exit 1 unset PGPASSWORD @@ -318,7 +334,7 @@ create_db_database_postgresql() { export PGSSLKEY=${ZBX_DBTLSKEYFILE} fi - createdb --host "${DB_SERVER_HOST}" --port "${DB_SERVER_PORT}" --username "${DB_SERVER_ROOT_USER}" \ + createdb $psql_connect_args --username "${DB_SERVER_ROOT_USER}" \ --owner "${DB_SERVER_ZBX_USER}" --lc-ctype "en_US.utf8" --lc-collate "en_US.utf8" "${DB_SERVER_DBNAME}" unset PGPASSWORD diff --git a/Dockerfiles/server-pgsql/ol/docker-entrypoint.sh b/Dockerfiles/server-pgsql/ol/docker-entrypoint.sh index d3d13ca91..ba08deb16 100755 --- a/Dockerfiles/server-pgsql/ol/docker-entrypoint.sh +++ b/Dockerfiles/server-pgsql/ol/docker-entrypoint.sh @@ -87,16 +87,20 @@ update_config_var() { echo -n "** Updating '$config_path' parameter \"$var_name\": '$var_value'..." fi - # Remove configuration parameter definition in case of unset parameter value + # Remove configuration parameter definition in case of unset or empty parameter value if [ -z "$var_value" ]; then sed -i -e "/^$var_name=/d" "$config_path" echo "removed" return fi - # Remove value from configuration parameter in case of double quoted parameter value - if [ "$var_value" == '""' ]; then - sed -i -e "/^$var_name=/s/=.*/=/" "$config_path" + # Remove value from configuration parameter in case of set to double quoted parameter value + if [[ "$var_value" == '""' ]]; then + if [ "$(grep -E "^$var_name=" $config_path)" ]; then + sed -i -e "/^$var_name=/s/=.*/=/" "$config_path" + else + sed -i -e "/^[#;] $var_name=/s/.*/&\n$var_name=/" "$config_path" + fi echo "undefined" return fi @@ -154,12 +158,12 @@ file_process_from_env() { # Check prerequisites for PostgreSQL database check_variables_postgresql() { + : ${DB_SERVER_HOST="postgres-server"} + : ${DB_SERVER_PORT:="5432"} + file_env POSTGRES_USER file_env POSTGRES_PASSWORD - : ${DB_SERVER_HOST:="postgres-server"} - : ${DB_SERVER_PORT:="5432"} - DB_SERVER_ROOT_USER=${POSTGRES_USER:-"postgres"} DB_SERVER_ROOT_PASS=${POSTGRES_PASSWORD:-""} @@ -171,12 +175,24 @@ check_variables_postgresql() { DB_SERVER_DBNAME=${POSTGRES_DB:-"zabbix"} : ${POSTGRES_USE_IMPLICIT_SEARCH_PATH:="false"} + + if [ -n "${DB_SERVER_HOST}" ]; then + psql_connect_args="--host ${DB_SERVER_HOST} --port ${DB_SERVER_PORT}" + else + DB_SERVER_HOST='""' + psql_connect_args="--port ${DB_SERVER_PORT}" + fi } check_db_connect_postgresql() { echo "********************" - echo "* DB_SERVER_HOST: ${DB_SERVER_HOST}" - echo "* DB_SERVER_PORT: ${DB_SERVER_PORT}" + if [[ "$DB_SERVER_HOST" != '""' ]]; then + echo "* DB_SERVER_HOST: ${DB_SERVER_HOST}" + echo "* DB_SERVER_PORT: ${DB_SERVER_PORT}" + else + echo "* DB_SERVER_HOST: Using DB socket" + echo "* DB_SERVER_PORT: ${DB_SERVER_PORT}" + fi echo "* DB_SERVER_DBNAME: ${DB_SERVER_DBNAME}" echo "* DB_SERVER_SCHEMA: ${DB_SERVER_SCHEMA}" if [ "${DEBUG_MODE,,}" == "true" ]; then @@ -206,8 +222,8 @@ check_db_connect_postgresql() { while true : do - psql --host ${DB_SERVER_HOST} --port ${DB_SERVER_PORT} --username ${DB_SERVER_ROOT_USER} --list --quiet 1>/dev/null 2>&1 && break - psql --host ${DB_SERVER_HOST} --port ${DB_SERVER_PORT} --username ${DB_SERVER_ROOT_USER} --list --dbname ${DB_SERVER_DBNAME} --quiet 1>/dev/null 2>&1 && break + psql $psql_connect_args --username ${DB_SERVER_ROOT_USER} --list --quiet 1>/dev/null 2>&1 && break + psql $psql_connect_args --username ${DB_SERVER_ROOT_USER} --list --dbname ${DB_SERVER_DBNAME} --quiet 1>/dev/null 2>&1 && break echo "**** PostgreSQL server is not available. Waiting $WAIT_TIMEOUT seconds..." sleep $WAIT_TIMEOUT @@ -244,7 +260,7 @@ psql_query() { export PGSSLKEY=${ZBX_DBTLSKEYFILE} fi - result=$(psql --no-align --quiet --tuples-only --host "${DB_SERVER_HOST}" --port "${DB_SERVER_PORT}" \ + result=$(psql --no-align --quiet --tuples-only $psql_connect_args \ --username "${DB_SERVER_ROOT_USER}" --command "$query" --dbname "$db" 2>/dev/null); unset PGPASSWORD @@ -284,7 +300,7 @@ exec_sql_file() { fi $command $sql_script | psql --quiet \ - --host "${DB_SERVER_HOST}" --port "${DB_SERVER_PORT}" \ + $psql_connect_args \ --username "${DB_SERVER_ZBX_USER}" --dbname "${DB_SERVER_DBNAME}" 1>/dev/null || exit 1 unset PGPASSWORD @@ -318,7 +334,7 @@ create_db_database_postgresql() { export PGSSLKEY=${ZBX_DBTLSKEYFILE} fi - createdb --host "${DB_SERVER_HOST}" --port "${DB_SERVER_PORT}" --username "${DB_SERVER_ROOT_USER}" \ + createdb $psql_connect_args --username "${DB_SERVER_ROOT_USER}" \ --owner "${DB_SERVER_ZBX_USER}" --lc-ctype "en_US.utf8" --lc-collate "en_US.utf8" "${DB_SERVER_DBNAME}" unset PGPASSWORD diff --git a/Dockerfiles/server-pgsql/rhel/docker-entrypoint.sh b/Dockerfiles/server-pgsql/rhel/docker-entrypoint.sh index d3d13ca91..ba08deb16 100755 --- a/Dockerfiles/server-pgsql/rhel/docker-entrypoint.sh +++ b/Dockerfiles/server-pgsql/rhel/docker-entrypoint.sh @@ -87,16 +87,20 @@ update_config_var() { echo -n "** Updating '$config_path' parameter \"$var_name\": '$var_value'..." fi - # Remove configuration parameter definition in case of unset parameter value + # Remove configuration parameter definition in case of unset or empty parameter value if [ -z "$var_value" ]; then sed -i -e "/^$var_name=/d" "$config_path" echo "removed" return fi - # Remove value from configuration parameter in case of double quoted parameter value - if [ "$var_value" == '""' ]; then - sed -i -e "/^$var_name=/s/=.*/=/" "$config_path" + # Remove value from configuration parameter in case of set to double quoted parameter value + if [[ "$var_value" == '""' ]]; then + if [ "$(grep -E "^$var_name=" $config_path)" ]; then + sed -i -e "/^$var_name=/s/=.*/=/" "$config_path" + else + sed -i -e "/^[#;] $var_name=/s/.*/&\n$var_name=/" "$config_path" + fi echo "undefined" return fi @@ -154,12 +158,12 @@ file_process_from_env() { # Check prerequisites for PostgreSQL database check_variables_postgresql() { + : ${DB_SERVER_HOST="postgres-server"} + : ${DB_SERVER_PORT:="5432"} + file_env POSTGRES_USER file_env POSTGRES_PASSWORD - : ${DB_SERVER_HOST:="postgres-server"} - : ${DB_SERVER_PORT:="5432"} - DB_SERVER_ROOT_USER=${POSTGRES_USER:-"postgres"} DB_SERVER_ROOT_PASS=${POSTGRES_PASSWORD:-""} @@ -171,12 +175,24 @@ check_variables_postgresql() { DB_SERVER_DBNAME=${POSTGRES_DB:-"zabbix"} : ${POSTGRES_USE_IMPLICIT_SEARCH_PATH:="false"} + + if [ -n "${DB_SERVER_HOST}" ]; then + psql_connect_args="--host ${DB_SERVER_HOST} --port ${DB_SERVER_PORT}" + else + DB_SERVER_HOST='""' + psql_connect_args="--port ${DB_SERVER_PORT}" + fi } check_db_connect_postgresql() { echo "********************" - echo "* DB_SERVER_HOST: ${DB_SERVER_HOST}" - echo "* DB_SERVER_PORT: ${DB_SERVER_PORT}" + if [[ "$DB_SERVER_HOST" != '""' ]]; then + echo "* DB_SERVER_HOST: ${DB_SERVER_HOST}" + echo "* DB_SERVER_PORT: ${DB_SERVER_PORT}" + else + echo "* DB_SERVER_HOST: Using DB socket" + echo "* DB_SERVER_PORT: ${DB_SERVER_PORT}" + fi echo "* DB_SERVER_DBNAME: ${DB_SERVER_DBNAME}" echo "* DB_SERVER_SCHEMA: ${DB_SERVER_SCHEMA}" if [ "${DEBUG_MODE,,}" == "true" ]; then @@ -206,8 +222,8 @@ check_db_connect_postgresql() { while true : do - psql --host ${DB_SERVER_HOST} --port ${DB_SERVER_PORT} --username ${DB_SERVER_ROOT_USER} --list --quiet 1>/dev/null 2>&1 && break - psql --host ${DB_SERVER_HOST} --port ${DB_SERVER_PORT} --username ${DB_SERVER_ROOT_USER} --list --dbname ${DB_SERVER_DBNAME} --quiet 1>/dev/null 2>&1 && break + psql $psql_connect_args --username ${DB_SERVER_ROOT_USER} --list --quiet 1>/dev/null 2>&1 && break + psql $psql_connect_args --username ${DB_SERVER_ROOT_USER} --list --dbname ${DB_SERVER_DBNAME} --quiet 1>/dev/null 2>&1 && break echo "**** PostgreSQL server is not available. Waiting $WAIT_TIMEOUT seconds..." sleep $WAIT_TIMEOUT @@ -244,7 +260,7 @@ psql_query() { export PGSSLKEY=${ZBX_DBTLSKEYFILE} fi - result=$(psql --no-align --quiet --tuples-only --host "${DB_SERVER_HOST}" --port "${DB_SERVER_PORT}" \ + result=$(psql --no-align --quiet --tuples-only $psql_connect_args \ --username "${DB_SERVER_ROOT_USER}" --command "$query" --dbname "$db" 2>/dev/null); unset PGPASSWORD @@ -284,7 +300,7 @@ exec_sql_file() { fi $command $sql_script | psql --quiet \ - --host "${DB_SERVER_HOST}" --port "${DB_SERVER_PORT}" \ + $psql_connect_args \ --username "${DB_SERVER_ZBX_USER}" --dbname "${DB_SERVER_DBNAME}" 1>/dev/null || exit 1 unset PGPASSWORD @@ -318,7 +334,7 @@ create_db_database_postgresql() { export PGSSLKEY=${ZBX_DBTLSKEYFILE} fi - createdb --host "${DB_SERVER_HOST}" --port "${DB_SERVER_PORT}" --username "${DB_SERVER_ROOT_USER}" \ + createdb $psql_connect_args --username "${DB_SERVER_ROOT_USER}" \ --owner "${DB_SERVER_ZBX_USER}" --lc-ctype "en_US.utf8" --lc-collate "en_US.utf8" "${DB_SERVER_DBNAME}" unset PGPASSWORD diff --git a/Dockerfiles/server-pgsql/ubuntu/docker-entrypoint.sh b/Dockerfiles/server-pgsql/ubuntu/docker-entrypoint.sh index 878c62ce0..d1f5aee49 100755 --- a/Dockerfiles/server-pgsql/ubuntu/docker-entrypoint.sh +++ b/Dockerfiles/server-pgsql/ubuntu/docker-entrypoint.sh @@ -87,16 +87,20 @@ update_config_var() { echo -n "** Updating '$config_path' parameter \"$var_name\": '$var_value'..." fi - # Remove configuration parameter definition in case of unset parameter value + # Remove configuration parameter definition in case of unset or empty parameter value if [ -z "$var_value" ]; then sed -i -e "/^$var_name=/d" "$config_path" echo "removed" return fi - # Remove value from configuration parameter in case of double quoted parameter value - if [ "$var_value" == '""' ]; then - sed -i -e "/^$var_name=/s/=.*/=/" "$config_path" + # Remove value from configuration parameter in case of set to double quoted parameter value + if [[ "$var_value" == '""' ]]; then + if [ "$(grep -E "^$var_name=" $config_path)" ]; then + sed -i -e "/^$var_name=/s/=.*/=/" "$config_path" + else + sed -i -e "/^[#;] $var_name=/s/.*/&\n$var_name=/" "$config_path" + fi echo "undefined" return fi @@ -154,12 +158,12 @@ file_process_from_env() { # Check prerequisites for PostgreSQL database check_variables_postgresql() { + : ${DB_SERVER_HOST="postgres-server"} + : ${DB_SERVER_PORT:="5432"} + file_env POSTGRES_USER file_env POSTGRES_PASSWORD - : ${DB_SERVER_HOST:="postgres-server"} - : ${DB_SERVER_PORT:="5432"} - DB_SERVER_ROOT_USER=${POSTGRES_USER:-"postgres"} DB_SERVER_ROOT_PASS=${POSTGRES_PASSWORD:-""} @@ -171,12 +175,24 @@ check_variables_postgresql() { DB_SERVER_DBNAME=${POSTGRES_DB:-"zabbix"} : ${POSTGRES_USE_IMPLICIT_SEARCH_PATH:="false"} + + if [ -n "${DB_SERVER_HOST}" ]; then + psql_connect_args="--host ${DB_SERVER_HOST} --port ${DB_SERVER_PORT}" + else + DB_SERVER_HOST='""' + psql_connect_args="--port ${DB_SERVER_PORT}" + fi } check_db_connect_postgresql() { echo "********************" - echo "* DB_SERVER_HOST: ${DB_SERVER_HOST}" - echo "* DB_SERVER_PORT: ${DB_SERVER_PORT}" + if [[ "$DB_SERVER_HOST" != '""' ]]; then + echo "* DB_SERVER_HOST: ${DB_SERVER_HOST}" + echo "* DB_SERVER_PORT: ${DB_SERVER_PORT}" + else + echo "* DB_SERVER_HOST: Using DB socket" + echo "* DB_SERVER_PORT: ${DB_SERVER_PORT}" + fi echo "* DB_SERVER_DBNAME: ${DB_SERVER_DBNAME}" echo "* DB_SERVER_SCHEMA: ${DB_SERVER_SCHEMA}" if [ "${DEBUG_MODE,,}" == "true" ]; then @@ -206,8 +222,8 @@ check_db_connect_postgresql() { while true : do - psql --host ${DB_SERVER_HOST} --port ${DB_SERVER_PORT} --username ${DB_SERVER_ROOT_USER} --list --quiet 1>/dev/null 2>&1 && break - psql --host ${DB_SERVER_HOST} --port ${DB_SERVER_PORT} --username ${DB_SERVER_ROOT_USER} --list --dbname ${DB_SERVER_DBNAME} --quiet 1>/dev/null 2>&1 && break + psql $psql_connect_args --username ${DB_SERVER_ROOT_USER} --list --quiet 1>/dev/null 2>&1 && break + psql $psql_connect_args --username ${DB_SERVER_ROOT_USER} --list --dbname ${DB_SERVER_DBNAME} --quiet 1>/dev/null 2>&1 && break echo "**** PostgreSQL server is not available. Waiting $WAIT_TIMEOUT seconds..." sleep $WAIT_TIMEOUT @@ -244,7 +260,7 @@ psql_query() { export PGSSLKEY=${ZBX_DBTLSKEYFILE} fi - result=$(psql --no-align --quiet --tuples-only --host "${DB_SERVER_HOST}" --port "${DB_SERVER_PORT}" \ + result=$(psql --no-align --quiet --tuples-only $psql_connect_args \ --username "${DB_SERVER_ROOT_USER}" --command "$query" --dbname "$db" 2>/dev/null); unset PGPASSWORD @@ -284,7 +300,7 @@ exec_sql_file() { fi $command $sql_script | psql --quiet \ - --host "${DB_SERVER_HOST}" --port "${DB_SERVER_PORT}" \ + $psql_connect_args \ --username "${DB_SERVER_ZBX_USER}" --dbname "${DB_SERVER_DBNAME}" 1>/dev/null || exit 1 unset PGPASSWORD @@ -318,7 +334,7 @@ create_db_database_postgresql() { export PGSSLKEY=${ZBX_DBTLSKEYFILE} fi - createdb --host "${DB_SERVER_HOST}" --port "${DB_SERVER_PORT}" --username "${DB_SERVER_ROOT_USER}" \ + createdb $psql_connect_args --username "${DB_SERVER_ROOT_USER}" \ --owner "${DB_SERVER_ZBX_USER}" --lc-ctype "en_US.utf8" --lc-collate "en_US.utf8" "${DB_SERVER_DBNAME}" unset PGPASSWORD diff --git a/Dockerfiles/web-apache-pgsql/alpine/docker-entrypoint.sh b/Dockerfiles/web-apache-pgsql/alpine/docker-entrypoint.sh index 8cf4118d4..65a4465f1 100755 --- a/Dockerfiles/web-apache-pgsql/alpine/docker-entrypoint.sh +++ b/Dockerfiles/web-apache-pgsql/alpine/docker-entrypoint.sh @@ -62,7 +62,7 @@ check_variables() { file_env POSTGRES_USER file_env POSTGRES_PASSWORD - : ${DB_SERVER_HOST:="postgres-server"} + : ${DB_SERVER_HOST="postgres-server"} : ${DB_SERVER_PORT:="5432"} DB_SERVER_ZBX_USER=${POSTGRES_USER:-"zabbix"} @@ -73,11 +73,23 @@ check_variables() { DB_SERVER_DBNAME=${POSTGRES_DB:-"zabbix"} : ${POSTGRES_USE_IMPLICIT_SEARCH_PATH:="false"} + + if [ -n "${DB_SERVER_HOST}" ]; then + psql_connect_args="--host ${DB_SERVER_HOST} --port ${DB_SERVER_PORT}" + else + psql_connect_args="--port ${DB_SERVER_PORT}" + fi } check_db_connect() { echo "********************" - echo "* DB_SERVER_HOST: ${DB_SERVER_HOST}" + if [ -n "${DB_SERVER_HOST}" ]; then + echo "* DB_SERVER_HOST: ${DB_SERVER_HOST}" + echo "* DB_SERVER_PORT: ${DB_SERVER_PORT}" + else + echo "* DB_SERVER_HOST: Using DB socket" + echo "* DB_SERVER_PORT: ${DB_SERVER_PORT}" + fi echo "* DB_SERVER_PORT: ${DB_SERVER_PORT}" echo "* DB_SERVER_DBNAME: ${DB_SERVER_DBNAME}" echo "* DB_SERVER_SCHEMA: ${DB_SERVER_SCHEMA}" @@ -106,7 +118,7 @@ check_db_connect() { export PGSSLKEY=${ZBX_DBTLSKEYFILE} fi - while [ ! "$(psql --host ${DB_SERVER_HOST} --port ${DB_SERVER_PORT} --username ${DB_SERVER_ZBX_USER} --dbname ${DB_SERVER_DBNAME} --list --quiet 2>/dev/null)" ]; do + while [ ! "$(psql $psql_connect_args --username ${DB_SERVER_ZBX_USER} --dbname ${DB_SERVER_DBNAME} --list --quiet 2>/dev/null)" ]; do echo "**** PostgreSQL server is not available. Waiting $WAIT_TIMEOUT seconds..." sleep $WAIT_TIMEOUT done diff --git a/Dockerfiles/web-apache-pgsql/centos/docker-entrypoint.sh b/Dockerfiles/web-apache-pgsql/centos/docker-entrypoint.sh index 139d7f130..5a41b6cfe 100755 --- a/Dockerfiles/web-apache-pgsql/centos/docker-entrypoint.sh +++ b/Dockerfiles/web-apache-pgsql/centos/docker-entrypoint.sh @@ -62,7 +62,7 @@ check_variables() { file_env POSTGRES_USER file_env POSTGRES_PASSWORD - : ${DB_SERVER_HOST:="postgres-server"} + : ${DB_SERVER_HOST="postgres-server"} : ${DB_SERVER_PORT:="5432"} DB_SERVER_ZBX_USER=${POSTGRES_USER:-"zabbix"} @@ -73,11 +73,23 @@ check_variables() { DB_SERVER_DBNAME=${POSTGRES_DB:-"zabbix"} : ${POSTGRES_USE_IMPLICIT_SEARCH_PATH:="false"} + + if [ -n "${DB_SERVER_HOST}" ]; then + psql_connect_args="--host ${DB_SERVER_HOST} --port ${DB_SERVER_PORT}" + else + psql_connect_args="--port ${DB_SERVER_PORT}" + fi } check_db_connect() { echo "********************" - echo "* DB_SERVER_HOST: ${DB_SERVER_HOST}" + if [ -n "${DB_SERVER_HOST}" ]; then + echo "* DB_SERVER_HOST: ${DB_SERVER_HOST}" + echo "* DB_SERVER_PORT: ${DB_SERVER_PORT}" + else + echo "* DB_SERVER_HOST: Using DB socket" + echo "* DB_SERVER_PORT: ${DB_SERVER_PORT}" + fi echo "* DB_SERVER_PORT: ${DB_SERVER_PORT}" echo "* DB_SERVER_DBNAME: ${DB_SERVER_DBNAME}" echo "* DB_SERVER_SCHEMA: ${DB_SERVER_SCHEMA}" @@ -106,7 +118,7 @@ check_db_connect() { export PGSSLKEY=${ZBX_DBTLSKEYFILE} fi - while [ ! "$(psql --host ${DB_SERVER_HOST} --port ${DB_SERVER_PORT} --username ${DB_SERVER_ZBX_USER} --dbname ${DB_SERVER_DBNAME} --list --quiet 2>/dev/null)" ]; do + while [ ! "$(psql $psql_connect_args --username ${DB_SERVER_ZBX_USER} --dbname ${DB_SERVER_DBNAME} --list --quiet 2>/dev/null)" ]; do echo "**** PostgreSQL server is not available. Waiting $WAIT_TIMEOUT seconds..." sleep $WAIT_TIMEOUT done diff --git a/Dockerfiles/web-apache-pgsql/ol/docker-entrypoint.sh b/Dockerfiles/web-apache-pgsql/ol/docker-entrypoint.sh index 139d7f130..5a41b6cfe 100755 --- a/Dockerfiles/web-apache-pgsql/ol/docker-entrypoint.sh +++ b/Dockerfiles/web-apache-pgsql/ol/docker-entrypoint.sh @@ -62,7 +62,7 @@ check_variables() { file_env POSTGRES_USER file_env POSTGRES_PASSWORD - : ${DB_SERVER_HOST:="postgres-server"} + : ${DB_SERVER_HOST="postgres-server"} : ${DB_SERVER_PORT:="5432"} DB_SERVER_ZBX_USER=${POSTGRES_USER:-"zabbix"} @@ -73,11 +73,23 @@ check_variables() { DB_SERVER_DBNAME=${POSTGRES_DB:-"zabbix"} : ${POSTGRES_USE_IMPLICIT_SEARCH_PATH:="false"} + + if [ -n "${DB_SERVER_HOST}" ]; then + psql_connect_args="--host ${DB_SERVER_HOST} --port ${DB_SERVER_PORT}" + else + psql_connect_args="--port ${DB_SERVER_PORT}" + fi } check_db_connect() { echo "********************" - echo "* DB_SERVER_HOST: ${DB_SERVER_HOST}" + if [ -n "${DB_SERVER_HOST}" ]; then + echo "* DB_SERVER_HOST: ${DB_SERVER_HOST}" + echo "* DB_SERVER_PORT: ${DB_SERVER_PORT}" + else + echo "* DB_SERVER_HOST: Using DB socket" + echo "* DB_SERVER_PORT: ${DB_SERVER_PORT}" + fi echo "* DB_SERVER_PORT: ${DB_SERVER_PORT}" echo "* DB_SERVER_DBNAME: ${DB_SERVER_DBNAME}" echo "* DB_SERVER_SCHEMA: ${DB_SERVER_SCHEMA}" @@ -106,7 +118,7 @@ check_db_connect() { export PGSSLKEY=${ZBX_DBTLSKEYFILE} fi - while [ ! "$(psql --host ${DB_SERVER_HOST} --port ${DB_SERVER_PORT} --username ${DB_SERVER_ZBX_USER} --dbname ${DB_SERVER_DBNAME} --list --quiet 2>/dev/null)" ]; do + while [ ! "$(psql $psql_connect_args --username ${DB_SERVER_ZBX_USER} --dbname ${DB_SERVER_DBNAME} --list --quiet 2>/dev/null)" ]; do echo "**** PostgreSQL server is not available. Waiting $WAIT_TIMEOUT seconds..." sleep $WAIT_TIMEOUT done diff --git a/Dockerfiles/web-apache-pgsql/ubuntu/docker-entrypoint.sh b/Dockerfiles/web-apache-pgsql/ubuntu/docker-entrypoint.sh index 02160b802..da1ef5476 100755 --- a/Dockerfiles/web-apache-pgsql/ubuntu/docker-entrypoint.sh +++ b/Dockerfiles/web-apache-pgsql/ubuntu/docker-entrypoint.sh @@ -64,7 +64,7 @@ check_variables() { file_env POSTGRES_USER file_env POSTGRES_PASSWORD - : ${DB_SERVER_HOST:="postgres-server"} + : ${DB_SERVER_HOST="postgres-server"} : ${DB_SERVER_PORT:="5432"} DB_SERVER_ZBX_USER=${POSTGRES_USER:-"zabbix"} @@ -75,11 +75,23 @@ check_variables() { DB_SERVER_DBNAME=${POSTGRES_DB:-"zabbix"} : ${POSTGRES_USE_IMPLICIT_SEARCH_PATH:="false"} + + if [ -n "${DB_SERVER_HOST}" ]; then + psql_connect_args="--host ${DB_SERVER_HOST} --port ${DB_SERVER_PORT}" + else + psql_connect_args="--port ${DB_SERVER_PORT}" + fi } check_db_connect() { echo "********************" - echo "* DB_SERVER_HOST: ${DB_SERVER_HOST}" + if [ -n "${DB_SERVER_HOST}" ]; then + echo "* DB_SERVER_HOST: ${DB_SERVER_HOST}" + echo "* DB_SERVER_PORT: ${DB_SERVER_PORT}" + else + echo "* DB_SERVER_HOST: Using DB socket" + echo "* DB_SERVER_PORT: ${DB_SERVER_PORT}" + fi echo "* DB_SERVER_PORT: ${DB_SERVER_PORT}" echo "* DB_SERVER_DBNAME: ${DB_SERVER_DBNAME}" echo "* DB_SERVER_SCHEMA: ${DB_SERVER_SCHEMA}" @@ -108,7 +120,7 @@ check_db_connect() { export PGSSLKEY=${ZBX_DBTLSKEYFILE} fi - while [ ! "$(psql --host ${DB_SERVER_HOST} --port ${DB_SERVER_PORT} --username ${DB_SERVER_ZBX_USER} --dbname ${DB_SERVER_DBNAME} --list --quiet 2>/dev/null)" ]; do + while [ ! "$(psql $psql_connect_args --username ${DB_SERVER_ZBX_USER} --dbname ${DB_SERVER_DBNAME} --list --quiet 2>/dev/null)" ]; do echo "**** PostgreSQL server is not available. Waiting $WAIT_TIMEOUT seconds..." sleep $WAIT_TIMEOUT done diff --git a/Dockerfiles/web-nginx-pgsql/alpine/docker-entrypoint.sh b/Dockerfiles/web-nginx-pgsql/alpine/docker-entrypoint.sh index f885a0ed0..b59efb787 100755 --- a/Dockerfiles/web-nginx-pgsql/alpine/docker-entrypoint.sh +++ b/Dockerfiles/web-nginx-pgsql/alpine/docker-entrypoint.sh @@ -65,7 +65,7 @@ check_variables() { file_env POSTGRES_USER file_env POSTGRES_PASSWORD - : ${DB_SERVER_HOST:="postgres-server"} + : ${DB_SERVER_HOST="postgres-server"} : ${DB_SERVER_PORT:="5432"} DB_SERVER_ZBX_USER=${POSTGRES_USER:-"zabbix"} @@ -76,11 +76,23 @@ check_variables() { DB_SERVER_DBNAME=${POSTGRES_DB:-"zabbix"} : ${POSTGRES_USE_IMPLICIT_SEARCH_PATH:="false"} + + if [ -n "${DB_SERVER_HOST}" ]; then + psql_connect_args="--host ${DB_SERVER_HOST} --port ${DB_SERVER_PORT}" + else + psql_connect_args="--port ${DB_SERVER_PORT}" + fi } check_db_connect() { echo "********************" - echo "* DB_SERVER_HOST: ${DB_SERVER_HOST}" + if [ -n "${DB_SERVER_HOST}" ]; then + echo "* DB_SERVER_HOST: ${DB_SERVER_HOST}" + echo "* DB_SERVER_PORT: ${DB_SERVER_PORT}" + else + echo "* DB_SERVER_HOST: Using DB socket" + echo "* DB_SERVER_PORT: ${DB_SERVER_PORT}" + fi echo "* DB_SERVER_PORT: ${DB_SERVER_PORT}" echo "* DB_SERVER_DBNAME: ${DB_SERVER_DBNAME}" echo "* DB_SERVER_SCHEMA: ${DB_SERVER_SCHEMA}" @@ -109,7 +121,7 @@ check_db_connect() { export PGSSLKEY=${ZBX_DBTLSKEYFILE} fi - while [ ! "$(psql --host ${DB_SERVER_HOST} --port ${DB_SERVER_PORT} --username ${DB_SERVER_ZBX_USER} --dbname ${DB_SERVER_DBNAME} --list --quiet 2>/dev/null)" ]; do + while [ ! "$(psql $psql_connect_args --username ${DB_SERVER_ZBX_USER} --dbname ${DB_SERVER_DBNAME} --list --quiet 2>/dev/null)" ]; do echo "**** PostgreSQL server is not available. Waiting $WAIT_TIMEOUT seconds..." sleep $WAIT_TIMEOUT done diff --git a/Dockerfiles/web-nginx-pgsql/centos/docker-entrypoint.sh b/Dockerfiles/web-nginx-pgsql/centos/docker-entrypoint.sh index 2b29ef2f0..b8b4efe6b 100755 --- a/Dockerfiles/web-nginx-pgsql/centos/docker-entrypoint.sh +++ b/Dockerfiles/web-nginx-pgsql/centos/docker-entrypoint.sh @@ -65,7 +65,7 @@ check_variables() { file_env POSTGRES_USER file_env POSTGRES_PASSWORD - : ${DB_SERVER_HOST:="postgres-server"} + : ${DB_SERVER_HOST="postgres-server"} : ${DB_SERVER_PORT:="5432"} DB_SERVER_ZBX_USER=${POSTGRES_USER:-"zabbix"} @@ -76,11 +76,23 @@ check_variables() { DB_SERVER_DBNAME=${POSTGRES_DB:-"zabbix"} : ${POSTGRES_USE_IMPLICIT_SEARCH_PATH:="false"} + + if [ -n "${DB_SERVER_HOST}" ]; then + psql_connect_args="--host ${DB_SERVER_HOST} --port ${DB_SERVER_PORT}" + else + psql_connect_args="--port ${DB_SERVER_PORT}" + fi } check_db_connect() { echo "********************" - echo "* DB_SERVER_HOST: ${DB_SERVER_HOST}" + if [ -n "${DB_SERVER_HOST}" ]; then + echo "* DB_SERVER_HOST: ${DB_SERVER_HOST}" + echo "* DB_SERVER_PORT: ${DB_SERVER_PORT}" + else + echo "* DB_SERVER_HOST: Using DB socket" + echo "* DB_SERVER_PORT: ${DB_SERVER_PORT}" + fi echo "* DB_SERVER_PORT: ${DB_SERVER_PORT}" echo "* DB_SERVER_DBNAME: ${DB_SERVER_DBNAME}" echo "* DB_SERVER_SCHEMA: ${DB_SERVER_SCHEMA}" @@ -109,7 +121,7 @@ check_db_connect() { export PGSSLKEY=${ZBX_DBTLSKEYFILE} fi - while [ ! "$(psql --host ${DB_SERVER_HOST} --port ${DB_SERVER_PORT} --username ${DB_SERVER_ZBX_USER} --dbname ${DB_SERVER_DBNAME} --list --quiet 2>/dev/null)" ]; do + while [ ! "$(psql $psql_connect_args --username ${DB_SERVER_ZBX_USER} --dbname ${DB_SERVER_DBNAME} --list --quiet 2>/dev/null)" ]; do echo "**** PostgreSQL server is not available. Waiting $WAIT_TIMEOUT seconds..." sleep $WAIT_TIMEOUT done diff --git a/Dockerfiles/web-nginx-pgsql/ol/docker-entrypoint.sh b/Dockerfiles/web-nginx-pgsql/ol/docker-entrypoint.sh index 2b29ef2f0..b8b4efe6b 100755 --- a/Dockerfiles/web-nginx-pgsql/ol/docker-entrypoint.sh +++ b/Dockerfiles/web-nginx-pgsql/ol/docker-entrypoint.sh @@ -65,7 +65,7 @@ check_variables() { file_env POSTGRES_USER file_env POSTGRES_PASSWORD - : ${DB_SERVER_HOST:="postgres-server"} + : ${DB_SERVER_HOST="postgres-server"} : ${DB_SERVER_PORT:="5432"} DB_SERVER_ZBX_USER=${POSTGRES_USER:-"zabbix"} @@ -76,11 +76,23 @@ check_variables() { DB_SERVER_DBNAME=${POSTGRES_DB:-"zabbix"} : ${POSTGRES_USE_IMPLICIT_SEARCH_PATH:="false"} + + if [ -n "${DB_SERVER_HOST}" ]; then + psql_connect_args="--host ${DB_SERVER_HOST} --port ${DB_SERVER_PORT}" + else + psql_connect_args="--port ${DB_SERVER_PORT}" + fi } check_db_connect() { echo "********************" - echo "* DB_SERVER_HOST: ${DB_SERVER_HOST}" + if [ -n "${DB_SERVER_HOST}" ]; then + echo "* DB_SERVER_HOST: ${DB_SERVER_HOST}" + echo "* DB_SERVER_PORT: ${DB_SERVER_PORT}" + else + echo "* DB_SERVER_HOST: Using DB socket" + echo "* DB_SERVER_PORT: ${DB_SERVER_PORT}" + fi echo "* DB_SERVER_PORT: ${DB_SERVER_PORT}" echo "* DB_SERVER_DBNAME: ${DB_SERVER_DBNAME}" echo "* DB_SERVER_SCHEMA: ${DB_SERVER_SCHEMA}" @@ -109,7 +121,7 @@ check_db_connect() { export PGSSLKEY=${ZBX_DBTLSKEYFILE} fi - while [ ! "$(psql --host ${DB_SERVER_HOST} --port ${DB_SERVER_PORT} --username ${DB_SERVER_ZBX_USER} --dbname ${DB_SERVER_DBNAME} --list --quiet 2>/dev/null)" ]; do + while [ ! "$(psql $psql_connect_args --username ${DB_SERVER_ZBX_USER} --dbname ${DB_SERVER_DBNAME} --list --quiet 2>/dev/null)" ]; do echo "**** PostgreSQL server is not available. Waiting $WAIT_TIMEOUT seconds..." sleep $WAIT_TIMEOUT done diff --git a/Dockerfiles/web-nginx-pgsql/rhel/docker-entrypoint.sh b/Dockerfiles/web-nginx-pgsql/rhel/docker-entrypoint.sh index 2b29ef2f0..b8b4efe6b 100755 --- a/Dockerfiles/web-nginx-pgsql/rhel/docker-entrypoint.sh +++ b/Dockerfiles/web-nginx-pgsql/rhel/docker-entrypoint.sh @@ -65,7 +65,7 @@ check_variables() { file_env POSTGRES_USER file_env POSTGRES_PASSWORD - : ${DB_SERVER_HOST:="postgres-server"} + : ${DB_SERVER_HOST="postgres-server"} : ${DB_SERVER_PORT:="5432"} DB_SERVER_ZBX_USER=${POSTGRES_USER:-"zabbix"} @@ -76,11 +76,23 @@ check_variables() { DB_SERVER_DBNAME=${POSTGRES_DB:-"zabbix"} : ${POSTGRES_USE_IMPLICIT_SEARCH_PATH:="false"} + + if [ -n "${DB_SERVER_HOST}" ]; then + psql_connect_args="--host ${DB_SERVER_HOST} --port ${DB_SERVER_PORT}" + else + psql_connect_args="--port ${DB_SERVER_PORT}" + fi } check_db_connect() { echo "********************" - echo "* DB_SERVER_HOST: ${DB_SERVER_HOST}" + if [ -n "${DB_SERVER_HOST}" ]; then + echo "* DB_SERVER_HOST: ${DB_SERVER_HOST}" + echo "* DB_SERVER_PORT: ${DB_SERVER_PORT}" + else + echo "* DB_SERVER_HOST: Using DB socket" + echo "* DB_SERVER_PORT: ${DB_SERVER_PORT}" + fi echo "* DB_SERVER_PORT: ${DB_SERVER_PORT}" echo "* DB_SERVER_DBNAME: ${DB_SERVER_DBNAME}" echo "* DB_SERVER_SCHEMA: ${DB_SERVER_SCHEMA}" @@ -109,7 +121,7 @@ check_db_connect() { export PGSSLKEY=${ZBX_DBTLSKEYFILE} fi - while [ ! "$(psql --host ${DB_SERVER_HOST} --port ${DB_SERVER_PORT} --username ${DB_SERVER_ZBX_USER} --dbname ${DB_SERVER_DBNAME} --list --quiet 2>/dev/null)" ]; do + while [ ! "$(psql $psql_connect_args --username ${DB_SERVER_ZBX_USER} --dbname ${DB_SERVER_DBNAME} --list --quiet 2>/dev/null)" ]; do echo "**** PostgreSQL server is not available. Waiting $WAIT_TIMEOUT seconds..." sleep $WAIT_TIMEOUT done diff --git a/Dockerfiles/web-nginx-pgsql/ubuntu/docker-entrypoint.sh b/Dockerfiles/web-nginx-pgsql/ubuntu/docker-entrypoint.sh index 0be87cf81..8baffe32c 100755 --- a/Dockerfiles/web-nginx-pgsql/ubuntu/docker-entrypoint.sh +++ b/Dockerfiles/web-nginx-pgsql/ubuntu/docker-entrypoint.sh @@ -65,7 +65,7 @@ check_variables() { file_env POSTGRES_USER file_env POSTGRES_PASSWORD - : ${DB_SERVER_HOST:="postgres-server"} + : ${DB_SERVER_HOST="postgres-server"} : ${DB_SERVER_PORT:="5432"} DB_SERVER_ZBX_USER=${POSTGRES_USER:-"zabbix"} @@ -76,11 +76,23 @@ check_variables() { DB_SERVER_DBNAME=${POSTGRES_DB:-"zabbix"} : ${POSTGRES_USE_IMPLICIT_SEARCH_PATH:="false"} + + if [ -n "${DB_SERVER_HOST}" ]; then + psql_connect_args="--host ${DB_SERVER_HOST} --port ${DB_SERVER_PORT}" + else + psql_connect_args="--port ${DB_SERVER_PORT}" + fi } check_db_connect() { echo "********************" - echo "* DB_SERVER_HOST: ${DB_SERVER_HOST}" + if [ -n "${DB_SERVER_HOST}" ]; then + echo "* DB_SERVER_HOST: ${DB_SERVER_HOST}" + echo "* DB_SERVER_PORT: ${DB_SERVER_PORT}" + else + echo "* DB_SERVER_HOST: Using DB socket" + echo "* DB_SERVER_PORT: ${DB_SERVER_PORT}" + fi echo "* DB_SERVER_PORT: ${DB_SERVER_PORT}" echo "* DB_SERVER_DBNAME: ${DB_SERVER_DBNAME}" echo "* DB_SERVER_SCHEMA: ${DB_SERVER_SCHEMA}" @@ -109,7 +121,7 @@ check_db_connect() { export PGSSLKEY=${ZBX_DBTLSKEYFILE} fi - while [ ! "$(psql --host ${DB_SERVER_HOST} --port ${DB_SERVER_PORT} --username ${DB_SERVER_ZBX_USER} --dbname ${DB_SERVER_DBNAME} --list --quiet 2>/dev/null)" ]; do + while [ ! "$(psql $psql_connect_args --username ${DB_SERVER_ZBX_USER} --dbname ${DB_SERVER_DBNAME} --list --quiet 2>/dev/null)" ]; do echo "**** PostgreSQL server is not available. Waiting $WAIT_TIMEOUT seconds..." sleep $WAIT_TIMEOUT done diff --git a/compose_databases.yaml b/compose_databases.yaml index 72c98f0f7..8e392bb6b 100644 --- a/compose_databases.yaml +++ b/compose_databases.yaml @@ -18,7 +18,7 @@ services: volumes: - ${DATA_DIRECTORY}/var/lib/mysql:/var/lib/mysql:rw - ${ENV_VARS_DIRECTORY}/mysql_init/init_proxy_db.sql:/docker-entrypoint-initdb.d/mysql_init_proxy.sql:ro -# - dbsocket:/var/run/mysqld/ +# - mysql_socket:/var/run/mysqld/ env_file: - ${ENV_VARS_DIRECTORY}/.env_db_mysql - path: ${ENV_VARS_DIRECTORY}/.env_db_mysql_override @@ -48,6 +48,7 @@ services: - ${ENV_VARS_DIRECTORY}/.ZBX_DB_CA_FILE:/run/secrets/root-ca.pem:ro - ${ENV_VARS_DIRECTORY}/.ZBX_DB_CERT_FILE:/run/secrets/server-cert.pem:ro - ${ENV_VARS_DIRECTORY}/.ZBX_DB_KEY_FILE:/run/secrets/server-key.pem:ro +# - pgsql_socket:/var/run/postgresql/ env_file: - ${ENV_VARS_DIRECTORY}/.env_db_pgsql - path: ${ENV_VARS_DIRECTORY}/.env_db_pgsql_override diff --git a/compose_zabbix_components.yaml b/compose_zabbix_components.yaml index 03adb0280..38e241342 100644 --- a/compose_zabbix_components.yaml +++ b/compose_zabbix_components.yaml @@ -66,7 +66,7 @@ services: extends: service: server # volumes: -# - dbsocket:/var/run/mysqld/ +# - mysql_socket:/var/run/mysqld/ env_file: - ${ENV_VARS_DIRECTORY}/.env_db_mysql secrets: @@ -90,6 +90,7 @@ services: # - ${ENV_VARS_DIRECTORY}/.ZBX_DB_CA_FILE:/run/secrets/root-ca.pem:ro # - ${ENV_VARS_DIRECTORY}/.ZBX_DB_CERT_FILE:/run/secrets/client-cert.pem:ro # - ${ENV_VARS_DIRECTORY}/.ZBX_DB_KEY_FILE:/run/secrets/client-key.pem:ro +# - pgsql_socket:/var/run/postgresql env_file: - ${ENV_VARS_DIRECTORY}/.env_db_pgsql secrets: @@ -181,7 +182,7 @@ services: protocol: tcp app_protocol: zabbix-trapper # volumes: -# - dbsocket:/var/run/mysqld/ +# - mysql_socket:/var/run/mysqld/ env_file: - ${ENV_VARS_DIRECTORY}/.env_db_mysql_proxy - ${ENV_VARS_DIRECTORY}/.env_prx_mysql @@ -259,7 +260,7 @@ services: extends: service: web-apache # volumes: -# - dbsocket:/var/run/mysqld/ +# - mysql_socket:/var/run/mysqld/ env_file: - ${ENV_VARS_DIRECTORY}/.env_db_mysql secrets: @@ -279,6 +280,7 @@ services: # - ${ENV_VARS_DIRECTORY}/.ZBX_DB_CA_FILE:/run/secrets/root-ca.pem:ro # - ${ENV_VARS_DIRECTORY}/.ZBX_DB_CERT_FILE:/run/secrets/client-cert.pem:ro # - ${ENV_VARS_DIRECTORY}/.ZBX_DB_KEY_FILE:/run/secrets/client-key.pem:ro +# - pgsql_socket:/var/run/postgresql env_file: - ${ENV_VARS_DIRECTORY}/.env_db_pgsql secrets: @@ -345,7 +347,7 @@ services: extends: service: web-nginx # volumes: -# - dbsocket:/var/run/mysqld/ +# - mysql_socket:/var/run/mysqld/ env_file: - ${ENV_VARS_DIRECTORY}/.env_db_mysql secrets: @@ -369,6 +371,7 @@ services: # - ${ENV_VARS_DIRECTORY}/.ZBX_DB_CA_FILE:/run/secrets/root-ca.pem:ro # - ${ENV_VARS_DIRECTORY}/.ZBX_DB_CERT_FILE:/run/secrets/client-cert.pem:ro # - ${ENV_VARS_DIRECTORY}/.ZBX_DB_KEY_FILE:/run/secrets/client-key.pem:ro +# - pgsql_socket:/var/run/postgresql env_file: - ${ENV_VARS_DIRECTORY}/.env_db_pgsql secrets: diff --git a/docker-compose_v3_alpine_mysql_latest.yaml b/docker-compose_v3_alpine_mysql_latest.yaml index 35a42509d..672dbf543 100644 --- a/docker-compose_v3_alpine_mysql_latest.yaml +++ b/docker-compose_v3_alpine_mysql_latest.yaml @@ -158,7 +158,7 @@ networks: volumes: snmptraps: -# dbsocket: +# mysql_socket: secrets: MYSQL_USER: diff --git a/docker-compose_v3_alpine_mysql_local.yaml b/docker-compose_v3_alpine_mysql_local.yaml index d263d74d5..e7cce1f47 100644 --- a/docker-compose_v3_alpine_mysql_local.yaml +++ b/docker-compose_v3_alpine_mysql_local.yaml @@ -258,7 +258,7 @@ networks: volumes: snmptraps: -# dbsocket: +# mysql_socket: secrets: MYSQL_USER: diff --git a/docker-compose_v3_alpine_pgsql_latest.yaml b/docker-compose_v3_alpine_pgsql_latest.yaml index ad2dbc096..bcc2747b7 100644 --- a/docker-compose_v3_alpine_pgsql_latest.yaml +++ b/docker-compose_v3_alpine_pgsql_latest.yaml @@ -173,7 +173,8 @@ networks: volumes: snmptraps: -# dbsocket: +# mysql_socket: +# pgsql_socket: secrets: MYSQL_USER: diff --git a/docker-compose_v3_alpine_pgsql_local.yaml b/docker-compose_v3_alpine_pgsql_local.yaml index 6c41fed86..c46cb5fb4 100644 --- a/docker-compose_v3_alpine_pgsql_local.yaml +++ b/docker-compose_v3_alpine_pgsql_local.yaml @@ -287,7 +287,8 @@ networks: volumes: snmptraps: -# dbsocket: +# mysql_socket: +# pgsql_socket: secrets: MYSQL_USER: diff --git a/docker-compose_v3_centos_mysql_latest.yaml b/docker-compose_v3_centos_mysql_latest.yaml index 63dc08867..b3ef5dd6a 100644 --- a/docker-compose_v3_centos_mysql_latest.yaml +++ b/docker-compose_v3_centos_mysql_latest.yaml @@ -158,7 +158,7 @@ networks: volumes: snmptraps: -# dbsocket: +# mysql_socket: secrets: MYSQL_USER: diff --git a/docker-compose_v3_centos_mysql_local.yaml b/docker-compose_v3_centos_mysql_local.yaml index a03fa564c..b18007fc3 100644 --- a/docker-compose_v3_centos_mysql_local.yaml +++ b/docker-compose_v3_centos_mysql_local.yaml @@ -259,7 +259,7 @@ networks: volumes: snmptraps: -# dbsocket: +# mysql_socket: secrets: MYSQL_USER: diff --git a/docker-compose_v3_centos_pgsql_latest.yaml b/docker-compose_v3_centos_pgsql_latest.yaml index ce9ad67ab..07691427e 100644 --- a/docker-compose_v3_centos_pgsql_latest.yaml +++ b/docker-compose_v3_centos_pgsql_latest.yaml @@ -172,7 +172,8 @@ networks: volumes: snmptraps: -# dbsocket: +# mysql_socket: +# pgsql_socket: secrets: MYSQL_USER: diff --git a/docker-compose_v3_centos_pgsql_local.yaml b/docker-compose_v3_centos_pgsql_local.yaml index 666f47bfe..853622d7c 100644 --- a/docker-compose_v3_centos_pgsql_local.yaml +++ b/docker-compose_v3_centos_pgsql_local.yaml @@ -286,7 +286,8 @@ networks: volumes: snmptraps: -# dbsocket: +# mysql_socket: +# pgsql_socket: secrets: MYSQL_USER: diff --git a/docker-compose_v3_ol_mysql_latest.yaml b/docker-compose_v3_ol_mysql_latest.yaml index 772e8f56d..0d82bade7 100644 --- a/docker-compose_v3_ol_mysql_latest.yaml +++ b/docker-compose_v3_ol_mysql_latest.yaml @@ -158,7 +158,7 @@ networks: volumes: snmptraps: -# dbsocket: +# mysql_socket: secrets: MYSQL_USER: diff --git a/docker-compose_v3_ol_mysql_local.yaml b/docker-compose_v3_ol_mysql_local.yaml index d1823b374..775b838dd 100644 --- a/docker-compose_v3_ol_mysql_local.yaml +++ b/docker-compose_v3_ol_mysql_local.yaml @@ -259,7 +259,7 @@ networks: volumes: snmptraps: -# dbsocket: +# mysql_socket: secrets: MYSQL_USER: diff --git a/docker-compose_v3_ol_pgsql_latest.yaml b/docker-compose_v3_ol_pgsql_latest.yaml index 899b0e5c2..dd70329d4 100644 --- a/docker-compose_v3_ol_pgsql_latest.yaml +++ b/docker-compose_v3_ol_pgsql_latest.yaml @@ -172,7 +172,8 @@ networks: volumes: snmptraps: -# dbsocket: +# mysql_socket: +# pgsql_socket: secrets: MYSQL_USER: diff --git a/docker-compose_v3_ol_pgsql_local.yaml b/docker-compose_v3_ol_pgsql_local.yaml index add780ab2..14783d2b2 100644 --- a/docker-compose_v3_ol_pgsql_local.yaml +++ b/docker-compose_v3_ol_pgsql_local.yaml @@ -286,7 +286,8 @@ networks: volumes: snmptraps: -# dbsocket: +# mysql_socket: +# pgsql_socket: secrets: MYSQL_USER: diff --git a/docker-compose_v3_ubuntu_mysql_latest.yaml b/docker-compose_v3_ubuntu_mysql_latest.yaml index 39c5409ff..b6ea6a248 100644 --- a/docker-compose_v3_ubuntu_mysql_latest.yaml +++ b/docker-compose_v3_ubuntu_mysql_latest.yaml @@ -146,7 +146,7 @@ networks: volumes: snmptraps: -# dbsocket: +# mysql_socket: secrets: MYSQL_USER: diff --git a/docker-compose_v3_ubuntu_mysql_local.yaml b/docker-compose_v3_ubuntu_mysql_local.yaml index 1d4163e81..95b2badbf 100644 --- a/docker-compose_v3_ubuntu_mysql_local.yaml +++ b/docker-compose_v3_ubuntu_mysql_local.yaml @@ -247,7 +247,7 @@ networks: volumes: snmptraps: -# dbsocket: +# mysql_socket: secrets: MYSQL_USER: diff --git a/docker-compose_v3_ubuntu_pgsql_latest.yaml b/docker-compose_v3_ubuntu_pgsql_latest.yaml index 9283e91f2..e7af9ac8d 100644 --- a/docker-compose_v3_ubuntu_pgsql_latest.yaml +++ b/docker-compose_v3_ubuntu_pgsql_latest.yaml @@ -160,7 +160,8 @@ networks: volumes: snmptraps: -# dbsocket: +# mysql_socket: +# pgsql_socket: secrets: MYSQL_USER: diff --git a/docker-compose_v3_ubuntu_pgsql_local.yaml b/docker-compose_v3_ubuntu_pgsql_local.yaml index ec92b5a85..d36c8f8db 100644 --- a/docker-compose_v3_ubuntu_pgsql_local.yaml +++ b/docker-compose_v3_ubuntu_pgsql_local.yaml @@ -274,7 +274,8 @@ networks: volumes: snmptraps: -# dbsocket: +# mysql_socket: +# pgsql_socket: secrets: MYSQL_USER: