Docker Desktop 安装

Docker Desktop 安装 PostgreSQL 并挂载本地卷

在开发环境中,PostgreSQL 是一个非常受欢迎的开源关系型数据库。通过 Docker Desktop,我们可以轻松地在本地安装并运行 PostgreSQL,同时利用 Docker 的卷功能来实现数据的持久化,确保即使容器被删除,数据也不会丢失。

一、准备工作

确保你已经安装了 Docker Desktop。如果尚未安装,请从 Docker 官方网站 下载并安装。

二、拉取 PostgreSQL 镜像

打开终端或命令提示符,运行以下命令来拉取 PostgreSQL 的官方镜像:

复制代码
docker pull postgres

这会从 Docker Hub 下载最新的 PostgreSQL 镜像到你的本地机器。

三、创建本地目录

为了实现数据持久化,我们需要创建一个本地目录来存储 PostgreSQL 的数据。运行以下命令来创建目录(根据你的需求修改路径):

bash 复制代码
mkdir -p /path/to/postgres/data

在 Windows 上,路径可能类似于 C:\ProgramData\Docker\Containers\postgres\data

四、运行 PostgreSQL 容器并挂载本地卷

使用以下命令运行 PostgreSQL 容器,并将本地目录挂载到容器内的数据目录:

kotlin 复制代码
docker run -d -p 5432:5432 --name mypostgres -e POSTGRES_PASSWORD=mysecretpassword -v C:\ProgramData\Docker\Containers\postgres\data/data:/var/lib/postgresql/data postgres

这条命令的含义如下:

  • -d:后台运行容器。
  • -p 5432:5432:将容器的 5432 端口映射到宿主机的 5432 端口。
  • --name mypostgres:为容器命名为 mypostgres
  • -e POSTGRES_PASSWORD=mysecretpassword:设置 PostgreSQL 默认用户 postgres 的密码。
  • -v /path/to/postgres/data:/var/lib/postgresql/data:将本地目录挂载到容器内的 /var/lib/postgresql/data 目录,实现数据持久化。

五、验证容器运行状态

运行以下命令来查看所有正在运行的容器,确认 PostgreSQL 容器已经启动:

复制代码
docker ps

你应该能看到名为 mypostgres 的容器正在运行。

六、连接到 PostgreSQL 数据库

你可以使用任何 PostgreSQL 客户端工具连接到数据库。以下是一些常见的连接方式:

使用命令行工具

bash 复制代码
docker exec -it mypostgres psql -U postgres

这将打开 PostgreSQL 的命令行界面,你可以在这里执行 SQL 命令。

使用 pgAdmin

如果你使用的是 pgAdmin,可以通过以下连接信息连接到数据库:

  • Hostlocalhost
  • Port5432
  • Usernamepostgres
  • Password:你在启动容器时设置的密码。

七、数据持久化验证

为了验证数据是否持久化,你可以:

  1. 在数据库中创建一个表并插入一些数据。

  2. 停止并删除容器:

    arduino 复制代码
    docker stop mypostgres
    docker rm mypostgres
  3. 重新运行容器:

    kotlin 复制代码
    docker run -d -p 5432:5432 --name mypostgres -e POSTGRES_PASSWORD=mysecretpassword -v /path/to/postgres/data:/var/lib/postgresql/data postgres
  4. 连接到数据库,检查之前创建的表和数据是否仍然存在。

八、总结

通过上述步骤,我们成功地在 Docker Desktop 上安装了 PostgreSQL,并通过挂载本地卷实现了数据的持久化。这种方式不仅简化了 PostgreSQL 的安装和配置过程,还确保了数据的安全性和持久性,非常适合开发和测试环境。

如果你在操作过程中遇到任何问题,可以参考 Docker 和 PostgreSQL 的官方文档,或者在相关社区寻求帮助。希望这篇文章能帮助你更好地利用 Docker Desktop 和 PostgreSQL,提升你的开发效率。

相关推荐
Vitalia2 分钟前
从零开始学Rust:枚举(enum)与模式匹配核心机制
开发语言·后端·rust
飞飞翼26 分钟前
python-flask
后端·python·flask
草捏子2 小时前
最终一致性避坑指南:小白也能看懂的分布式系统生存法则
后端
一个public的class2 小时前
什么是 Java 泛型
java·开发语言·后端
头孢头孢3 小时前
k8s常用总结
运维·后端·k8s
TheITSea3 小时前
后端开发 SpringBoot 工程模板
spring boot·后端
Asthenia04123 小时前
编译原理中的词法分析器:从文本到符号的桥梁
后端
Asthenia04124 小时前
用RocketMQ和MyBatis实现下单-减库存-扣钱的事务一致性
后端
Pasregret4 小时前
04-深入解析 Spring 事务管理原理及源码
java·数据库·后端·spring·oracle
Micro麦可乐4 小时前
最新Spring Security实战教程(七)方法级安全控制@PreAuthorize注解的灵活运用
java·spring boot·后端·spring·intellij-idea·spring security