You've already forked postgres
mirror of
https://github.com/docker-library/postgres.git
synced 2025-11-10 04:42:21 +03:00
Add new "docker-ensure-initdb.sh" script
This mimics the behavior of `docker-entrypoint.sh` before it starts the PostgreSQL server.
It has three main goals/uses:
1. (most importantly) as an example of how to use "docker-entrypoint.sh" to extend/reuse the initialization behavior
2. ("docker-ensure-initdb.sh") as a Kubernetes "init container" to ensure the provided database directory is initialized; see also "startup probes" for an alternative solution
(no-op if database is already initialized)
3. ("docker-enforce-initdb.sh") as part of CI to ensure the database is fully initialized before use
(error if database is already initialized)
This commit is contained in:
71
docker-ensure-initdb.sh
Executable file
71
docker-ensure-initdb.sh
Executable file
@@ -0,0 +1,71 @@
|
||||
#!/usr/bin/env bash
|
||||
set -Eeuo pipefail
|
||||
|
||||
#
|
||||
# This script is intended for three main use cases:
|
||||
#
|
||||
# 1. (most importantly) as an example of how to use "docker-entrypoint.sh" to extend/reuse the initialization behavior
|
||||
#
|
||||
# 2. ("docker-ensure-initdb.sh") as a Kubernetes "init container" to ensure the provided database directory is initialized; see also "startup probes" for an alternative solution
|
||||
# (no-op if database is already initialized)
|
||||
#
|
||||
# 3. ("docker-enforce-initdb.sh") as part of CI to ensure the database is fully initialized before use
|
||||
# (error if database is already initialized)
|
||||
#
|
||||
|
||||
source /usr/local/bin/docker-entrypoint.sh
|
||||
|
||||
# arguments to this script are assumed to be arguments to the "postgres" server (same as "docker-entrypoint.sh"), and most "docker-entrypoint.sh" functions assume "postgres" is the first argument (see "_main" over there)
|
||||
if [ "$#" -eq 0 ] || [ "$1" != 'postgres' ]; then
|
||||
set -- postgres "$@"
|
||||
fi
|
||||
|
||||
# see also "_main" in "docker-entrypoint.sh"
|
||||
|
||||
docker_setup_env
|
||||
# setup data directories and permissions (when run as root)
|
||||
docker_create_db_directories
|
||||
if [ "$(id -u)" = '0' ]; then
|
||||
# then restart script as postgres user
|
||||
exec gosu postgres "$BASH_SOURCE" "$@"
|
||||
fi
|
||||
|
||||
# only run initialization on an empty data directory
|
||||
if [ -z "$DATABASE_ALREADY_EXISTS" ]; then
|
||||
docker_verify_minimum_env
|
||||
|
||||
# check dir permissions to reduce likelihood of half-initialized database
|
||||
ls /docker-entrypoint-initdb.d/ > /dev/null
|
||||
|
||||
docker_init_database_dir
|
||||
pg_setup_hba_conf "$@"
|
||||
|
||||
# PGPASSWORD is required for psql when authentication is required for 'local' connections via pg_hba.conf and is otherwise harmless
|
||||
# e.g. when '--auth=md5' or '--auth-local=md5' is used in POSTGRES_INITDB_ARGS
|
||||
export PGPASSWORD="${PGPASSWORD:-$POSTGRES_PASSWORD}"
|
||||
docker_temp_server_start "$@"
|
||||
|
||||
docker_setup_db
|
||||
docker_process_init_files /docker-entrypoint-initdb.d/*
|
||||
|
||||
docker_temp_server_stop
|
||||
unset PGPASSWORD
|
||||
else
|
||||
self="$(basename "$0")"
|
||||
case "$self" in
|
||||
docker-ensure-initdb.sh)
|
||||
echo >&2 "$self: note: database already initialized in '$PGDATA'!"
|
||||
exit 0
|
||||
;;
|
||||
|
||||
docker-enforce-initdb.sh)
|
||||
echo >&2 "$self: error: (unexpected) database found in '$PGDATA'!"
|
||||
exit 1
|
||||
;;
|
||||
|
||||
*)
|
||||
echo >&2 "$self: error: unknown file name: $self"
|
||||
exit 99
|
||||
;;
|
||||
esac
|
||||
fi
|
||||
Reference in New Issue
Block a user