MySQLclient使用笔记

文章分析了在8.0.16及以上版本的libmysqlclient中使用异步操作与同步及ODBC的性能差异,以及写入时遇到的连接问题和解决方案。InnoDB引擎下,异步MySQLclient显著优于同步和ODBC。
摘要由CSDN通过智能技术生成

使用libmysqlclient库时,遇到的问题和性能分析总结
需要8.0.16之后版本才支持异步

一、测试情况
  1. 测试环境

    虚拟机:Ubuntu16.04
    CPU:4核
    内存:8G
    数据库表数据量:3万条
    libmysqlclient:8.0.25

  2. 测试量

    执行1万次,比如idwei 1 ~ 30000, 则将id=1 ~ 10000的数据进行更新或查询

  3. 测试写入结论

    对比mysqlclient异步操作、mysqlclient同步操作、odbc方式
    1.InnoDB引擎:
    MySQLclient异步:681ms
    MySQLclient同步:1778ms
    ODBC:1681ms
    2.MySIAM引擎:
    MySQLclient异步:4633ms
    MySQLclient同步:5202ms
    ODBC:5267ms
    3.InnoDB引擎:每次commit
    MySQLclient异步:3367ms
    MySQLclient同步:8308ms
    ODBC:2365ms

  4. 读取测试结论

    1. mysqlclient异步操作(1线程、4连接):200ms
二、使用时的坑
  1. 写入时问题和解决方案

    1. 连接1写入数据,连接2读取,当还没完全写入,连接2就读新写入的数据,则一直读取不到,如果写入等待一会再去读就能取到
    2. 连接1写入,连接1立马读取,也能读取到
    3. 改为自动提交(mysql_autocommit(mysql,true)),则连接1写入数据,连接2立马读取,也能读取到
    4. 连接1写入,连接2执行mysql_reload接口或者操作sql语句:FLUSH PRIVILEGES 之后连接2也能读取到
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值