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. linux安装tree命令

    安装 yum install -y tree 使用,比如显示/root的2层树结构 tree -L 2 /root 效果 /root ├── \033 ├── code │   └── hellowo ...

  2. 让Visual Studio 自动添加头部注释信息

    在日常的开发过程中我们经常需要为我们的类文件添加注释和版权等信息,以前都是将信息文本复制.粘贴,要是添加一两个个还好,要是添加很多就显得很麻烦了.为了减少这种重复性的工作,有没有好的解决办法呢?答案是 ...

  3. VS2017 下使用 git. git服务器使用gitblit

    注意事项: 创建的GIT不要包括有中文, 不然会不成功的..... gitblit安装及配置及客户端下载略过...... 可参考:  https://www.cnblogs.com/jeremylee ...

  4. PHP 留言板练习

    登录页面同session一样 login页面 <form action="loginchuli.php" method="post"> <di ...

  5. pig(转载)

    本文可以让刚接触pig的人对一些基础概念有个初步的了解.本文大概是互联网上第一篇公开发表的且涵盖大量实际例子的Apache Pig中文教程(由Google搜索可知),文中的大量实例都是作者Darran ...

  6. $微信小程序开发实践点滴——Bmob基本REST API的python封装

    Refer:Bmob后端云REST API接口文档:http://docs.bmob.cn/data/Restful/a_faststart/doc/index.html 本文使用python对Bmo ...

  7. 入职第一个项目bug总结-2018/07/28

    此项目是正式入职后的第一个项目,可能各种原因重重,导致测试提出了如此多的bug,关于那些因为需求不清楚而导致的就不说了,bug总结如下: 一.ElementUI table组件出现横向滚动条 原因:因 ...

  8. HDU4628

    /*状态转移f[i]=min(f[i],f[j]+f[i^j]); 就是j状态+i^j状态=i状态,f[i]记录的是从i删除1要的最小步数*/ #include<string.h> #in ...

  9. JSP与Servlet之后台页面单条删除与多条删除的页面跳转之实现

    单条删除页面跳转 1.首先打开JSP页面,找到删除 2.这个时候要把它改成servlet的URL,并决定要传给后台什么数据,例如我需要传一个待删数据的ID id并不是什么见不得人的东西(而且是后台也不 ...

  10. vue2.0 transition 多个元素嵌套使用过渡

    在做vue的demo的时候遇到一个问题,多个嵌套的元素如何设置transition? 我的代码:代码中元素整体做平移,里面的inner中做旋转,实现一个圆形滚动的效果 <transition n ...