为什么我喜欢 PostgreSQL - 基础架构工程师的观点

分享 未结 0 550
舞动的程序
舞动的程序 LV4 2023年1月14日 10:11 发表
译者:魏 波
中国 PG 分会培训认证执行总监、资深数据库工程师,十多年的数据库运维管理及培训经验,掌握 PostgreSQL 架构部署、性能优化等,致力于推动 PostgreSQL 在中国的发展。

作者:沙扬・慕克吉(Shayon Mukherjee)
我是一名具有产品和基础设施工程经验的软件工程师。我喜欢构建和扩展以软件为主导的基础设施。我感兴趣的一些领域(没有特定的顺序或类别):分布式系统、站点可靠性、事件管理、运行、Gulab Jamun 和 Biryani。

虽然我喜欢作为产品和基础架构工程师使用 MySQL(第一个数据库),但最近,我也开始欣赏 PostgreSQL。最近阅读了这篇关于为什么基础架构工程师喜欢 MySQL 的文章,我认为它是有参考性的。

本文不是 MySQL vs PostgreSQL 的帖子。这只是我作为基础架构工程师对 PostgreSQL 的欣赏的一个小总结。

结构更改

往池塘里扔一块石头,你就会让基础设施工程师讲述结构更改如何导致生产中断的故事。对于大多数操作,我发现 PostgreSQL 具有更安全的开箱即用替代方案,因此允许您通过获取最少的锁来执行零停机时间或接近零停机时间的结构更改。

此外,在每个主要版本中,都有一个引入优化的主题,重点是在引擎中为常见任务获取更少的锁。

一些例子:

添加或删除索引

PostgreSQL 能够在不获取任何锁的情况下添加和删除索引。它使用一个名为 CONCURRENTLY 的参数来执行此操作。

CREATE INDEX CONCURRENTLY sales_quantity_index ON sales_table (quantity);
DROP INDEX CONCURRENTLY sales_quantity_index ON sales_table;

外键约束

在添加外键时通过 NOT VALID 传递给语句,可以使得 PostgreSQL 跳过验证约束,因此不需要获取会阻塞写入的锁(source)。当然这也是一个选择,所以你的操作可能会有所不同(使其生效需要再执行一条语句)。

ALTER TABLE distributors ADD CONSTRAINT distfk FOREIGN KEY (address) REFERENCES addresses (address) NOT VALID;
ALTER TABLE distributors VALIDATE CONSTRAINT distfk;

添加 NOT NULL 或其他约束

执行以下操作会使 PostgreSQL 扫描整个表以确保约束有效。

ALTER TABLE table_name ALTER COLUMN column_name SET NOT NULL;

根据工作负载的性质,这可能非常具有侵入性。相反,您可以将其分解为更多语句,首先添加一个约束但不立即验证。

ALTER TABLE table_name ADD CONSTRAINT constraint_name CHECK (column IS NOT NULL) NOT VALID;

请注意,我们在这里利用 NOT VALID 选项。接下来,您可以手动执行命令,告诉 PostgreSQL 验证约束。

ALTER TABLE table_name VALIDATE CONSTRAINT constraint_name;

这使得 PostgreSQL 不会获得 ACCESS EXCLUSIVE LOCK,而是 SHARE UPDATE EXCLUSIVE,这意味着您的读 / 写不受影响。接下来,添加非空约束:

ALTER TABLE table_name ALTER COLUMN column_name SET NOT NULL;

因为这个约束已经验证过了,所以 PostgreSQL 这次不会获得 ACCESS EXCLUSIVE LOCK。现在,您可以执行以下命令删除 CHECK 约束:

ALTER TABLE table_name DROP CONSTRAINT constraint_name;

虽然它增加了要执行的步骤数量,但它也使整个过程更加可靠。

可扩展性

我认为这是产品和基础架构工程师都欣赏的东西,包括从自定义数据类型到用户定义的函数。能够在 SQL 甚至 C 中编写自定义函数是非常强大的,通常可应用在自动化操作任务时(我经常选择使用 SQL)。这是在模块化函数中抽象逻辑的绝佳方式,因为它是 SQL,所以你可以 “让数据库做困难的工作”。

结论

到目前为止,我很喜欢利用 PostgreSQL 的这些开箱即用的特性来执行关键操作。从现在开始,期待着发现 PostgreSQL 数据库更多令人欢喜的功能。

最后修改于 2022 年 1 月 17 日

原文链接
https://www.shayon.dev/post/2022/17/why-i-enjoy-postgresql-infrastructure-engineers-perspective/



预告 | 2021 PG 亚洲大会 12 月与您相约
PG ACE 计划的正式发布
三期 PostgreSQL 国际线上沙龙活动的举办
六期 PostgreSQL 国内线上沙龙活动的举办

中国 PostgreSQL 分会与腾讯云战略合作协议签订

中国 PostgreSQL 分会与美创科技战略合作协议签订
中国 PostgreSQL 分会与中软国际战略合作协议签订
中国 PostgreSQL 分会 “走进” 北京大学
中国 PostgreSQL 分会 “走进” 深圳大学
PGFans 社区核心用户点亮计划

PostgreSQL 14.0 正式发布

深度报告:开源协议那些事儿

从 “非主流” 到 “潮流”,开源早已值得拥有

Oracle 中国正在进行新一轮裁员,传 N+6 补偿

PostgreSQL 与 MySQL 版权比较

新闻 | Babelfish 使 PostgreSQL 直接兼容 SQL Server 应用程序

四年三冠,PostgreSQL 再度荣获 “年度数据库”

中国 PostgreSQL 分会入选工信部重点领域人才能力评价机构


更多新闻资讯行业动态技术热点,请关注中国 PostgreSQL 分会官方网站

https://www.postgresqlchina.com

中国 PostgreSQL 分会生态产品

https://www.pgfans.cn

中国 PostgreSQL 分会资源下载站

https://www.postgreshub.cn


收藏(0)  分享
相关标签: mysql postgresql
问题没解决?让chatGPT帮你作答 智能助手
0个回复
  • 消灭零回复
相关帖子
MySQL5.7安装包 0