postgresql13.0刚刚发布,并在各个方面进行了许多性能改进。为了了解这些变化带来了的差异,我使用HammerDB对不同数量的虚拟用户运行了许多基准测试,比较了未调整配置和“启动程序”调整配置的PostgreSQL 12.4和13.0,即我们建议用户将其用作自己的部署的起点。
-
服务器规格
被测服务器( SUT )是运行 Red Hat Enterprise Linux 版本 8.2 ( Ootpa )的 Amazon AWS m5.metal 实例
PostgreSQL
数据目录位于
RAID 10
中配置的八个磁盘上。文件系统为
xfs
,预读设置为
8192
。、
PostgreSQL WAL目录位于其自己的磁盘上。文件系统为 xfs,预读设置为 8192。
-
PostgreSQL
这些测试在社区软件包中的 PostgreSQL 12.4和 PostgreSQL 13.0上运行。每个服务器的测试大多未经调整。
-
“ 未调整 ” 设置
所有其他设置保持默认值。
-
调整设置
所有其他设置保持默认值。
-
HammerDB
使用的测试驱动程序是 HammerDB,对数据模型进行了一些修改,以使用适当的 PostgreSQL 数据类型,优化列顺序进行对齐,并删除填充因子设置(有关使用的确切模式,请参见本文结尾处的 “ 数据模型 ” 部分) )。这些修改符合 TPC-C 规范:
第1.3节—表格布局
对于每个表,可以使用从测试系统获得的任何物理表示形式,以任何顺序实现以下属性列表。
HammerDB 使用的算法未做任何更改。
HammerDB 使用 2000 个仓库填充该数据库。每个表都通过其主键索引进行聚类(历史记录中没有索引)。 ANALYZE 和 VACUUM FREEZE 在所有表上运行。保留此原始数据库的基本备份。
-
方法
对于每个虚拟用户数,都会从基本备份中还原一个新数据库。然后以5 分钟的加速时间和1 小时的测试时间运行HammerDB 。
请注意,思考和关键时间已禁用,因为此测试的目的是查看最大可能的性能。这不能反映实际的工作量,也不适合运行“
按本就算”
的TPC-C
基准测试。
注意:对于正确的TPC-C
基准测试,测试必须运行至少两个小时。
-
结果
下表显示了开箱即用和正确调整的 12.4 和 13.0 的结果。值表示每分钟的交易量。
从该图表中我们可以看到,
12.4
和
13.0
的未调整性能基本相同,其中
13.0
具有优势,并且性能在
50
至
75
个虚拟用户数之间最大化。
-
概要
测试表明,正确调整PostgreSQL 服务器具有巨大的好处。13.0 版的开箱即用性能比12.4 更好,并且在调整两个服务器时的差异甚至更大。PostgreSQL 13 代表了开源关系数据库的又一次飞跃,因为它随着每个新版本的发布而不断完善 。
-
附录 A :数据模型
CREATE TABLE customer (
c_since timestamp with time zone NOT NULL,
c_id integer NOT NULL,
c_w_id integer NOT NULL,
c_d_id smallint NOT NULL,
c_payment_cnt smallint NOT NULL,
c_delivery_cnt smallint NOT NULL,
c_first character varying(16) NOT NULL,
c_middle character(2) NOT NULL,
c_last character varying(16) NOT NULL,
c_street_1 character varying(20) NOT NULL,
c_street_2 character varying(20) NOT NULL,
c_city character varying(20) NOT NULL,
c_state character(2) NOT NULL,
c_zip character(9) NOT NULL,
c_phone character(16) NOT NULL,
c_credit character(2) NOT NULL,
c_credit_lim numeric(12,2) NOT NULL,
c_discount numeric(4,4) NOT NULL,
c_balance numeric(12,2) NOT NULL,
c_ytd_payment numeric(12,2) NOT NULL,
c_data character varying(500) NOT NULL,
CONSTRAINT customer_i1 PRIMARY KEY (c_w_id, c_d_id, c_id)
);
CREATE UNIQUE INDEX customer_i2 ON customer USING btree (c_w_id, c_d_id, c_last, c_first, c_id);
CREATE TABLE district (
d_w_id integer NOT NULL,
d_next_o_id integer NOT NULL,
d_id smallint NOT NULL,
d_ytd numeric(12,2) NOT NULL,
d_tax numeric(4,4) NOT NULL,
d_name character varying(10) NOT NULL,
d_street_1 character varying(20) NOT NULL,
d_street_2 character varying(20) NOT NULL,
d_city character varying(20) NOT NULL,
d_state character(2) NOT NULL,
d_zip character(9) NOT NULL,
CONSTRAINT district_i1 PRIMARY KEY (d_w_id, d_id)
);
CREATE TABLE history (
h_date timestamp with time zone NOT NULL,
h_c_id integer,
h_c_w_id integer NOT NULL,
h_w_id integer NOT NULL,
h_c_d_id smallint NOT NULL,
h_d_id smallint NOT NULL,
h_amount numeric(6,2) NOT NULL,
h_data character varying(24) NOT NULL
);
CREATE TABLE item (
i_id integer NOT NULL,
i_im_id integer NOT NULL,
i_name character varying(24) NOT NULL,
i_price numeric(5,2) NOT NULL,
i_data character varying(50) NOT NULL,
CONSTRAINT item_i1 PRIMARY KEY (i_id)
);
CREATE TABLE new_order (
no_w_id integer NOT NULL,
no_o_id integer NOT NULL,
no_d_id smallint NOT NULL,
CONSTRAINT new_order_i1 PRIMARY KEY (no_w_id, no_d_id, no_o_id)
);
CREATE TABLE order_line (
ol_delivery_d timestamp with time zone,
ol_o_id integer NOT NULL,
ol_w_id integer NOT NULL,
ol_i_id integer NOT NULL,
ol_supply_w_id integer NOT NULL,
ol_d_id smallint NOT NULL,
ol_number smallint NOT NULL,
ol_quantity smallint NOT NULL,
ol_amount numeric(6,2),
ol_dist_info character(24),
CONSTRAINT order_line_i1 PRIMARY KEY (ol_w_id, ol_d_id, ol_o_id, ol_number)
);
CREATE TABLE orders (
o_entry_d timestamp with time zone NOT NULL,
o_id integer NOT NULL,
o_w_id integer NOT NULL,
o_c_id integer NOT NULL,
o_d_id smallint NOT NULL,
o_carrier_id smallint,
o_ol_cnt smallint NOT NULL,
o_all_local smallint NOT NULL,
CONSTRAINT orders_i1 PRIMARY KEY (o_w_id, o_d_id, o_id)
);
CREATE UNIQUE INDEX orders_i2 ON orders USING btree (o_w_id, o_d_id, o_c_id, o_id);
CREATE TABLE stock (
s_i_id integer NOT NULL,
s_w_id integer NOT NULL,
s_ytd integer NOT NULL,
s_quantity smallint NOT NULL,
s_order_cnt smallint NOT NULL,
s_remote_cnt smallint NOT NULL,
s_dist_01 character(24) NOT NULL,
s_dist_02 character(24) NOT NULL,
s_dist_03 character(24) NOT NULL,
s_dist_04 character(24) NOT NULL,
s_dist_05 character(24) NOT NULL,
s_dist_06 character(24) NOT NULL,
s_dist_07 character(24) NOT NULL,
s_dist_08 character(24) NOT NULL,
s_dist_09 character(24) NOT NULL,
s_dist_10 character(24) NOT NULL,
s_data character varying(50) NOT NULL,
CONSTRAINT stock_i1 PRIMARY KEY (s_w_id, s_i_id)
);
CREATE TABLE warehouse (
w_id integer NOT NULL,
w_name character varying(10) NOT NULL,
w_street_1 character varying(20) NOT NULL,
w_street_2 character varying(20) NOT NULL,
w_city character varying(20) NOT NULL,
w_state character(2) NOT NULL,
w_zip character(9) NOT NULL,
w_tax numeric(4,4) NOT NULL,
w_ytd numeric(12,2) NOT NULL,
CONSTRAINT warehouse_i1 PRIMARY KEY (w_id)
);
原文链接:https://www.enterprisedb.com/blog/postgresql-tproc-c-benchmarks-postgresql-12-vs-postgresql-13-performance