mysql多线程coredump_多线程中使用curl致coredump问题

coredump时的调用栈:#0 0x081eff2c in addbyter ()#1 0x081f05b8 in dprintf_formatf ()#2 0x081f15cf in curl_mvsnprintf ()#3 0x081f0079 in curl_msnprintf ()#4 0x081ef55c in Curl_failf ()#5 0x081fa1a3 in C...
摘要由CSDN通过智能技术生成

coredump时的调用栈:

#0  0x081eff2c in addbyter ()

#1  0x081f05b8 in dprintf_formatf ()

#2  0x081f15cf in curl_mvsnprintf ()

#3  0x081f0079 in curl_msnprintf ()

#4  0x081ef55c in Curl_failf ()

#5  0x081fa1a3 in Curl_resolv_timeout ()

#6  0xeb8fbdd4 in ?? ()

#7  0x00000000 in ?? ()

coredump的原因是因为curl的DNS解析超时控制是使用SIGALARM实现的。

这样导致发现SIGALARM会出现多线程修改同一个全局变量,由此产生了COREDUMP。

问题发生的前提是设置了CURLOPT_TIMEOUT或CURLOPT_CONNECTTIMEOUT,并且值不为0。

解决办法:

1) 设置CURLOPT_NOSIGNAL的值为1

2) 使用c-ares(configure时指定参数--enable-ares)

lib/curl_setup.h(异步模式使用c-ares控制DNS解析超时):

只有当configure时指定了--enable-ares才会定义USE_ARES。

#ifdef USE_ARES

#  define CURLRES_ASYNCH

#  define CURLRES_ARES

/* now undef the stock libc functions just to avoid them being used */

#  undef HAVE_GETADDRINFO<

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值