记录一次docker安装postgresql(pg)数据库容器后异常关机后启动异常问题

使用docker安装的pg9.5容器,突然云主机升级直接停机后pg数据库容器启动不了后查看容器日志提示以下内容,

解决:按提示将容器的配置文件复制出来后修改后再复制到容器中

 sudo docker cp pg_hba.conf 4d62f4628665:/var/lib/postgresql/data/pg_hba.conf  //将本地配置文件复制到容器中

sudo docker cp 4d62f4628665:/var/lib/postgresql/data/pg_hba.conf .    //将容器配置文件复制到当前目录中

 

LOG:  syntax error in file "/var/lib/postgresql/data/postgresql.conf" line 1, near token "*"
FATAL:  configuration file "/var/lib/postgresql/data/postgresql.conf" contains errors

listen_addresses =¡¯*¡¯  改为  listen_addresses = "*"后报以下错误:

LOG:  syntax error in file "/var/lib/postgresql/data/postgresql.conf" line 1, near token """
FATAL:  configuration file "/var/lib/postgresql/data/postgresql.conf" contains errors

listen_addresses = "*"改为  listen_addresses = '*'后启动正常

LOG:  invalid connection type "*host"
CONTEXT:  line 6 of configuration file "/var/lib/postgresql/data/pg_hba.conf"
FATAL:  could not load pg_hba.conf

PostgreSQL Database directory appears to contain a database; Skipping initialization

# TYPE DATABASE  USER    CIDR-ADDRESS     METHOD
 # "local" is for Unix domain socket connections only
 local all    all               trust
 # IPv4 local connections:
 host  all    all    127.0.0.1/32     trust

*host  all    all    0.0.0.1/0    md5* 
 # IPv6 local connections:
 host  all    all    ::1/128       trust

LOG:  invalid authentication method "md5*"
CONTEXT:  line 6 of configuration file "/var/lib/postgresql/data/pg_hba.conf"

*host  all    all    0.0.0.1/0    md5*  将这行的*都去掉就可以了

 

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
要在Docker安装和运行PostgreSQL数据库,您可以按照以下步骤操作: 1. 首先,确保您已经安装DockerDocker Compose。您可以在官方网站上找到相应的安装说明。 2. 创建一个新的文件夹,并在文件夹中创建一个名为`docker-compose.yml`的文件。 3. 打开`docker-compose.yml`文件并添加以下内容: ```yaml version: '3.8' services: postgres: image: postgres restart: always ports: - 5432:5432 environment: POSTGRES_USER: your_username POSTGRES_PASSWORD: your_password POSTGRES_DB: your_database_name ``` 在上述代码中,您需要将`your_username`,`your_password`和`your_database_name`替换为您想要使用的实际值。 4. 保存并关闭`docker-compose.yml`文件。 5. 打开终端或命令提示符,导航到包含`docker-compose.yml`文件的文件夹。 6. 运行以下命令以启动PostgreSQL容器: ``` docker-compose up -d ``` 这将下载并启动PostgreSQL容器。 `-d`选项将使容器在后台运行。 7. 等待一段时间,直到容器启动完成。您可以使用以下命令检查容器的状态: ``` docker ps ``` 如果您看到名为`postgres`的容器正在运行,那么PostgreSQL已成功安装和运行。 8. 现在,您可以使用各种客户端工具(如pgAdmin、psql等)连接到PostgreSQL数据库。使用以下连接详细信息: - 主机:localhost - 端口:5432 - 用户名:您在`docker-compose.yml`文件中指定的`POSTGRES_USER` - 密码:您在`docker-compose.yml`文件中指定的`POSTGRES_PASSWORD` - 数据库:您在`docker-compose.yml`文件中指定的`POSTGRES_DB` 希望这可以帮助您安装和运行PostgreSQL数据库。如有任何问题,请随时提问。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值