微信公众号搜"智元新知"关注
微信扫一扫可直接关注哦!

Sysbench测试Mysql但没有读取磁盘

如何解决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实例中发生。

版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 dio@foxmail.com 举报,一经查实,本站将立刻删除。