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,提升你的开发效率。

相关推荐
有风6311 分钟前
优先级队列详解
后端
雨中飘荡的记忆26 分钟前
ByteBuddy 实战指南
后端
Apifox32 分钟前
Apifox 11 月更新|AI 生成测试用例能力持续升级、JSON Body 自动补全、支持为响应组件添加描述和 Header
前端·后端·测试
有风631 小时前
双向循环带头链表详解
后端
找不到对象就NEW一个1 小时前
用wechatapi进行微信二次开发,微信api
后端
charlie1145141911 小时前
勇闯前后端Week2:后端基础——Flask API速览
笔记·后端·python·学习·flask·教程
有风631 小时前
基于顺序表完成通讯录项目
后端
yuuki2332331 小时前
【C++】初识C++基础
c语言·c++·后端
q***87601 小时前
springboot下使用druid-spring-boot-starter
java·spring boot·后端
程序员西西1 小时前
SpringBoot无感刷新Token实战指南
java·开发语言·前端·后端·计算机·程序员