当前位置:   article > 正文

Docker部署PostgreSQL数据库_docker postgresql

docker postgresql

PostgreSQL

# 在u01目录下创建postgres目录
mkdir postgres
# 需要赋权不然部署时会报错
sudo chown 777 /u01/postgres/
cd postgres
# data映射postgres数据
mkdir data
  • 1
  • 2
  • 3
  • 4
  • 5
  • 6
  • 7
  • 拉取镜像并部署
# 拉取postgres镜像
docker pull postgres:16
# 部署postgres命令
docker run -d --name postgres \
-p 5432:5432 \
--privileged=true \
-e POSTGRES_USER=root \
-e POSTGRES_PASSWORD="ta50oU4WUTq/4NuMDwIzp05BdKp7Bdmf" \
-e POSTGRES_DB=coder \
-e PGDATA="/var/lib/postgresql/data" \
-v ./postgres/data:/var/lib/postgresql/data \
postgres:16
  • 1
  • 2
  • 3
  • 4
  • 5
  • 6
  • 7
  • 8
  • 9
  • 10
  • 11
  • 12

docker-compose.yml

通过docker-compose部署postgres服务

version: '3'
services:
  postgres:
    image: postgres:16
    container_name: postgres
    # 容器设置为特权模式
    privileged: true
    # restart: always
    ports:
      - '5432:5432'
    environment:
      # 创建具有超级用户权限的指定用户和同名的数据库
      POSTGRES_USER: 'root'
      POSTGRES_PASSWORD: 'ta50oU4WUTq/4NuMDwIzp05BdKp7Bdmf'
      # 如果未指定,则将POSTGRES_USER使用的值。
      POSTGRES_DB: 'coder'
      # 默认为/var/lib/postgresql/data
      PGDATA: /var/lib/postgresql/data
    volumes:
      - /etc/localtime:/etc/localtime
      - ./postgres/data:/var/lib/postgresql/data
  • 1
  • 2
  • 3
  • 4
  • 5
  • 6
  • 7
  • 8
  • 9
  • 10
  • 11
  • 12
  • 13
  • 14
  • 15
  • 16
  • 17
  • 18
  • 19
  • 20
  • 21

配置外网访问

访问IP

  • pg_hba.conf文件在data目录下
# IPv4 local connections:
host    all             all             0.0.0.0/0               trust
  • 1
  • 2

METHOD的ident修改为trust,可以实现用账户和密码来访问数据库

监听地址

  • postgresql.conf文件在data目录下
listen_addresses = '*'
  • 1
声明:本文内容由网友自发贡献,不代表【wpsshop博客】立场,版权归原作者所有,本站不承担相应法律责任。如您发现有侵权的内容,请联系我们。转载请注明出处:https://www.wpsshop.cn/w/空白诗007/article/detail/791572
推荐阅读
相关标签
  

闽ICP备14008679号