首页 星云 工具 资源 星选 资讯 热门工具
:

PDF转图片 完全免费 小红书视频下载 无水印 抖音视频下载 无水印 数字星空

[postgres]使用pgbench进行基准测试

编程知识
2024年08月31日 16:52

前言

pgbench是一种在postgres上进行基准测试的简单程序,一般安装后就会自带。pgbench可以再并发的数据库绘画中一遍遍地进行相同序列的SQL语句,并且计算平均事务率。

测试准备

既然要测postgres,肯定要先有个postgres。安装过程略过。

一些环境信息:

  • postgres版本:15.3,安装完成后默认配置
  • os version:debian 12
  • 硬件配置:vbox虚拟机,4核4GB内存,40GB SSD存储

pgbench选项

运行pgbench --help查看帮助文档

pgbench is a benchmarking tool for PostgreSQL.

Usage:
  pgbench [OPTION]... [DBNAME]

Initialization options:
  -i, --initialize         调用初始化模式
  -I, --init-steps=[dtgGvpf]+ (default "dtgvp")
                           运行选定的初始化步骤
  -F, --fillfactor=NUM     设置填充因子
  -n, --no-vacuum          初始化期间不运行 VACUUM
  -q, --quiet              安静日志记录(每 5 秒一条消息)
  -s, --scale=NUM          缩放因子
  --foreign-keys           在表之间创建外键约束
  --index-tablespace=TABLESPACE
                           在指定的表空间中创建索引
  --partition-method=(range|hash)
                           使用此方法对 pgbench_accounts 进行分区(默认:range)
  --partitions=NUM         将 pgbench_accounts 分成 NUM 个部分(默认:0)
  --tablespace=TABLESPACE  在指定的表空间中创建表
  --unlogged-tables        将表创建为非记录表

Options to select what to run:
  -b, --builtin=NAME[@W]   添加内置脚本 NAME,权重为 W(默认:1)
                           (使用 "-b list" 列出可用脚本)
  -f, --file=FILENAME[@W]  添加脚本 FILENAME,权重为 W(默认:1)
  -N, --skip-some-updates  跳过 pgbench_tellers 和 pgbench_branches 的更新
                           (与 "-b simple-update" 相同)
  -S, --select-only        仅执行 SELECT 类型事务
                           (与 "-b select-only" 相同)

Benchmarking options:
  -c, --client=NUM         并发数据库客户端数(默认:1)
  -C, --connect            为每个事务建立新连接
  -D, --define=VARNAME=VALUE
                           为自定义脚本定义变量
  -j, --jobs=NUM           线程数(默认:1)
  -l, --log                将事务时间写入日志文件
  -L, --latency-limit=NUM  计数超过 NUM 毫秒的事务为延迟
  -M, --protocol=simple|extended|prepared
                           提交查询的协议(默认:simple)
  -n, --no-vacuum          在测试前不运行 VACUUM
  -P, --progress=NUM       每 NUM 秒显示线程进度报告
  -r, --report-per-command 每个命令报告延迟、失败和重试
  -R, --rate=NUM           目标事务每秒速率
  -s, --scale=NUM          在输出中报告此缩放因子
  -t, --transactions=NUM   每个客户端运行的事务数(默认:10)
  -T, --time=NUM           基准测试持续时间(秒)
  -v, --vacuum-all         测试前清理所有四个标准表
  --aggregate-interval=NUM 将数据汇总在 NUM 秒内
  --failures-detailed      按基本类型分组报告失败情况
  --log-prefix=PREFIX      事务时间日志文件的前缀
                           (默认:"pgbench_log")
  --max-tries=NUM          运行事务的最大尝试次数(默认:1)
  --progress-timestamp     使用 Unix 纪元时间戳作为进度
  --random-seed=SEED       设置随机种子("time", "rand", 整数)
  --sampling-rate=NUM      日志记录的事务比例(例如,0.01 代表 1%)
  --show-script=NAME       显示内置脚本代码,然后退出
  --verbose-errors         打印所有错误的消息

Common options:
  -d, --debug              打印调试输出
  -h, --host=HOSTNAME      数据库服务器主机或套接字目录
  -p, --port=PORT          数据库服务器端口号
  -U, --username=USERNAME  以指定的数据库用户身份连接
  -V, --version            输出版本信息,然后退出
  -?, --help               显示此帮助信息,然后退出

Report bugs to <pgsql-bugs@lists.postgresql.org>.
PostgreSQL home page: <https://www.postgresql.org/>

测试示例

  1. 初始化测试数据。以下命令会自动创建四张测试表,在其中一个表pgbench_accounts中创建200000行数据。再次初始化的话,pgbench会先把旧表删除,然后再建测试表。
pgbench -i -s 2
  1. 使用默认配置执行一次简单的基准测试
$ pgbench

