1.初始化:

  pgbench -i pgbench

  如果端口号有变化,需要先手动创建数据库,再执行。

  pgbench -i -s 10 -p 5433 pgbench

 重点:主要用到两个参数,-i:初始化模式,-s 插入的倍数,默认是1,即插入100000条;也就是执行多少次generate_series(1,100000)。

2.开始测试:

  pgbench -c 96  -j 12 -T 20 -r -p 5433 pgbench

-bash-4.1$ pgbench -c 96  -j 12 -T 20 -r -p 5433 pgbench
starting vacuum...end.
transaction type: TPC-B (sort of)
scaling factor:
query mode: simple
number of clients:
number of threads:
duration: s
number of transactions actually processed:
latency average: 1345.443 ms
tps = 71.351954 (including connections establishing)
tps = 71.400363 (excluding connections establishing)
statement latencies in milliseconds:
0.003744 \set nbranches * :scale
0.001051 \set ntellers * :scale
0.000855 \set naccounts * :scale
0.001345 \setrandom aid :naccounts
0.000850 \setrandom bid :nbranches
0.000680 \setrandom tid :ntellers
0.000797 \setrandom delta -
0.425127 BEGIN;
3.685616 UPDATE pgbench_accounts SET abalance = abalance + :delta WHERE aid = :aid;
0.189167 SELECT abalance FROM pgbench_accounts WHERE aid = :aid;
1144.710503 UPDATE pgbench_tellers SET tbalance = tbalance + :delta WHERE tid = :tid;
121.211975 UPDATE pgbench_branches SET bbalance = bbalance + :delta WHERE bid = :bid;
0.194937 INSERT INTO pgbench_history (tid, bid, aid, delta, mtime) VALUES (:tid, :bid, :aid, :delta, CURRENT_TIMESTAMP);
13.740971 END;

  主要参数:

  -c 总连接数,创建多少个连接到数据库,一般数据库接受连接数默认为100,其中需要预留3个左右的连接。

  -j 进程数量,每个进程创建n个连接,那么就存在如下关系:-c = -j *n。

  -T 测试持续时间,指定了-T就不能指定-t,每个连接执行的事物数量。即,要么指定测试多长时间,要么指定测试多少个事物。

  -r 显示每一步操作的平均时间。

  -f 指定测试脚本,不指定则使用默认脚本。

3.测试结果分析

  可以看看设置的参数,也可以看到TPS,当然可以算到QPS,也可以看到系统的读写更新的速度,知道该往哪方面优化。

4.pgbench初始化参数:

 

pgbench accepts the following command-line initialization arguments: 

-F fillfactor
Create the pgbench_accounts, pgbench_tellers and pgbench_branches tables with the given fillfactor. Default is . -i
Required to invoke initialization mode. -s scale_factor
Multiply the number of rows generated by the scale factor. For example, -s will create ,, rows in the pgbench_accounts table. Default is .

5.pgbench 压力测试参数:

pgbench accepts the following command-line benchmarking arguments: 

-c clients
Number of clients simulated, that is, number of concurrent database sessions. Default is . -C
Establish a new connection for each transaction, rather than doing it just once per client session. This is useful to measure the connection overhead. -d
Print debugging output. -D varname=value
Define a variable for use by a custom script (see below). Multiple -D options are allowed. -f filename
Read transaction script from filename. See below for details. -N, -S, and -f are mutually exclusive. -j threads
Number of worker threads within pgbench. Using more than one thread can be helpful on multi-CPU machines. The number of clients must be a multiple of the number of threads, since each thread is given the same number of client sessions to manage. Default is . -l
Write the time taken by each transaction to a log file. See below for details. -M querymode
Protocol to use for submitting queries to the server: simple: use simple query protocol. extended: use extended query protocol. prepared: use extended query protocol with prepared statements. The default is simple query protocol. (See Chapter for more information.) -n
Perform no vacuuming before running the test. This option is necessary if you are running a custom test scenario that does not include the standard tables pgbench_accounts, pgbench_branches, pgbench_history, and pgbench_tellers. -N
Do not update pgbench_tellers and pgbench_branches. This will avoid update contention on these tables, but it makes the test case even less like TPC-B. -s scale_factor
Report the specified scale factor in pgbench is output. With the built-in tests, this is not necessary; the correct scale factor will be detected by counting the number of rows in the pgbench_branches table. However, when testing custom benchmarks (-f option), the scale factor will be reported as unless this option is used. -S
Perform select-only transactions instead of TPC-B-like test. -t transactions
Number of transactions each client runs. Default is . -T seconds
Run the test for this many seconds, rather than a fixed number of transactions per client. -t and -T are mutually exclusive. -v
Vacuum all four standard tables before running the test. With neither -n nor -v, pgbench will vacuum the pgbench_tellers and pgbench_branches tables, and will truncate pgbench_history.

