ubuntu22.04 docker-compose安装postgresql数据库

在 Ubuntu 22.04 上使用 Docker Compose 来安装和运行 PostgreSQL 数据库的过程如下:

1. 创建 Docker Compose 文件

在项目文件夹中创建一个 docker-compose.yml 文件,以配置 PostgreSQL 数据库的服务。

bash 复制代码
mkdir postgres_docker
cd postgres_docker
touch docker-compose.yml

2. 配置 docker-compose.yml

docker-compose.yml 中定义 PostgreSQL 服务的配置,设置数据库名称、用户名和密码等。

yaml 复制代码
version: '3.8'

services:
  postgres:
    image: postgres:14  # 使用 PostgreSQL 14 版本,你可以选择其他版本
    container_name: postgres_container  # 容器名称
    environment:
      POSTGRES_DB: mydatabase  # 数据库名称
      POSTGRES_USER: myuser    # 数据库用户名
      POSTGRES_PASSWORD: mypassword  # 数据库密码
    volumes:
      - pg_data:/var/lib/postgresql/data  # 持久化数据卷
    ports:
      - "5432:5432"  # 映射端口

volumes:
  pg_data:

3. 运行 Docker Compose

在终端中运行以下命令来启动 PostgreSQL 容器:

bash 复制代码
docker-compose up -d

这个命令会下载 PostgreSQL 的 Docker 镜像并启动容器。

4. 验证 PostgreSQL 是否运行

要确认 PostgreSQL 容器是否已成功启动,可以使用以下命令查看正在运行的容器:

bash 复制代码
docker ps

你应该会看到一个名为 postgres_container 的容器在端口 5432 上运行。

5. 连接到 PostgreSQL 数据库

可以使用 psql 客户端连接到 PostgreSQL 数据库,或者通过任何 PostgreSQL GUI 工具(如 DBeaver、pgAdmin)连接。也可以直接进入容器并使用 psql

bash 复制代码
docker exec -it postgres_container psql -U myuser -d mydatabase

这将打开 psql 命令行界面,连接到 mydatabase 数据库。

6. 停止和删除容器

如果想停止并删除容器,可以使用以下命令:

bash 复制代码
docker-compose down

这将停止 PostgreSQL 容器,并释放端口 5432

完整配置总结

现在,你的 docker-compose.yml 文件中配置了 PostgreSQL,并且数据将保存在一个持久化卷中。你可以通过端口 5432 访问 PostgreSQL 数据库,并根据需要修改 POSTGRES_DBPOSTGRES_USERPOSTGRES_PASSWORD 的值来设置数据库名称、用户名和密码。

相关推荐
time never ceases10 分钟前
使用docker方式进行Oracle数据库的物理迁移(helowin/oracle_11g)
数据库·docker·oracle
Frank牛蛙14 分钟前
1.每日SQL----2024/11/7
数据库·sql
Ciderw16 分钟前
块存储、文件存储和对象存储详细介绍
网络·数据库·nvme·对象存储·存储·块存储·文件存储
薛晓刚17 分钟前
数据库优化指南:如何将基本功能运用到极致?
数据库
stars_User20 分钟前
MySQL数据库面试题(下)
数据库·mysql
未来之窗软件服务1 小时前
sql速度优化多条合并为一条语句
数据库
山东布谷科技官方1 小时前
布谷直播源码部署服务器关于数据库配置的详细说明
运维·服务器·数据库·直播系统源码·直播源码·直播系统搭建·直播软件开发
易云码1 小时前
信息安全建设方案,网络安全等保测评方案,等保技术解决方案,等保总体实施方案(Word原件)
数据库·物联网·安全·web安全·低代码
newxtc1 小时前
【客观理性深入讨论国产中间件及数据库-科创基础软件】
数据库·中间件·国产数据库·国产中间件·科创
水月梦镜花1 小时前
redis:list列表命令和内部编码
数据库·redis·list