Sysbench测试Mysql但没有读取磁盘

问题描述

当我使用sysbench测试mysql时,我使用iotop来监视io,并且发现速度只有DiSH WRITEDISK READ的速度始终为0。然后我使用{{1 }},我发现缓冲区/缓存增加了,这是否意味着sysbench的测试数据不是写入磁盘,而是写入缓冲区,并且没有自动更新到磁盘?

非常感谢您!

解决方法

mysql在哪里运行?我不了解iotop及其测量方法,但是即使很小的sysbench运行也会产生大量的IO。可能是一个用户问题,也许是mysql在另一个用户下生成了io而没有被发现。

# you can isolate the db into a container and run sysbench against this to see
# if/when/how much IO there is.

docker run --rm -it --name mdb105 --network host -e MYSQL_ALLOW_EMPTY_PASSWORD=on mariadb:10.5 --port=10306

# in another terminal run
docker stats

# now run sysbench,and you will see enormous IO

# you can get another shell in container named mdb105 by:
docker exec -it --user root mdb105 bash

# mariadb:10.5 is based on ubuntu:20.04
# you could maybe run iotop inside the container

更新:我能够使用树莓派复制类似零IO的情况。实际上,泊坞窗统计数据没有显示任何IO,而数据显然已保存到磁盘。我最初的反应是,也许某些内核/发行版缺少某些功能,但是看起来好像不是内核/发行版,因为我在玩磁盘/ fs时看到了IO,即扩展的USB磁盘...我认为这更多与不支持此类统计信息的Micro SD卡及其控制器/驱动程序。而且由于您的TPS太低,我怀疑您也正在使用与Micro SD类似的产品。

这可能不会在ec2实例中发生。

相关问答

依赖报错 idea导入项目后依赖报错,解决方案:https://blog....
错误1:代码生成器依赖和mybatis依赖冲突 启动项目时报错如下...
错误1:gradle项目控制台输出为乱码 # 解决方案:https://bl...
错误还原:在查询的过程中,传入的workType为0时,该条件不起...
报错如下,gcc版本太低 ^ server.c:5346:31: 错误:‘struct...