当前位置:   article > 正文

解决使用 libcurl 遇到的多线程崩溃问题_解决 libcurl 高并发线程不安全

解决 libcurl 高并发线程不安全

使用 curl 访问 http 链接时,用 easy handle,阻塞方式访问时发现会每个访问启动一个线程去进行dns

想减少这种消耗,故此采用了 sh = curl_share_init(); curl_share_setopt(sh, CURLSHOPT_SHARE, CURL_LOCK_DATA_DNS);来启用dns cache功能,工作的挺好

后面在多个线程里使用同一个 sh 句柄时,偶尔会报错,研究代码发现,这个dns cache不是线程安全的,为每个线程创建一个 sh 句柄,解决了此问题


续:仍然存在libcurl调用到openssl后产生的崩溃,经调查,openssl 1.0.2 不是线程安全的,若要启动线程安全机制,需要自定义实现 openssl 用到的全局锁(大概是41个),并提供一个锁定/释放的 callback 函数,具体可以参考  OpenSSL_1_0_2l\crypto\threads\mttest.c 里的 thread_setup/thread_cleanup/win32_locking_callback 3个函数的实现。或者改用 openssl 1.1.0

libcurl 的声明如下:https://curl.haxx.se/libcurl/c/threadsafe.html

声明:本文内容由网友自发贡献,不代表【wpsshop博客】立场,版权归原作者所有,本站不承担相应法律责任。如您发现有侵权的内容,请联系我们。转载请注明出处:https://www.wpsshop.cn/w/在线问答5/article/detail/968680
推荐阅读
相关标签
  

闽ICP备14008679号