mysql-tpcc-mysql压测工具使用

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

前置条件

  1. 确保MySQL或MariaDB已安装 :在开始之前,请确保你的系统中已经安装了MySQL或者MariaDB数据库,并且正在运行。
    在编译之前需要安装mysql和mysql编译时链接的库
bash 复制代码
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源码。

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

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

    bash 复制代码
    make

tpcc-mysql包含所需要的sql脚本文件

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

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

    bash 复制代码
    # 创建数据库(例如: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. 运行测试

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

    语法:

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

    示例

    groovy 复制代码
    ./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 文件中的连接部分,添加:

groovy 复制代码
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

bash 复制代码
mysql -u root

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

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

执行以下 SQL 命令:

sql 复制代码
ALTER USER 'root'@'localhost' IDENTIFIED WITH mysql_native_password BY 'your_password';
FLUSH PRIVILEGES;

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

步骤 3:退出 MySQL

sql 复制代码
exit;
相关推荐
唐·柯里昂7981 小时前
野火鲁班猫5使用正点原子 RTL8188EUS Wifi模块驱动移植(Linux5.10 Debian系统) 解决zsh报错
linux·c语言·mcu·物联网·ubuntu·硬件工程·软件构建
源梦想1 小时前
机甲恐龙动作冒险网页小游戏Linux部署教程
linux·运维·服务器
3***g2051 小时前
SQLyog安装配置(注册码)连接MySQL
android·mysql·adb
Hoshino.411 小时前
从0开始学习Linux——第七部分:DNS(1)
linux·网络·学习
poemyang2 小时前
守护“真相之源”:深入理解数据库的预写日志(WAL)与检查点技术
mysql·日志技术
yiyeguzhou1002 小时前
论文解读:Overcoming the IOTLB wall for multi-100-Gbps Linux-based networking
linux·运维·服务器
Y淑滢潇潇2 小时前
RHCE Day 7 SHELL概述和基本功能
linux·前端·rhce
妄想出头的工业炼药师2 小时前
cuda如何安装卸载
linux·运维·服务器
q_19132846952 小时前
基于Springboot2+Vue2的旅游景点购票系统
java·vue.js·spring boot·后端·mysql·毕业设计·计算机毕业设计
柳鲲鹏2 小时前
LINUX下载编译libcamera
linux·运维·服务器