Как сохранить данные с помощью postgres docker image?
Я пытаюсь сохранить мои данные в /home/me / redmine, чтобы при остановке контейнера не было потери данных. Я использую официальный образ Postgres docker hub.
проблема в том, что каждый раз, когда я запускаю контейнер postgres, он немедленно выходит. Эта проблема началась, когда я добавил "данные" в /var/lib/postgresql, иначе, без добавления "данных", он запускается, но мои данные не сохраняются. Кроме того, путь, который у меня есть на моей хост-машине, - /var/lib/postgresql/9.4/data, но страница изображения говорит использовать /var/lib/postgresql / data.
вот как я пытаюсь запустить / смонтировать том с хоста:
docker run --name postgres -d
--env='DB_NAME=redmine_production'
--env='DB_USER=redmine'
--env='DB_PASS=secret'
--volume=/home/me/redmine/postgresql:/var/lib/postgresql/data
postgres
... а потом после я бы связал redmine следующим образом ...
docker run -d -p 3000:3000 --name redmine
-v /home/me/redmine/files:/usr/src/redmine/files
--link postgres:postgres redmine
в контейнере redmine том /home/me/redmine/files является отдельным каталогом, в котором я пытаюсь сохранить файлы, кроме тех, которые находятся в базе данных Postgres.
Edit:
когда я cd в мои хост-машины /var/lib/postgresql каталог, я нахожу в нем 9.4 / data, а затем увидеть, что владелец и группа не перечислены в my /etc/passwd или /etc/groups, и задаться вопросом, не связано ли это с проблемой.
/var/lib/postgresql/9.4/data # ls -la
total 88
drwx------ 18 70 70 4096 Aug 13 2015 .
drwxr-xr-x 3 root root 4096 Mar 28 2015 ..
drwx------ 8 70 70 4096 Jul 2 2015 base
drwx------ 2 70 70 4096 Jul 2 2015 global
drwx------ 2 70 70 4096 Mar 28 2015 pg_clog
drwx------ 2 70 70 4096 Mar 28 2015 pg_dynshmem
lrwxrwxrwx 1 root root 31 Mar 28 2015 pg_hba.conf -> /etc/postgresql- 9.4/pg_hba.conf
lrwxrwxrwx 1 root root 33 Mar 28 2015 pg_ident.conf -> /etc/postgresql-9.4/pg_ident.conf
drwx------ 4 70 70 4096 Mar 28 2015 pg_logical
drwx------ 4 70 70 4096 Mar 28 2015 pg_multixact
drwx------ 2 70 70 4096 Jul 2 2015 pg_notify
drwx------ 2 70 70 4096 Mar 28 2015 pg_replslot
drwx------ 2 70 70 4096 Mar 28 2015 pg_serial
drwx------ 2 70 70 4096 Mar 28 2015 pg_snapshots
drwx------ 2 70 70 4096 Aug 13 2015 pg_stat
drwx------ 2 70 70 4096 Aug 13 2015 pg_stat_tmp
drwx------ 2 70 70 4096 Mar 28 2015 pg_subtrans
drwx------ 2 70 70 4096 Mar 28 2015 pg_tblspc
drwx------ 2 70 70 4096 Mar 28 2015 pg_twophase
-rw------- 1 70 70 4 Mar 28 2015 PG_VERSION
drwx------ 3 70 70 4096 Mar 28 2015 pg_xlog
-rw------- 1 70 70 88 Mar 28 2015 postgresql.auto.conf
lrwxrwxrwx 1 root root 35 Mar 28 2015 postgresql.conf -> /etc/postgresql-9.4/postgresql.conf
-rw------- 1 70 70 1626 Aug 13 2015 postmaster.log
-rw------- 1 70 70 114 Jul 2 2015 postmaster.opts
мысли?
1 ответов
во-первых, эти переменные среды выглядят подозрительно. Взгляните на документация для официального изображения Docker и обратите внимание, что вам нужно POSTGRES_DB
, POSTGRES_USER
и POSTGRES_PASSWORD
, а не DB_NAME
, DB_USER
и DB_PASS
.
кроме того, ты, кажется, в основном на правильном пути. Вот полный пример:
во-первых, я запускаю контейнер Postgres. Я нахожу постоянное хранилище где-то за пределами моего домашнего каталога, потому что, как вы уже отметили, файлы не будут принадлежать вам, что может запутать в вашем домашнем каталоге (хотя и не обязательно проблематично):
docker run --rm --name postgres \
-v /tmp/postgres:/var/lib/postgresql/data \
-e POSTGRES_DB=larstest \
-e POSTGRES_USER=lars \
-e POSTGRES_PASSWORD=secret postgres
поскольку это первый раз, когда я начал postgres, указывая на этот каталог данных, мы увидим, что он инициализирует базу данных:
The database cluster will be initialized with locale "en_US.utf8".
The default database encoding has accordingly been set to "UTF8".
The default text search configuration will be set to "english".
Data page checksums are disabled.
fixing permissions on existing directory /var/lib/postgresql/data ... ok
creating subdirectories ... ok
selecting default max_connections ... 100
selecting default shared_buffers ... 128MB
selecting dynamic shared memory implementation ... posix
creating configuration files ... ok
running bootstrap script ... ok
performing post-bootstrap initialization ... ok
syncing data to disk ... ok
Success. You can now start the database server using:
сейчас, из другого окна, я могу подключиться к нему...
$ psql -h 172.17.0.4 -U lars larstest
Password for user lars:
psql (9.5.4, server 9.6.0)
WARNING: psql major version 9.5, server major version 9.6.
Some psql features might not work.
Type "help" for help.
...и создайте некоторые данные:
larstest=# create table testtable (id integer);
CREATE TABLE
larstest=# insert into testtable values (1);
INSERT 0 1
larstest=# select * from testtable;
id
----
1
(1 row)
теперь я выхожу из контейнер:
^CLOG: received fast shutdown request
LOG: aborting any active transactions
FATAL: terminating connection due to administrator command
LOG: autovacuum launcher shutting down
LOG: shutting down
LOG: database system is shut down
мы можем проверить, что он больше не работает:
$ docker ps | grep postgres
но если мы начнем его снова с теми же аргументами командной строки;
docker run --rm --name postgres \
-v /tmp/postgres:/var/lib/postgresql/data \
-e POSTGRES_DB=larstest \
-e POSTGRES_USER=lars \
-e POSTGRES_PASSWORD=secret postgres
мы видим, что он не инициализирует базу данных, так как она уже существует, и сразу переходим к:
LOG: database system was shut down at 2016-10-21 03:13:50 UTC
LOG: MultiXact member wraparound protections are now enabled
LOG: database system is ready to accept connections
LOG: autovacuum launcher started
на данный момент, мы можем повторно подключиться к базе данных и обнаружили, что наши данные все еще существует:
$ psql -h 172.17.0.2 -U lars larstest
Password for user lars:
psql (9.5.4, server 9.6.0)
WARNING: psql major version 9.5, server major version 9.6.
Some psql features might not work.
Type "help" for help.
larstest=# select * from testtable;
id
----
1
(1 row)
это почти все.