系列教程丨用 Docker 探索开源软件 —— PostgreSQL(二)

本文涉及的产品
云原生数据库 PolarDB MySQL 版,Serverless 5000PCU 100GB
简介: Docker 的一大优点是可以让您快速使用它来试用应用程序,而无需直接在开发人员的计算机上安装它。如果您不想在自己的计算机上安装 Java 或 erlang 等运行时环境,那么您就可以不安装它们......

screenshot

出品丨Docker公司(ID:docker-cn)
编译丨小东
每周一、三、五,与您不见不散!


Docker 的一大优点是可以让您快速使用它来试用应用程序,而无需直接在开发人员的计算机上安装它。如果您不想在自己的计算机上安装 Java 或 erlang 等运行时环境,那么您就可以不安装它们,因为容器封装了所有依赖项,并在删除时可以不留下任何痕迹。在上一篇文章《系列教程丨用 Docker 探索开源软件 —— PostgreSQL(一)》中,我们介绍了 Docker Volumes 是如何运行的,今天,我将带来本篇文章的第二部分内容。


停止并重新启动容器

让我们验证一下,如果我们停止并重新启动容器,我们将不会丢失数据。

docker stop postgres1
docker start postgres1

与其再次连接到这个容器,不如从另一个连接的容器进行测试,使用与在 Redis 演示中看到的连接容器相同的技术。

docker run -it --rm --link postgres1:pg --name client1 postgres sh

启动“psql”,但连接到另一个容器(-h),我们给它们命名为“pg”:

# psql -U postgres -h pg mydb

现在,通过这个“client1”容器,我们可以访问存储在“postgres1” 数据库容器中的数据:

mydb=# SELECT * FROM people;
 id | name
----+------
 1 | Mark
(1 row)

现在,我们可以退出“psql”以及我们的 shell,这将删除“client1”容器,因为我们使用了“—rm”标志,以便在容器退出时自动删除该容器。

mydb=# \q
# exit

检查 volume

我们可以找到有关使用“docker volume inspect”创建的 volume 信息,包括我们本地磁盘上存储该 volume 中数据的位置。下面是一些典型的输出:

$ docker volume inspect postgres-data
[
   {
       "CreatedAt": "2018-09-03T19:50:23Z",
       "Driver": "local",
       "Labels": null,
       "Mountpoint": "/var/lib/docker/volumes/postgres-data/_data",
       "Name": "postgres-data",
       "Options": null,
       "Scope": "local"
   }
]

如果我们查看 Docker 主机上的本地文件夹,我们就可以看到该 volume 中存储的所有数据。

$ ls /var/lib/docker/volumes/postgres-data/_data/
PG_VERSION           pg_multixact         pg_tblspc
base                 pg_notify            pg_twophase
global               pg_replslot          pg_wal
pg_commit_ts         pg_serial            pg_xact
pg_dynshmem          pg_snapshots         postgresql.auto.conf
pg_hba.conf          pg_stat              postgresql.conf
pg_ident.conf        pg_stat_tmp          postmaster.opts
pg_logical           pg_subtrans          postmaster.pid

显然,Docker volume 不需要存储在 Docker 主机上的本地磁盘中。在像 Azure 这样的生产环境中,您很可能将 Azure 文件共享作为 volume 挂载。


丢弃容器,但保留数据

让我们使用一个命令停止并删除“postgres1”容器(-f强制它删除正在运行的容器)。因为数据存储在 volume 中,所以它仍然是安全的。

docker rm -f postgres1

将现有 volume 附加到新容器

现在让我们启动一个名为postgres2的全新容器,但是要附加包含我们现有数据库的“postgres-data”volume:

docker run -d -p 5432:5432 -v postgres-data:/var/lib/postgresql/data --name postgres2 postgres

启动后,让我们在其中运行一个“psql”会话,并检查数据库、表和数据是否仍然存在且正确:

docker exec -it postgres2 sh
# psql -U postgres mydb
mydb=# SELECT * FROM people;
 id | name
----+-------
 1 | Mark
(1 row)

然后再次退出:

mydb=# \q
# exit

清理一切

