当前位置: 首页 > news >正文

sysbench压测pgsql数据库 —— 筑梦之路

这里主要使用sysbench工具对Pgsql数据库进行基准测试。

1. 创建数据库和用户名

# 创建用户和数据库CREATE USER sysbench WITH PASSWORD '123456';CREATE DATABASE sysbench owner sysbench;# 给用户授权访问
vim  pg_hba.confhost    sysbench          sysbench          127.0.0.1/32         md5pg_ctl reload

2. 初始化数据库


sysbench \
--db-driver=pgsql \
--oltp-table-size=100000 \
--oltp-tables-count=25 \
--threads=1 \
--pgsql-host=127.0.0.1 \
--pgsql-port=5432 \
--pgsql-user=sysbench \
--pgsql-password=123456  \
--pgsql-db=sysbench  \
/usr/share/sysbench/tests/include/oltp_legacy/parallel_prepare.lua run

25 张表(从 sbtest1 到 sbtest25)每张表生成 100,000 行数据。

# 检查表是否创建成功psql -U sysbench -h 127.0.0.1 -p 5432 -d sysbench -W# 查看数据库大小psql -U sysbench -h 127.0.0.1 -p 5432 -d sysbench -W -c "select datname, pg_size_pretty(pg_database_size(datname)) as "DB_Size" from pg_stat_database where datname = 'sysbench'"

 3. 数据库压测

1)读写测试

sysbench \
--db-driver=pgsql \
--report-interval=2 \
--oltp-table-size=100000 \
--oltp-tables-count=25 \
--threads=64 \
--time=60 \
--pgsql-host=127.0.0.1 \
--pgsql-port=5432 \
--pgsql-user=sysbench \
--pgsql-password=123456 \
--pgsql-db=sysbench \
/usr/share/sysbench/tests/include/oltp_legacy/oltp.lua \
run

这条命令生成一个 OLTP 工作负载,使用名为 /usr/share/sysbench/tests/include/oltp_legacy/oltp.lua 的 LUA 脚本,并对 25 张表的 100,000 行数据,使用 64 个线程进行 60 秒的测试

# 监控数据库的活动select * from pg_stat_activity where usename = 'sysbench';

2)只读测试

sysbench \
--db-driver=pgsql \
--report-interval=2 \
--oltp-table-size=100000 \
--oltp-tables-count=24 \
--threads=64 \
--time=60 \
--pgsql-host=127.0.0.1 \
--pgsql-port=5432 \
--pgsql-user=sysbench \
--pgsql-password=123456 \
--pgsql-db=sysbench \
/usr/share/sysbench/tests/include/oltp_legacy/select.lua \
run
# 查询内存命中率select ((blks_hit)*100.00)/(blks_hit+blks_read) AS “perc_mem_hit” from pg_stat_database where datname like 'sysbench;

4. 优化建议

  1. )增加内存分配:如果服务器的内存充足,考虑增加 PostgreSQL 的共享缓冲区大小 (shared_buffers) 和工作内存 (work_mem),以提高内存命中率。

  2. )优化查询:在查询繁重的情况下,尽量避免全表扫描,可以通过创建索引来加速查询操作。

  3. )性能监控:定期使用 pg_stat_activity 和 pg_stat_database 来监控数据库性能,特别是在高负载情况下。

http://www.lryc.cn/news/542358.html

相关文章:

  • 数字IC后端培训教程| 芯片后端实战项目中base layer drc violation解析
  • Android之APP更新(通过接口更新)
  • 什么是 OCP 数据库专家
  • 基于AT89C51单片机的教室智能照明控制系统
  • DIP的实际举例
  • DeepSeek引领目标检测新趋势:如何通过知识蒸馏优化模型性能
  • vue2.x 中父组件通过props向子组件传递数据详细解读
  • 安装PHPStudy 并搭建DVWA靶场
  • RoCBert:具有多模态对比预训练的健壮中文BERT
  • 【C】堆的应用1 -- 堆排序
  • BGP配置华为——路径优选验证
  • 【原创】Windows11安装WSL“无法解析服务器的名称或地址”问题解决方法
  • 【CS285】高斯策略对数概率公式的学习笔记
  • R与RStudio简介及安装
  • TTL和CMOS的区别【数电速通】
  • Linux红帽:RHCSA认证知识讲解(二)配置网络与登录本地远程Linux主机
  • Threejs教程一【三要素】
  • 3-1 WPS JS宏工作簿的新建与保存(批量新建工作簿)学习笔记
  • 明日方舟一键端+单机+联网+安装教程+客户端apk
  • Redis基操
  • 学习笔记03——《深入理解Java虚拟机(第三版)》类加载机制知识总结与面试核心要点
  • w227springboot旅游管理系统设计与实现
  • 漏洞文字版表述一句话版本(漏洞危害以及修复建议),通常用于漏洞通报中简洁干练【持续更新中】
  • 项目——仿RabbitMQ实现消息队列
  • 嵌入式硬件篇---滤波器
  • JAVA最新版本详细安装教程(附安装包)
  • 《筑牢元宇宙根基:AI与区块链的安全信任密码》
  • 云原生周刊:云原生和 AI
  • rust笔记9-引用与原始指针
  • 信而泰CCL仿真:解锁AI算力极限,智算中心网络性能跃升之道