DeepSeek总结的使用 Docker 对 PostgreSQL 进行 Beta 测试
本文介绍了如何使用Docker容器测试PostgreSQL 19 Beta 1版本。作者详细说明了通过Docker构建预发布镜像的步骤,包括获取适合操作系统的Docker版本和使用docker buildx命令构建特定版本。文中演示了启动容器、连接数据库以及测试PostgreSQL 19的新功能,如pg_stat_lock视图、pg_plan_advice扩展和pg_stat_statements
来源:https://andyatkinson.com/postgresql-beta-testing-docker
使用 Docker 对 PostgreSQL 进行 Beta 测试
作者: Andy Atkinson
日期: 未注明
分类: PostgreSQL 数据库
Postgres 社区非常重视对 Beta 版本进行测试的反馈,而借助 Docker,可以更轻松地启动和运行预发布版本。
随着最近 PostgreSQL 19 Beta 1 的发布,让我们启动它并测试一些新功能。
使用 Docker 获取 Postgres 预发布版本
首先,你需要为你的操作系统安装 Docker!为你的操作系统和处理器架构(例如 ARM 或 AMD/Intel/x86)获取所需的版本。
在 MacOS 上,运行 uname -m 或 sw_vers 来了解你的硬件细节。
对于 Windows,请查看《在 Windows 上安装 Docker Desktop》。
构建和运行
用于 Docker Postgres 的官方 Postgres 镜像仅限于正式发布版本。
幸运的是,@yosifkit 创建了一个 PR,添加了 19 Beta 1(由 @tianon 合并),并提供了如何使用 docker buildx 构建预发布版本的说明。
以下命令会下载并构建 postgres:19beta1-trixie:
docker buildx build -t postgres:19beta1-trixie \
'https://github.com/infosiftr/postgres.git#19-rc:19/trixie'
构建完成后,我可以使用 postgres:19beta1-trixie 调用 docker run。我将其命名为 pg19。
我还根据我运行其他 Docker Postgres 容器的方式传递了以下环境变量(这些选项可能不是必需的)。
最终命令:
docker run \
--name pg19 \
--env POSTGRES_USER=postgres \
--env POSTGRES_PASSWORD=postgres \
--detach postgres:19beta1-trixie
要检查它是否正在运行,我运行 docker ps -a。要查看日志,我会运行:docker logs -f postgres:19beta1-trixie。
通过 psql 连接
容器正在运行,日志显示了我们想要的信息:“database system is ready to accept connections”。
让我们使用容器上的 psql 连接到 postgres 数据库:
docker container exec -it pg19 psql -U postgres
我们应该会看到类似显示版本 19 的输出:
psql (19beta1 (Debian 19~beta1-1.pgdg13+1))
Type "help" for help.
在 19 中测试新功能
太好了。让我们尝试一下 19 中的一些新功能。
19 添加了一个用于查看锁的新系统视图。让我们试试:
postgres=# select * from pg_stat_lock;
我们得到了很多新数据,比如等待计数、等待时间等等。
那新的 pg_plan_advice 扩展呢?首先,让我们加载它,然后创建一个表 t 进行实验:
postgres=# LOAD 'pg_plan_advice';
postgres=# create table t (id int);
完成后,我们可以使用新的 PLAN_ADVICE 参数通过 EXPLAIN 显示输出:
postgres=# EXPLAIN (PLAN_ADVICE) SELECT * FROM t;
QUERY PLAN
-----------------------------------------------------
Seq Scan on t (cost=0.00..35.50 rows=2550 width=4)
Generated Plan Advice:
SEQ_SCAN(t)
NO_GATHER(t)
(4 rows)
我想知道为什么默认的行数估计是 2550?让我们运行 analyze t;。
这样做之后,估计行数变为 1,看起来更合理了:
postgres=# EXPLAIN (PLAN_ADVICE) SELECT * FROM t;
QUERY PLAN
-------------------------------------------------
Seq Scan on t (cost=0.00..0.00 rows=1 width=4)
Generated Plan Advice:
SEQ_SCAN(t)
NO_GATHER(t)
(4 rows)
pg_stat_statements 的新增功能
扩展 pg_stat_statements 在 19 中获得了新功能。
让我们试试:
postgres=# select * from pg_stat_statements;
ERROR: relation "pg_stat_statements" does not exist
哦,我们需要先将其添加到 shared_preload_libraries。我们可以看到目前情况并非如此:
postgres=# show shared_preload_libraries;
shared_preload_libraries
--------------------------
(1 row)
使用 docker run 实现这一点的一种方法是使用 -c 参数,如下所示:
docker run \
--name pg19 \
--env POSTGRES_USER=postgres \
--env POSTGRES_PASSWORD=postgres \
--detach postgres:19beta1-trixie \
-c shared_preload_libraries=pg_stat_statements
现在我们在 shared_preload_libraries 中看到了我们想要的内容:
postgres=# show shared_preload_libraries;
shared_preload_libraries
--------------------------
pg_stat_statements
(1 row)
不过,鉴于 \dx 没有列出它,我们还没有启用该扩展。让我们这样做:
psql> create extension if not exists pg_stat_statements;
现在 \dx 显示它,我们已经准备好查询它了。
新增功能之一是跟踪预备语句的使用。让我们创建一个基础表和一个预备语句。
如果需要,再次创建表:
create table if not exists t (id int);
创建一个简单的预备语句 get_t 并执行它。这里的目标是让 pg_stat_statements 增加 generic_plan_calls 字段。
PREPARE get_t AS
SELECT *
FROM t;
现在让我们执行它:
EXECUTE get_t;
它起作用了吗?
postgres=# select left(query,100),generic_plan_calls from pg_stat_statements limit 1;
left | generic_plan_calls
------------------+--------------------
PREPARE get_t AS+| 1
SELECT * +|
FROM t |
它起作用了!我们看到 generic_plan_calls 已经递增。
这对于监控预备语句的使用情况看起来非常有用。
总结
请尝试一下,并实验 Postgres 19 中的新功能!
添加 19.x 版本(当前为 beta 1)
https://github.com/docker-library/postgres/pull/1415
更多推荐


所有评论(0)