pgbench
是一个 核心实用程序,用于在PostgreSQL上运行基准测试。
pgbench
在 PostgreSQL 7.0 中添加。
用法
pgbench
能够生成一组示例数据,并对这些数据运行一组默认查询(松散地基于TPC-B);或者,可以执行用户提供的自定义脚本。
默认数据和查询
如果使用内置的基准测试功能,pgbench
需要执行两次,一次初始化数据,一次运行基准测试查询。
初始化步骤使用 pgbench
执行;将创建四个表(默认情况下,将删除具有相同名称的现有表)。三个表将预先填充生成的数据;数据量由 -i
-s
/--scale
选项控制(默认值:1
)。下表显示了生成的表以及在不同比例因子下插入的行数
1 |
10 |
100 |
|
pgbench_branches |
1 |
10 |
100 |
pgbench_tellers |
10 |
100 |
1,000 |
pgbench_accounts |
100,000 |
1,000,000 |
10,000,000 |
pgbench_history |
0 |
0 |
0 |
默认情况下,行作为客户端生成的单个 INSERT
语句插入。如果选项 -I
/--init-steps
包含 G
标志,则将使用 generate_series()
创建数据。
生成数据后,可以第二次执行 pgbench
以多次运行内置的类似TPC-B的事务。每个事务运行以下命令:
\set aid random(1, 100000 * :scale) \set bid random(1, 1 * :scale) \set tid random(1, 10 * :scale) \set delta random(-5000, 5000) BEGIN; UPDATE pgbench_accounts SET abalance = abalance + :delta WHERE aid = :aid; SELECT abalance FROM pgbench_accounts WHERE aid = :aid; UPDATE pgbench_tellers SET tbalance = tbalance + :delta WHERE tid = :tid; UPDATE pgbench_branches SET bbalance = bbalance + :delta WHERE bid = :bid; INSERT INTO pgbench_history (tid, bid, aid, delta, mtime) VALUES (:tid, :bid, :aid, :delta, CURRENT_TIMESTAMP); END;
变更历史
开发中
- PostgreSQL 18
- 改进了与失败事务相关的结果输出(提交 cae0f3c4)
- PostgreSQL 17
- PostgreSQL 15
- PostgreSQL 14
- PostgreSQL 13
- PostgreSQL 12
- PostgreSQL 11
- 主要脚本语言改进(提交 bc7fa0c1)
- 添加了
pow()
/power()
函数(提交 7a727c18) - 添加了
\if
支持(提交 f67b113a) - 允许在变量名称中使用非ASCII字符(提交 9d36a386)
- 添加了哈希函数
hash()
、hash_murmur2()
和hash_fnv1a()
(提交 e51a0484) - 添加了
random_zipfian()
函数(提交 1fcd0ade) - 添加了选项
--init-steps
(提交 591c504f) - 添加了选项
--random-seed
(提交 64f85894) - 使用
--latency-limit
和--rate
生成的统计信息的准确性得到改进(提交 c23bb6ba 和 16827d44)
- PostgreSQL 9.5
- PostgreSQL 9.4
- PostgreSQL 9.3
- PostgreSQL 9.2
- PostgreSQL 8.4
- PostgreSQL 8.3
- 移除了
-P
选项(提交 4192f2d8)
- 移除了
- PostgreSQL 7.0
示例
默认测试
与pgbench
一起提供的默认测试需要将一组示例表和数据安装到目标数据库中;这可以通过以下方式完成:
pgbench -i [other-options
]dbname
其中other-options
应包含连接参数,这些参数与psql和其他基于libpq的客户端使用的参数相同。
再次执行pgbench
而不使用-i
选项将导致执行基本测试,例如:
postgres:~$ pgbench -U postgres testdb starting vacuum...end. transaction type: TPC-B (sort of) scaling factor: 1 query mode: simple number of clients: 1 number of threads: 1 number of transactions per client: 10 number of transactions actually processed: 10/10 tps = 108.049703 (including connections establishing) tps = 110.750557 (excluding connections establishing)
默认选项不会提供特别有用的输出;调整pgbench
最有用的选项是
-c
(客户端数量)-t
(事务数量)-T
(时间限制)
参考
- PostgreSQL 文档: pgbench
有用链接
- PostgreSQL 社区维基: Pgbench