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

news/2024/11/8 16:43:55 标签: 数据库, docker, postgresql

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

1. 创建 Docker Compose 文件

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

mkdir postgres_docker
cd postgres_docker
touch docker-compose.yml

dockercomposeyml_12">2. 配置 docker-compose.yml

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

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 容器:

docker-compose up -d

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

4. 验证 PostgreSQL 是否运行

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

docker ps

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

5. 连接到 PostgreSQL 数据库

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

docker exec -it postgres_container psql -U myuser -d mydatabase

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

6. 停止和删除容器

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

docker-compose down

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

完整配置总结

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


http://www.niftyadmin.cn/n/5744166.html

相关文章

基于MATLAB的实现垃圾分类Matlab源码

⼀、垃圾分类 如何通过垃圾分类管理,最⼤限度地实现垃圾资源利⽤,减少垃圾处置量,改善⽣存环境质量,是当前世界各国共同关注的迫切问题之⼀。根据国家制定的统⼀标准,现在⽣活垃圾被⼴泛分为四类,分别是可…

.Net IOC理解及代码实现

IOC理解 IoC(Inversion of Control):即控制反转,这是一种设计思想,指将对象的控制权交给IOC容器,由容器来实现对象的创建、管理,程序员只需要从容器获取想要的对象就可以了。DI(Dependency Injection),即依…

【学习笔记】SAP ABAP——OPEN SQL(一)【INTO语句】

【INTO语句】 结构体插入(插入一条语句时) SELECT...INTO [CORRESPONDING FIELDS OF] <wa> FROM <db> WHERE <condition>.内表插入(插入多条语句时) SELECT...INTO|APPENDING [CORRESPONDING FIELDS OF] TABLE <itab>FROM <db> WHERE <con…

计算机网络——HTTP篇

基础篇 IOS七层网络模型 TCP/IP四层模型&#xff1f; 应⽤层&#xff1a;位于传输层之上&#xff0c;主要提供两个终端设备上的应⽤程序之间的通信&#xff0c;它定义了信息交换的格式&#xff0c;消息会交给下⼀层传输层来传输。 传输层的主要任务就是负责向两台设备进程之间…

OpenSSL 生成根证书、中间证书和网站证书

OpenSSL 生成根证书、中间证书和网站证书 一、生成根证书&#xff08;ChinaRootCA&#xff09;二、生成中间 CA&#xff08;GuangDongCA&#xff09;三、生成网站证书&#xff08;gdzwfw&#xff09; 一、生成根证书&#xff08;ChinaRootCA&#xff09; 创建私钥&#xff1a; …

43.第二阶段x86游戏实战2-提取游戏里面的lua

免责声明&#xff1a;内容仅供学习参考&#xff0c;请合法利用知识&#xff0c;禁止进行违法犯罪活动&#xff01; 本次游戏没法给 内容参考于&#xff1a;微尘网络安全 本人写的内容纯属胡编乱造&#xff0c;全都是合成造假&#xff0c;仅仅只是为了娱乐&#xff0c;请不要…

【开源免费】基于SpringBoot+Vue.JS医院管理系统(JAVA毕业设计)

博主说明&#xff1a;本文项目编号 T 062 &#xff0c;文末自助获取源码 \color{red}{T062&#xff0c;文末自助获取源码} T062&#xff0c;文末自助获取源码 目录 一、系统介绍二、演示录屏三、启动教程四、功能截图五、文案资料5.1 选题背景5.2 国内外研究现状5.3 可行性分析…

域名邮箱推荐:安全与稳定的邮件域名邮箱!

域名邮箱推荐及绑定攻略&#xff1f;最好用的域名邮箱服务推荐&#xff1f; 域名邮箱&#xff0c;作为一种个性化且专业的电子邮件服务&#xff0c;越来越受到企业和个人的青睐。烽火将详细介绍域名邮箱登录的全过程&#xff0c;从注册到登录&#xff0c;帮助您轻松掌握这一重…