pgbench (15.3)
starting vacuum...end.
transaction type: <builtin: TPC-B (sort of)>  # 本次测试所使用的测试类型
scaling factor: 2  # 用于记录在初始化设置的数据量比例因子
query mode: simple  # 测试是指定的查询类型
number of clients: 1  # 客户端数量
number of threads: 1  # 每个客户端的线程数
maximum number of tries: 1
number of transactions per client: 10  # 每个客户端的事务数
number of transactions actually processed: 10/10  # 实际完成的事务数量和计划完成的事务数量
number of failed transactions: 0 (0.000%)
latency average = 7.501 ms  # 平均响应时间
initial connection time = 1.650 ms
tps = 133.317335 (without initial connection time)

删除测试数据

DROP TABLE IF EXISTS pgbench_accounts;
DROP TABLE IF EXISTS pgbench_branches;
DROP TABLE IF EXISTS pgbench_history;
DROP TABLE IF EXISTS pgbench_tellers;

测试数据

500w数据量,postgres为默认配置

序号 测试命令 平均响应时间 TPS 总事务数
1 pgbench -T60 6.857 ms 145.833890 8750
2 pgbench -j2 -c4 -T60 11.505 ms 347.677286 20858
3 pgbench -j4 -c8 -T60 13.721 ms 583.052560 34987
From:https://www.cnblogs.com/XY-Heruo/p/18390542
本文地址: http://shuzixingkong.net/article/1617
0评论
提交 加载更多评论
其他文章 Go plan9 汇编: 打通应用到底层的任督二脉
原创文章,欢迎转载,转载请注明出处,谢谢。 0. 前言 作为一个严肃的 Gopher,了解汇编是必须的。本汇编系列文章会围绕基本的 Go 程序介绍汇编的基础知识。 1. Go 程序到汇编 首先看一个简单到令人发指的示例: package main func main() { a := 1 print
Go plan9 汇编: 打通应用到底层的任督二脉 Go plan9 汇编: 打通应用到底层的任督二脉
2024 NepCTF
NepCTF NepMagic —— CheckIn 直接玩游戏就能出 注意有一关要把隐藏的方块全找到 NepCamera 先使用tshark读取数据 结果文件中发现大量jpeg头ffd8ffe0。 猜测是多个图片,编写脚本,提取出来。 脚本: import re inputFilePath=&qu
2024 NepCTF 2024 NepCTF 2024 NepCTF
设计模式之迭代器模式
迭代器模式很多人都熟悉,但是什么是迭代器,为什么要用迭代器?这个很多人就很难做出具体回答了,只是知道如果有了迭代器,那么我们就能foreach遍历了,方便循环处理。这只是对迭代器的用途,进行了回答,foreach语法是java1.5时加入的语法糖,那么在这之前呢,之前是怎么做的?要知道并不是所有容器
设计模式之迭代器模式
使用广播星历计算卫星坐标(Python)
前言 本代码为GNSS课程设计代码,仅供参考,使用的计算方法与公式均来源于王坚主编的《卫星定位原理与应用(第二版)》。 本代码计算结果可以通过下载精密星历进行比照,误差在1-10m左右。 实现功能:读取卫星广播星历,并将其计算为WGS-84坐标系下的坐标,每颗卫星,每15分钟输出一次。 广播星历下载
SNAT 与 DNAT
本文为博主原创,转载请注明出处: SNAT(Source Network Address Translation,源网络地址转换)和DNAT(Destination Network Address Translation,目标网络地址转换)是网络地址转换(NAT)中的两种重要技术,它们在实现内部网络
C++ lambda 引用捕获临时对象引发 coredump 的案例
今天复习前几年在项目过程中积累的各类技术案例,有一个小的 coredump 案例,当时小组里几位较资深的同事都没看出来,后面是我周末查了两三个小时解决掉的,今天再做一次系统的总结,给出一个复现的案例代码,案例代码比较简单,便于学习理解。 1. 简介 原则:临时对象不应该被 lambda 引用捕获,因
C++ lambda 引用捕获临时对象引发 coredump 的案例
STL 改造红黑树 模拟封装set和map
改造红黑树 目录改造红黑树适配STL迭代器的红黑树基本结构RBTreeNode__RBTree_iteratorRBTree完整代码封装的set封装的map 在初次看STL中实现红黑树的源码时有些不理解,然后自己尝试对set以RBTree&lt;K,K&gt;的方式封装红黑树的迭代器;实现过程发现,
大请求、请求超时问题
耗时很长的请求怎么处理?比如数据量大的。业务逻辑处理时间太久,以至于响应超时 这里的超时响应指的是ReadTimeOut,即发送请求内容完毕到接收响应数据开始的这段时间。普通HTTP请求可能在这段时间没有响应超时。 HTTP分块传输(Chunked Transfer Encoding)中每个数据块的
大请求、请求超时问题 大请求、请求超时问题 大请求、请求超时问题