6.默认测试脚本:

\set nbranches :scale
\set ntellers * :scale
\set naccounts * :scale
\setrandom delta -
\setrandom aid :naccounts
\setrandom bid :nbranches
\setrandom tid :ntellers 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; 备注:上面是 pgbench 自带的测试脚本,用户也可以自己编写测试脚本。

补充20190619:

7.在pg11上测试时,\setrandom报错,修改脚本:

\set nbranches :scale
\set ntellers * :scale
\set naccounts * :scale
\set delta random(-,)
\set aid random(,:naccounts)
\set bid random(,:nbranches)
\set tid random(,:ntellers) 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;

二、如果我们有绘图需要,一般可以这样解决:

1)使用pgbench 选用-P 选项,多少s报告一次进程的tps等信息,将这些信息可以放到excel或者Gnuplot、Matlab中绘图。

2)使用pgbench_tools来做综合测试,并给出一个趋势报告图。

下面是对pgbench_tools的介绍和使用:

https://github.com/kuang17/pgbench-tools

需要注意的是:

1)PG10修改了几个函数,例如pg_current_xlog_location变为了pg_current_wal_lsn。

2)在测试脚本中,\setrandom 需要对应的修改为\set xxx random(xxx, xxx)的方式。

3)在绘图时,需要先按照Gnuplot绘图工具及相关的字体。

yum install gnuplot -y

wget http://olea.org/paquetes-rpm//msttcore-fonts-2.0-6.noarch.rpm

rpm -ivh msttcore-fonts-2.0-6.noarch.rpm

修改/etc/profile或~/.bashrc,这样设置可以固定下来。

export GDFONTPATH="/usr/share/fonts/msttcore"

export GNUPLOT_DEFAULT_GDFONT="arial"

. /etc/profile

