DeepSeek总结的使用 Docker 对 PostgreSQL 进行 Beta 测试
来源: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:
dockerbuildx build-tpostgres:19beta1-trixie\'https://github.com/infosiftr/postgres.git#19-rc:19/trixie'构建完成后,我可以使用postgres:19beta1-trixie调用docker run。我将其命名为pg19。
我还根据我运行其他 Docker Postgres 容器的方式传递了以下环境变量(这些选项可能不是必需的)。
最终命令:
dockerrun\--namepg19\--envPOSTGRES_USER=postgres\--envPOSTGRES_PASSWORD=postgres\--detachpostgres:19beta1-trixie要检查它是否正在运行,我运行docker ps -a。要查看日志,我会运行:docker logs -f postgres:19beta1-trixie。
通过 psql 连接
容器正在运行,日志显示了我们想要的信息:“database system is ready to accept connections”。
让我们使用容器上的psql连接到postgres数据库:
dockercontainerexec-itpg19 psql-Upostgres我们应该会看到类似显示版本 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;QUERYPLAN-----------------------------------------------------Seq Scanont(cost=0.00..35.50rows=2550width=4)GeneratedPlanAdvice: SEQ_SCAN(t)NO_GATHER(t)(4rows)我想知道为什么默认的行数估计是 2550?让我们运行analyze t;。
这样做之后,估计行数变为 1,看起来更合理了:
postgres=# EXPLAIN (PLAN_ADVICE) SELECT * FROM t;QUERYPLAN-------------------------------------------------Seq Scanont(cost=0.00..0.00rows=1width=4)GeneratedPlanAdvice: SEQ_SCAN(t)NO_GATHER(t)(4rows)pg_stat_statements的新增功能
扩展pg_stat_statements在 19 中获得了新功能。
让我们试试:
postgres=# select * from pg_stat_statements;ERROR: relation"pg_stat_statements"doesnotexist哦,我们需要先将其添加到shared_preload_libraries。我们可以看到目前情况并非如此:
postgres=# show shared_preload_libraries;shared_preload_libraries--------------------------(1row)使用docker run实现这一点的一种方法是使用-c参数,如下所示:
dockerrun\--namepg19\--envPOSTGRES_USER=postgres\--envPOSTGRES_PASSWORD=postgres\--detachpostgres:19beta1-trixie\-cshared_preload_libraries=pg_stat_statements现在我们在shared_preload_libraries中看到了我们想要的内容:
postgres=# show shared_preload_libraries;shared_preload_libraries--------------------------pg_stat_statements(1row)不过,鉴于\dx没有列出它,我们还没有启用该扩展。让我们这样做:
psql>createextensionifnotexistspg_stat_statements;现在\dx显示它,我们已经准备好查询它了。
新增功能之一是跟踪预备语句的使用。让我们创建一个基础表和一个预备语句。
如果需要,再次创建表:
createtableifnotexistst(idint);创建一个简单的预备语句get_t并执行它。这里的目标是让pg_stat_statements增加generic_plan_calls字段。
PREPAREget_tASSELECT*FROMt;现在让我们执行它:
EXECUTEget_t;它起作用了吗?
postgres=# select left(query,100),generic_plan_calls from pg_stat_statements limit 1;left|generic_plan_calls------------------+--------------------PREPAREget_tAS+|1SELECT*+|FROMt|它起作用了!我们看到generic_plan_calls已经递增。
这对于监控预备语句的使用情况看起来非常有用。
总结
请尝试一下,并实验 Postgres 19 中的新功能!
添加 19.x 版本(当前为 beta 1)
https://github.com/docker-library/postgres/pull/1415
