Skip to content
Snippets Groups Projects
Commit f2a96da3 authored by Bertrand Gauthier's avatar Bertrand Gauthier
Browse files

Amélioration de la subsituabilité des scripts SQL de création/peuplement des objets de la bdd

parent fc53f1d1
Branches
No related tags found
No related merge requests found
Pipeline #9573 passed
data/
...@@ -10,8 +10,11 @@ RUN localedef -i fr_FR -c -f UTF-8 -A /usr/share/locale/locale.alias fr_FR.UTF-8 ...@@ -10,8 +10,11 @@ RUN localedef -i fr_FR -c -f UTF-8 -A /usr/share/locale/locale.alias fr_FR.UTF-8
ENV LANG fr_FR.utf8 ENV LANG fr_FR.utf8
# Script d'initialisation de la bdd, lancé automatiquement (ssi le répertoire `data/db` est vide). # Copie du script de création de la base 'sygal' et du user 'ad_sygal'
# (lancé automatiquement ssi le répertoire de persistance de la base de données est vide).
COPY docker/init_user_db.sh /docker-entrypoint-initdb.d/ COPY docker/init_user_db.sh /docker-entrypoint-initdb.d/
# Copie des scripts SQL de création de la bdd, lancés par le script `init_user_db.sh`. # Copie des scripts SQL de création des objets de la base de données 'sygal'
# (le script `init_user_db.sh` lancera tous les scripts .sql présents dans `/sql`).
# NB : il est possible de substituer ces scripts par les vôtres grâce à un volume.
COPY docker/sql/*.sql /sql/ COPY docker/sql/*.sql /sql/
# Sygal Db Image # Sygal Db Image
## Construction de l'image (build) ## Script `docker/init_user_db.sh`
Ce script est monté pour être lancé automatiquement au démarrage du container pour...
- créer une base de données `sygal`,
- créer le user `ad_sygal`,
- lancer tous les scripts .sql présents dans le répertoire `/sql` de l'image.
## Répertoire `docker/sql` =>
Construisez l'image pour la version de PHP désirée... Il contient les scripts SQL ordonnés pour la création et le peuplement des objets de la base de données 'sygal',
lancés par le script `docker/init_user_db.sh`.
Si vous voulez substituer ces scripts SQL par les vôtres, vous pouvez spécifier un montage du genre
`--volume $PWD/mes/scripts/sql/:/sql` au lancement du container.
## Construction de l'image (build)
```bash ```bash
docker build \ docker build \
...@@ -33,15 +46,14 @@ docker run \ ...@@ -33,15 +46,14 @@ docker run \
--env POSTGRES_PASSWORD=admin \ --env POSTGRES_PASSWORD=admin \
--publish 5432:5432 \ --publish 5432:5432 \
--volume $PWD/data/db:/var/lib/postgresql/data \ --volume $PWD/data/db:/var/lib/postgresql/data \
--volume $PWD/docker/db/sql/:/sql \
--name sygal-db-container \ --name sygal-db-container \
sygal-db-image sygal-db-image
``` ```
Remarques : Remarques :
- Le montage `./data/db:/var/lib/postgresql/data` permet de persister la base de données. - Le montage `./data/db:/var/lib/postgresql/data` permet de persister la base de données.
- Le montage `./docker/db/sql/:/sql` vous permet de remplacer les scripts SQL - Si vous voulez substituer les scripts SQL de création/peuplement des objets de la base de données par les vôtres,
de création/peuplement des objets de la base de données par les vôtres le cas échéant. ajoutez un montage du genre `--volume $PWD/mes/scripts/sql/:/sql`.
## Utilisation dans un `docker-compose.yml` ## Utilisation dans un `docker-compose.yml`
...@@ -53,6 +65,7 @@ services: ...@@ -53,6 +65,7 @@ services:
container_name: sygal-db-container container_name: sygal-db-container
restart: always restart: always
environment: environment:
POSTGRES_USER: postgres
POSTGRES_PASSWORD: admin POSTGRES_PASSWORD: admin
ports: ports:
- 5432:5432 - 5432:5432
......
#!/bin/bash #!/bin/bash
set -e set -e
cd /sql # volume
unset PGHOST PGPORT PGDATABASE PGUSER PGPASSWORD # précaution unset PGHOST PGPORT PGDATABASE PGUSER PGPASSWORD # précaution
#
# Création de la base 'sygal' et du user 'ad_sygal'.
#
export \ export \
PGDATABASE=$POSTGRES_DB \ PGDATABASE=$POSTGRES_DB \
PGUSER=$POSTGRES_USER \ PGUSER=$POSTGRES_USER \
ON_ERROR_STOP=1 ON_ERROR_STOP=1
psql <<EOF
create database sygal with ENCODING = 'UTF-8';
create user ad_sygal with encrypted password 'azerty' NOSUPERUSER NOCREATEDB;
grant all privileges on database sygal to ad_sygal;
EOF
psql -f 01_create_db_user.sql #
psql -c "alter user ad_sygal with encrypted password 'azerty'" # Création d'objets divers dans la base 'sygal'.
# NB : il est possible de substituer ces scripts par les vôtres grâce à un volume monter dans `/sql`.
#
export \ export \
PGDATABASE=sygal \ PGDATABASE=sygal \
PGUSER=ad_sygal \ PGUSER=ad_sygal \
PGPASSWORD=azerty PGPASSWORD=azerty
psql <<EOF
psql -f 02_create_schema.sql CREATE EXTENSION unaccent WITH SCHEMA public;
psql -f 03_insert_bootstrap_data.sql COMMENT ON EXTENSION unaccent IS 'text search dictionary that removes accents';
psql -f 04_insert_data.sql EOF
psql -f 05_create_constraints.sql #
psql -f 06_create_comue.sql # Exécution de tous les scripts .sql présents dans le répertoire `/sql`
psql -f 07_init.sql # pour créer/peupler les objets de la base 'sygal'.
psql -f 08_create_fixture.sql # NB : il est possible de substituer ces scripts par les vôtres grâce à un volume monter dans `/sql`.
#
cd /sql
for f in *.sql; do
psql -f $f
done
unset PGHOST PGPORT PGDATABASE PGUSER PGPASSWORD # précaution unset PGHOST PGPORT PGDATABASE PGUSER PGPASSWORD # précaution
--
-- DATABASE, USER, ETC.
--
-- Databases
create database sygal with ENCODING = 'UTF-8';
-- Users
create user ad_sygal with encrypted password 'MOT_DE_PASSE_PAR_DEFAUT' NOSUPERUSER NOCREATEDB;
-- Grants
grant all privileges on database sygal to ad_sygal;
0% Loading or .
You are about to add 0 people to the discussion. Proceed with caution.
Please register or to comment