Pomocí Docker Compose
Při práci s Docker Compose můžete použít command: postgres -c option=value
ve vašem docker-compose.yml
pro konfiguraci Postgres.
To například způsobí, že se Postgres zapíše do souboru:
command: postgres -c logging_collector=on -c log_destination=stderr -c log_directory=/logs
Přizpůsobení odpovědi Vojtěcha Vítka můžete použít
command: postgres -c config_file=/etc/postgresql.conf
pro změnu konfiguračního souboru, který Postgres použije. Připojili byste svůj vlastní konfigurační soubor se svazkem:
volumes:
- ./customPostgresql.conf:/etc/postgresql.conf
Zde je docker-compose.yml
mé aplikace, ukazující, jak nakonfigurovat Postgres:
# Start the app using docker-compose pull && docker-compose up to make sure you have the latest image
version: '2.1'
services:
myApp:
image: registry.gitlab.com/bullbytes/myApp:latest
networks:
- myApp-network
db:
image: postgres:9.6.1
# Make Postgres log to a file.
# More on logging with Postgres: https://www.postgresql.org/docs/current/static/runtime-config-logging.html
command: postgres -c logging_collector=on -c log_destination=stderr -c log_directory=/logs
environment:
# Provide the password via an environment variable. If the variable is unset or empty, use a default password
# Explanation of this shell feature: https://unix.stackexchange.com/questions/122845/using-a-b-for-variable-assignment-in-scripts/122848#122848
- POSTGRES_PASSWORD=${POSTGRES_PASSWORD:-4WXUms893U6j4GE&Hvk3S*hqcqebFgo!vZi}
# If on a non-Linux OS, make sure you share the drive used here. Go to Docker's settings -> Shared Drives
volumes:
# Persist the data between container invocations
- postgresVolume:/var/lib/postgresql/data
- ./logs:/logs
networks:
myApp-network:
# Our application can communicate with the database using this hostname
aliases:
- postgresForMyApp
networks:
myApp-network:
driver: bridge
# Creates a named volume to persist our data. When on a non-Linux OS, the volume's data will be in the Docker VM
# (e.g., MobyLinuxVM) in /var/lib/docker/volumes/
volumes:
postgresVolume:
Oprávnění k zápisu do adresáře log
Pamatujte, že v systému Linux musí mít adresář protokolu na hostiteli správná oprávnění. V opačném případě se zobrazí mírně zavádějící chyba
FATAL:nelze otevřít soubor protokolu"/logs/postgresql-2017-02-04_115222.log":Povolení odepřeno
Říkám zavádějící, protože chybová zpráva naznačuje, že adresář v kontejneru má špatné oprávnění, když ve skutečnosti adresář na hostiteli neumožňuje psaní.
Abych to vyřešil, nastavil jsem správná oprávnění na hostiteli pomocí
chgroup ./logs docker && chmod 770 ./logs