现在,我们来清理一下。我们不仅要删除“postgres2”容器,还要删除“postgres-data”volume。所以,此时数据库的内容也被删除了。

docker rm -f postgres2
docker volume rm postgres-data

总 结

如您所件,Docker 不仅可以让您轻松使用 PostgreSQL,还可以轻松配置 volume,从而可以独立于容器的生命周期管理数据的生命周期。如果愿意,我们还可以直接连接到5432端口上的这个 PostgreSQL 容器,并将其用于一些本地开发。

在下一篇系列文章中,我将向您展示如何在容器中运行 Elasticsearch,这将使我们有机会探索 docker-compose 的实际应用。

相关实践学习
使用PolarDB和ECS搭建门户网站
本场景主要介绍基于PolarDB和ECS实现搭建门户网站。
阿里云数据库产品家族及特性
阿里云智能数据库产品团队一直致力于不断健全产品体系,提升产品性能,打磨产品功能,从而帮助客户实现更加极致的弹性能力、具备更强的扩展能力、并利用云设施进一步降低企业成本。以云原生+分布式为核心技术抓手,打造以自研的在线事务型(OLTP)数据库Polar DB和在线分析型(OLAP)数据库Analytic DB为代表的新一代企业级云原生数据库产品体系, 结合NoSQL数据库、数据库生态工具、云原生智能化数据库管控平台,为阿里巴巴经济体以及各个行业的企业客户和开发者提供从公共云到混合云再到私有云的完整解决方案,提供基于云基础设施进行数据从处理、到存储、再到计算与分析的一体化解决方案。本节课带你了解阿里云数据库产品家族及特性。
相关文章
|
1月前
|
关系型数据库 MySQL Java
Docker Compose详细教程(从入门到放弃)
Docker Compose详细教程(从入门到放弃)
135 0
|
1月前
|
关系型数据库 Java 数据库连接
PostgreSQL从小白到高手教程 - 第47讲:JMETER工具使用
PostgreSQL从小白到高手教程 - 第47讲:JMETER工具使用
106 3
|
1月前
|
Oracle 关系型数据库 数据库
|
3月前
|
关系型数据库 MySQL 数据库
百度搜索:蓝易云【【Docker】Docker部署Mysql并设置数据持久化教程】
通过以上步骤,您已经成功地在Docker中部署了MySQL,并设置了数据持久化,确保数据在容器重新启动或迁移时得以保留。
50 0
|
3月前
|
大数据 数据管理 Docker
【Datahub系列教程】Datahub入门必学——DatahubCLI之Docker命令详解
【Datahub系列教程】Datahub入门必学——DatahubCLI之Docker命令详解
218 0
|
24天前
|
jenkins Java 持续交付
Docker搭建持续集成平台Jenkins最简教程
Jenkins 是一个广泛使用的开源持续集成工具,它能够自动化构建、测试和部署软件项目。在本文中,我们将使用 Docker 搭建一个基于 Jenkins 的持续集成平台。
108 2
|
28天前
|
负载均衡 监控 关系型数据库
PostgreSQL从小白到高手教程 - 第48讲:PG高可用实现keepalived
PostgreSQL技术大讲堂 - 第48讲:PG高可用实现keepalived
64 1
|
29天前
|
关系型数据库 分布式数据库 PolarDB
PolarDB常见问题之安装gms时出现docker如何解决
PolarDB是阿里云推出的下一代关系型数据库,具有高性能、高可用性和弹性伸缩能力,适用于大规模数据处理场景。本汇总囊括了PolarDB使用中用户可能遭遇的一系列常见问题及解答,旨在为数据库管理员和开发者提供全面的问题指导,确保数据库平稳运行和优化使用体验。
|
30天前
|
JavaScript Java jenkins
如何利用CentOS7+docker+jenkins+gitee部署springboot+vue前后端项目(保姆教程)
如何利用CentOS7+docker+jenkins+gitee部署springboot+vue前后端项目(保姆教程)
78 0
|
1月前
|
SQL 关系型数据库 OLAP
PostgreSQL从小白到高手教程 - 第46讲:poc-tpch测试
PostgreSQL从小白到高手教程 - 第46讲:poc-tpch测试
83 3