Docker+PostgreSQL数据库

进入docker hub,先搜索postgres,会出来一系列官方镜像,再点积Tags,搜索你的目标版本,例如我使用了16.4-alpine,这是个精简版,体积比较小

1.拉镜像

复制代码
docker pull postgres:16.4-alpine

2.启动docker

bash 复制代码
docker run --name moment_db -p 5432:5432 -e POSTGRES_USER=postgres -e POSTGRES_PASSWORD=.root -d postgres:16.4-alpine

--name moment_db 启动的容器名称

-p 端口映射,宿主机5432映射到docker5432port

-e初始化环境参数,这里初始了用户名和密码

-d 指定docker的镜像名称

3.检测启动

bash 复制代码
docker container ls

或者

nmap 127.0.0.1

两种方法都行,namp需要安装下,windows系统可以在wsl子系统里安装运行。如下图。5432端口已经被打开使用

4.启动和关闭这个docker可以使用

bash 复制代码
docker stop moment_db
docker start moment_db

5.进入docker容器内

bash 复制代码
docker exec -it moment_db /bin/bash

数据目录在 /var/lib/postgresql/data下

接下来做数据库文件永久化保存,避免容器删除带来的数据损失

首先为docker建立专用卷

bash 复制代码
docker volume create --name v_moment_db_data

查看卷,第一个是在容器创建的时候默认卷,第二个是新建专用卷

6.查看卷的信息

bash 复制代码
docker volume inspect v_moment_db_data

"Mountpoint": "/var/lib/docker/volumes/v_test/_data", 就是宿主机的数据同步位置,这里是因为win下面使用了wsl2,所以自动关联到wsl2目录下。

7.关闭并删除刚刚的容器,重新启动一个容器并绑定卷,指令:

bash 复制代码
docker run --name moment_db -v v_moment_db_data:/var/lib/postgresql/data -p 5432:5432 -e POSTGRES_USER=postgres -e POSTGRES_PASSWORD=.root -d postgres:16.4-alpine

8.使用以下指令观察容器结果:

bash 复制代码
docker inspect moment_db

Mounts:部分,可以看Source部分是创建的卷,这个是由docker volume指令创建的,位置在宿主机是固定的,不可更改的,它已经绑定到了docker容器内的"Destination"的路径上

9.也可以直接绑定固定位置不使用官方的create volume

复制代码
docker run --name moment_db -v /home/server/SqlData/MomentDB:/var/lib/postgresql/data -p 5432:5432 -e POSTGRES_USER=postgres -e POSTGRES_PASSWORD=.root -d postgres:16.4-alpine
相关推荐
JIngJaneIL13 分钟前
基于java + vue校园快递物流管理系统(源码+数据库+文档)
java·开发语言·前端·数据库·vue.js
廋到被风吹走27 分钟前
【数据库】【MySQL】分库分表策略 分类、优势与短板
数据库·mysql·分类
_oP_i30 分钟前
Docker 整体架构
docker·容器·架构
杨浦老苏31 分钟前
可视化服务构建器Dock-Dploy
docker·工具·群晖
落世繁华1 小时前
DIFY合同生成全流程开发实践(三、后端接口以及优化方向)
docker·一键部署·dify·合同生成·文字转word
嘻哈baby1 小时前
Redis高可用部署与集群管理实战
数据库·redis·bootstrap
ascarl20102 小时前
Kubernetes 环境 NFS 卡死问题排查与解决纪要
云原生·容器·kubernetes
DolphinDB智臾科技2 小时前
DolphinDB 面向金融交易与定价的统一数据模型
数据库·时序数据库
檀越剑指大厂2 小时前
时序数据库性能之战:金仓数据库如何在复杂场景下反超 InfluxDB?
数据库·时序数据库
计算机毕设VX:Fegn08952 小时前
计算机毕业设计|基于springboot + vue图书借阅管理系统(源码+数据库+文档)
数据库·vue.js·spring boot·后端·课程设计