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

mysql-tpcc-mysql压测工具使用

在Linux系统上安装和配置tpcc-mysql进行MySQL的TPC-C基准测试,通常涉及以下几个步骤。请注意,由于tpcc-mysql不是一个官方工具,它可能需要从第三方仓库获取,如Percona提供的版本。

前置条件

  1. 确保MySQL或MariaDB已安装:在开始之前,请确保你的系统中已经安装了MySQL或者MariaDB数据库,并且正在运行。
    在编译之前需要安装mysql和mysql编译时链接的库
sudo apt-get install mysql-server
sudo apt-get install mysql-client
sudo apt-get install libmysqlclient-dev

安装tpcc-mysql

  1. 克隆仓库

    可以从Percona的GitHub仓库获取tpcc-mysql源码。

    git clone https://github.com/percona/tpcc-mysql.git
    cd tpcc-mysql/src
    
  2. 编译源码

    tpcc-mysql目录下执行以下命令来编译源码。

    make
    

tpcc-mysql包含所需要的sql脚本文件
在这里插入图片描述

  1. 创建TPC-C表并加载数据

    使用tpcc-mysql提供的脚本创建必要的数据库、用户以及导入测试数据。

    # 创建数据库(例如:tpcc)
    mysql -e "CREATE DATABASE tpcc;"# 加载schema
    mysql tpcc < create_table.sql# 创建外键
    mysql tpcc < add_fkey_idx.sql# 加载初始数据,-w 参数指定仓库数量,默认为1,根据机器性能调整
    ./tpcc_load localhost -d tpcc user password -w 1000
    
  2. 运行测试

    使用如下命令开始测试,其中参数可以根据实际情况调整。
    语法:

    ./tpcc_start -h[host] -d[database] -u[user] -p[password] -w[warehouses] -c[connections] -r[warmup_time] -l[running_time]
    

    示例

    ./tpcc_start -hlocalhost -dtpcc1000 -uroot -pyour_password -w1000 -c64 -r30 -l120
    

参数说明:

  • -w1000:使用 1000 个仓库

  • -c64:并发连接数为 64

  • -r30:预热阶段 30 秒

  • -l120:测试运行 120 秒

运行完成后会输出 TPS(每秒事务数)、RT(响应时间)等指标。

常见问题

Q1: 报错 can’t connect to local MySQL server through socket ‘/tmp/mysql.sock’
A: 修改代码中连接方式为 TCP 而不是 socket。修改 tpcc.c 文件中的连接部分,添加:

my_data->sock = mysql_init(NULL);
mysql_real_connect(my_data->sock, "127.0.0.1", user, password, schema, 3306, NULL, 0);

你遇到的错误是:

1698, 28000, Access denied for user 'root'@'localhost'

❗问题原因

这个错误表示:

MySQL 拒绝了用户 root@localhost 的登录请求

这通常是因为 MySQL 的 root 用户使用了插件认证方式(如 auth_socketunix_socket),而不是传统的密码认证。这意味着即使你知道 root 用户“应该”有密码,也不能通过 -p 参数进行登录。


✅ 解决方法一:修改 root 用户的认证方式(推荐)

你可以让 root 用户使用标准的密码认证方式登录:

步骤 1:用免密方式登录 MySQL

mysql -u root

如果你能成功进入 MySQL 命令行,说明你是通过 socket 插件登录的。

步骤 2:修改 root 用户的认证方式并设置密码

执行以下 SQL 命令:

ALTER USER 'root'@'localhost' IDENTIFIED WITH mysql_native_password BY 'your_password';
FLUSH PRIVILEGES;

'your_password' 替换为你想设置的密码。

步骤 3:退出 MySQL

exit;

相关文章:

  • WIN--文件读写
  • Python函数异常处理底层实现原理
  • OpenLayers 加载ArcGIS瓦片数据
  • Spring AI系列之Spring AI 集成 ChromaDB 向量数据库
  • CVE-2024-36467 Zabbix权限提升
  • 新质生产力引擎:营销枢纽智能体贯通全链路,AI赋能企业数字化运营高效升级!
  • 关于(stream)流
  • Few-shot Personalized Scanpath Prediction
  • Windows中安装Neo4j图数据库的配置
  • Python基础语法(十四):Python常用内置模块及功能
  • C++基础算法————递推
  • 编写一个算法frequency,统计在一个输入字符串中各个不同字符出现的频度。用适当的测试数据来验证这个算法
  • 记一个小问题:Cookie 作用域规则
  • STM32CubeMX配置使用通用定时器产生PWM
  • 洛谷——P3372 【模板】线段树 1
  • 110 kV覆冰绝缘子电场分布特性有限元分析报告
  • 运行打印Hello World启动了多少线程?
  • 性能测试之全链路压测及实施策略
  • 每日算法刷题Day16 5.26:leetcode不定长滑动窗口求子数组个数越短越合法2道题+恰好型3道题,用时1h20min
  • MySQL : MySQL的安装【CentOS 7】
  • 怎么自己做网站推广/十大经典事件营销案例
  • 新乐网站建设/公司网站怎么建立
  • 网站开发检测用户微信号/推广app有哪些
  • 南京环力建设有限公司网站/百度论坛
  • 自己建设网站的利弊/百度知道在线问答
  • 商丘行业网站建设开发公司/微信营销推广