并发链接MySQL

先吐槽一下libmysqlclientAPI的设计, 多个线程同时去connect竟然会core掉. 后来Google了一番, 才发现mysql_real_connect不是线程安全的, 须要一些额外的处理. 具体就是:mysql

  • 首先调用一次mysql_library_init, 在整个程序生命周期中只须要调用一次
  • 而后每次connect的时候, 而后以此调用mysql_init, mysql_thread_initmysql_real_connect
  • 链接关闭的时候, 以此调用mysql_closemysql_thread_end
  • 最后在程序退出以前调用mysql_library_end

PS: 关于第4点, 我没处理, 无非就是会内存泄漏. 关键我找不到C++的方式能够在main函数退出以前自动调用mysql_library_end. 太操蛋了.sql

相关文章
相关标签/搜索