14

我无法重新启动 dockerized postgres 数据库(我使用 Core OS)。使用命令在 bash 脚本中启动数据库

# boot.sh
sudo -i -u postgres /usr/lib/postgresql/9.3/bin/postgres -D /var/lib/postgresql/9.3/main -c config_file=/etc/postgresql/9.3/main/postgresql.conf

哪个有效。我有另一个由 confd 调用的脚本,它在某些 etcd 键更改时运行(这部分没问题,文件被正确调用)并且必须重新启动 postgres(不重新加载,因为某些配置更改需要重新启动)。这是我尝试过的主要选项,但失败了...

# restart.sh
sudo -u postgres /usr/lib/postgresql/9.3/bin/pg_ctl --pgdata=/var/lib/postgresql/9.3/main restart

系统地引发错误:

%FATAL:  lock file "postmaster.pid" already exists
%HINT:  Is another postmaster (PID 273) running in data directory "/var/lib/postgresql/9.3/main"?

此外,

# restart.sh
rm /var/lib/postgresql/9.3/main/postmaster.pid
sudo -i -u postgres /usr/lib/postgresql/9.3/bin/postgres -D /var/lib/postgresql/9.3/main -c config_file=/etc/postgresql/9.3/main/postgresql.conf

,

rm /var/lib/postgresql/9.3/main/postmaster.pid
/etc/init.d/postgresql start

,

/etc/init.d/postgresql restart

exec su postgres -c "/usr/lib/postgresql/9.3/bin/postgres -D /var/lib/postgresql/9.3/main -c config_file=/etc/postgresql/9.3/main/postgresql.conf"

失败

ERROR exit status 1

任何想法?先感谢您!

4

1 回答 1

14

对我来说,更改配置并做

$ docker restart <postgres_container>

在主机上工作得很好。

于 2017-05-30T11:36:00.973 回答