C语言连接Mysql数据库,多线程问题

最近我写了一个接口程序,该接口启动了若干了线程,当监听到request请求时,某个线程会自动响应,连接数据库,处理数据,返回请求。这里我使用了Mysql提供的数据库接口,经常出现段错误使得程序崩溃。用dmesg命令查一下,有如下报错:

snetflow-API[792265]: segfault at ac ip 00007f52366cc220 sp 00007f5232ea6180 error 4 in libmysqlclient.so.20.3.2[7f523669a000+3a0000]

很明显这是mysql动态库的问题,但是这种官方库应该不会存在这么严重的bug,在网上查找资料,是需要添加两行代码的,保证线程间的安全。示例代码如下:

	MYSQL mysql;

	mysql_thread_init(); //初始化mysql对象之前,先开启线程安全
	mysql_init(mysql);
	if(!mysql_real_connect(mysql, database_host, database_username, database_password, database_name, database_port, NULL, 0))
	{
		myprintf("Failed to connect to Mysql: %s\n", mysql_error(mysql));
		return -1;
	}
......
	mysql_close(&mysql);
	mysql_thread_end(); //关闭mysql对象后,关闭线程安全

以上是我程序中的一个代码,每个线程都有会执行这段代码,都会有一个独立的MYSQL对象,不会再出现上述的错误。

更多关于mysql的高端知识,请参考这个大佬的博客:
https://www.cnblogs.com/stlong/p/6290335.html?utm_source=itdadao&utm_medium=referral

  • 1
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值