pgbench使用记录的更多相关文章

  1. [原创]使用benchmarksql和pgbench对PostgreSQL Plus Advanced Server进行性能测试

    一.测试环境 benchmarksql version:4.0.8 rhel 6.3 vmware esxi 二.理解benchmarksql性能测试原理TPC-C 1.理解TPC-C TPC-C模拟 ...

  2. 记一次debug记录:Uncaught SyntaxError: Unexpected token ILLEGAL

    在使用FIS3搭建项目的时候,遇到了一些问题,这里记录下. 这里是发布搭建代码: // 代码发布时 fis.media('qa') .match('*.{js,css,png}', { useHash ...

  3. nginx配置反向代理或跳转出现400问题处理记录

    午休完上班后,同事说测试站点访问接口出现400 Bad Request  Request Header Or Cookie Too Large提示,心想还好是测试服务器出现问题,影响不大,不过也赶紧上 ...

  4. Kali对wifi的破解记录

    好记性不如烂笔头,记录一下. 我是在淘宝买的拓实N87,Kali可以识别,还行. 操作系统:Kali 开始吧. 查看一下网卡的接口.命令如下 airmon-ng 可以看出接口名称是wlan0mon. ...

  5. 2015 西雅图微软总部MVP峰会记录

    2015 西雅图微软总部MVP峰会记录 今年决定参加微软MVP全球峰会,在出发之前本人就已经写这篇博客,希望将本次会议原汁原味奉献给大家 因为这次是本人第一次写会议记录,写得不好的地方希望各位园友见谅 ...

  6. 分享一个SQLSERVER脚本(计算数据库中各个表的数据量和每行记录所占用空间)

    分享一个SQLSERVER脚本(计算数据库中各个表的数据量和每行记录所占用空间) 很多时候我们都需要计算数据库中各个表的数据量和每行记录所占用空间 这里共享一个脚本 CREATE TABLE #tab ...

  7. 我是如何在SQLServer中处理每天四亿三千万记录的

    首先声明,我只是个程序员,不是专业的DBA,以下这篇文章是从一个问题的解决过程去写的,而不是一开始就给大家一个正确的结果,如果文中有不对的地方,请各位数据库大牛给予指正,以便我能够更好的处理此次业务. ...

  8. 前端学HTTP之日志记录

    前面的话 几乎所有的服务器和代理都会记录下它们所处理的HTTP事务摘要.这么做出于一系列的原因:跟踪使用情况.安全性.计费.错误检测等等.本文将谥介绍日志记录 记录内容 大多数情况下,日志的记录出于两 ...

  9. ASP.NET Core应用中如何记录和查看日志

    日志记录不仅对于我们开发的应用,还是对于ASP.NET Core框架功能都是一项非常重要的功能特性.我们知道ASP.NET Core使用的是一个极具扩展性的日志系统,该系统由Logger.Logger ...

随机推荐

  1. (转) latch 入门

    原链接:http://www.itpub.net/thread-1424719-1-1.html (入门1)一直想点文章关于Latch的,又一直没写,一是因为懒,二是一直觉得现在关于Latch的书那么 ...

  2. uiautomator定位元素

  3. android adb devices offline的解决办法

    在做Android开发时经常出现android adb devices offline,解决办法如下: 1 重启adb服务 adb kill-server adb start-server linux ...

  4. go——变量

    在数学概念中,变量(variable)表示没有固定值且可以改变的数.但从计算机系统实现角度来看,变量是一段或多段用来存储数据的内存.作为静态类型语言,Go语言总是有固定的数据类型,类型决定了变量内存的 ...

  5. day3-python-文件操作(1)

    本文内容涉及python打开/创建文件对象,文件的读写.文件指针位置的移动.获取命令行参数. 1. open()open函数以指定模式返回一个file对象,如: file_object = open( ...

  6. SharePoint 2010 以Jquery Ajax方式更新SharePoint列表数据!

    之前本人的博客介绍了<sharepoint 2010自定义访问日志列表设置移动终端否和客户端访问系统等计算列的公式>,那如何通过Jquery提交访问日志到自定义的SharePoint的访问 ...

  7. 百度feed 寒假实习 一面二面(offer)

    一面(1小时) 自我介绍,研究方向,本科学校,家乡等等.. 1 介绍了jdd风险登录的比赛,问题背景,建模,特征构建,特征选择,模型等. 个人觉得介绍项目一定要高大上一点,把自己创新或者有创意的点子讲 ...

  8. APDU指令返回码及其代表含义

    9000 正常 成功执行6200 警告 信息未提供6281 警告 回送数据可能出错6282 警告 文件长度小于Le6283 警告 选中的文件无效6284 警告 FCI格式与P2指定的不符6300 警告 ...

  9. 【Python】常用内建模块(卒)

    内容来自廖雪峰的官方网站 笔记性质 1.datetime 2.collections 3.base64 4.struct 5.hashlib 6.itertools 7.contextlib 8.XM ...

  10. SpringMVC的RequestMapping

    在Http请求中,我们每天都在使用Content-type来指定不同格式的请求信息,但是却很少有人去全面了解content-type中允许的值有多少,这里将讲解Content-Type的可用值,以及在 ...