2026 年 5 月 19 日到 22 日,PGConf.dev 在全球 PostgreSQL 开发者与用户的注视下开了一场四天的大会。从组织者名单到志愿者、从演讲者到包容性专场,这份周报本质上是一张社区全景图——它告诉你:这个生态正在由谁推动、朝着什么方向走。
组织骨架:七人核心 + 三层委员会
大会的七位组织者——Gwen Shapira、Jonathan Katz、Kaiting Chen、Magnus Hagander、Melanie Plageman、Paul Ramsey、Robert Haas——本身就是 PostgreSQL 生态里的长期贡献者。其中 Melanie Plageman 和 Robert Haas 同时出现在多个委员会里,说明核心人物承担了跨环节的串联工作。
三层委员会的分工很清晰:
- Program Committee(议程委员会):Jacob Champion、Jonathan Katz、Dilip Kumar、Melanie Plageman、Paul Ramsey——决定哪些议题能上台,直接塑造大会的技术方向。
- Tuesday Planning Committee(周二规划委员会):Claire Giordano、Corey Huinker、Matthias van de Meent、Paul Jungwirth、Robert Haas——单独规划周二议程,暗示这一天有特殊定位(通常是社区日或工作坊)。
- Code of Conduct Committee(行为准则委员会):Pavlo Golub、Stacey Haysler、Masahiko Sawada——三人小组,确保大会环境安全包容。
这种"核心组织者 + 专项委员会"的模式不是偶然。PostgreSQL 项目本身就是这样运转的——多个子团队各管一摊,靠少数跨团队的人保持信息流通。大会的组织结构,其实是项目治理结构的镜像。
演讲者阵容:从内核到生态的全覆盖
80+ 位演讲者的名单里,几个名字值得特别关注:
- Andres Freund——近两年 PostgreSQL 性能优化和 I/O 层重构的核心推动者,他的演讲通常直接指向下一个大版本的底层变化。
- Thomas Munro 和 Heikki Linnakangas——两者长期深耕事务系统和存储层,议题大概率涉及并发控制或恢复机制。
- Melanie Plageman——既组织又演讲,她的工作集中在执行器和 I/O 路径,是 v17/v18 性能提升的关键人物。
- Tomas Vondra 和 Peter V Geoghegan——前者关注统计信息与查询规划,后者是 B-tree 索引优化的长期贡献者。
- Noah Misch——发布管理员(Release Manager),他的演讲往往涉及发布流程和版本策略。
- Amit Kapila 和 Dilip Kumar——逻辑复制的核心开发者,这一领域在近几个版本持续演进。
从名单推断,大会的技术覆盖面横跨内核存储、执行器、复制、监控、运维和生态工具。如果你关注某个特定方向,大概率能找到对应的演讲者。
社区周边:两个本地用户组的联动
大会前后,两个 PostgreSQL 用户组借势组织了线下活动:
- Triangle Postgres Users Group(北卡三角区)在 5 月 18 日,大会前一天,组织了一次非正式聚会,由 Valerie Parham-Thompson 牵头。
- PostgreSQL User Group, Paris(巴黎)在 5 月 21 日,大会第三天,组织了自己的聚会,组织者包括 Sébastien DELOBEL、Vincent Mercier、Vik Fearing,演讲者有 Jules Bourdalé 和 Matt Cornillon。
这种"大会 + 本地用户组"的联动模式越来越常见。大会提供全球视野和深度技术内容,本地组提供低门槛的面对面交流。如果你所在城市有 PostgreSQL 用户组,大会期间往往是他们最活跃的窗口。
实践:如何从大会内容中提取可用的技术信号
大会演讲视频和幻灯片通常会在会后一周内发布到 PGConf.dev 官网和 YouTube 频道。与其被动等待,不如主动用几个手段把内容变成可检索的技术笔记。
下面是一个用 PostgreSQL 自身存储和检索大会信息的示例——你可以把演讲者、议题关键词、个人笔记全部放进一张表,后续用全文搜索快速定位:
-- 创建一张大会笔记表
CREATE TABLE pgconf_notes (
id SERIAL PRIMARY KEY,
year INT NOT NULL,
speaker TEXT NOT NULL,
topic TEXT NOT NULL,
keywords TEXT[], -- 关键词数组,方便后续过滤
summary TEXT,
link TEXT, -- 演讲视频或幻灯片链接
created_at TIMESTAMPTZ DEFAULT now()
);
-- 插入几条 2026 年大会的笔记(示例)
INSERT INTO pgconf_notes (year, speaker, topic, keywords, summary, link) VALUES
(2026, 'Andres Freund', 'I/O layer refactoring in v18',
ARRAY['io', 'performance', 'v18'],
'讨论 PostgreSQL v18 中 I/O 路径的重构方向,包括异步 I/O 和更细粒度的缓冲管理。',
'https://www.pgconf.dev/2026/schedule/andres-io-refactoring'),
(2026, 'Melanie Plageman', 'Executor pipeline improvements',
ARRAY['executor', 'pipeline', 'performance'],
'执行器流水线优化:减少上下文切换,提升大查询吞吐。',
'https://www.pgconf.dev/2026/schedule/melanie-executor'),
(2026, 'Amit Kapila', 'Logical replication next steps',
ARRAY['logical-replication', 'decoding', 'v18'],
'逻辑复制在 v18 的演进计划:行过滤、性能优化、冲突处理。',
'https://www.pgconf.dev/2026/schedule/amit-logical-rep');
-- 用关键词数组搜索:找所有涉及 performance 的笔记
SELECT speaker, topic, summary, link
FROM pgconf_notes
WHERE keywords @> ARRAY['performance'];
-- 用全文搜索在 summary 里找关键词
CREATE INDEX ON pgconf_notes USING gin(to_tsvector('english', summary));
SELECT speaker, topic, summary
FROM pgconf_notes
WHERE to_tsvector('english', summary) @@ to_tsquery('english', 'refactoring & performance');
运行前确保你的 PostgreSQL 实例已启动,且 gin 索引扩展可用(默认安装即包含)。你可以把 keywords 和 summary 替换成自己看完视频后整理的真实内容——这张表的价值在于后续检索,而不是初始数据。
包容性专场:不只是口号
Stacey Haysler、Floor Drees、Peter V Geoghegan 三人主持了包容性专场(Inclusivity Sessions)。这类专场在技术大会里经常被边缘化,但在 PostgreSQL 社区,它有实际意义:开源项目的贡献者来源越多样,代码审查和设计讨论的视角就越完整。如果你是第一次参加 PGConf.dev 或准备提交议题,包容性专场是了解社区文化和提交规范的好入口。
参会与参与清单
如果你错过了 PGConf.dev 2026,以下是后续跟进的几个动作:
- 关注视频发布——PGConf.dev 的 YouTube 频道通常在会后 5-10 天内上传所有演讲录像。
- 检索议题关键词——用上面的
pgconf_notes表或简单文本文件,把每个演讲的核心技术点记录下来,标注版本号(v17/v18),方便后续对照 release notes。 - 加入本地用户组——查看 postgresql.org/community/user-groups,找到你所在城市的组,下一次大会期间大概率会有联动活动。
- 提交 2027 年议题——PGConf.dev 的 CFP 通常在年初开放,Program Committee 的成员名单就是你的审查者,提前了解他们的关注方向有助于选题。
- 关注核心演讲者的博客和邮件列表——Andres Freund、Melanie Plageman、Robert Haas 等人经常在
-hackers邮件列表里发布技术提案,大会演讲往往是这些提案的公开版。
PGConf.dev 2026 的这份名单不是一份简单的出席记录——它是一张社区力量分布图。读懂这张图,你就知道 PostgreSQL 下一步的技术重心在哪里,以及该从哪个入口加入推动它的人。