linux – fork()后的libCurl SSL错误

linux – fork()后的libCurl SSL错误,第1张

概述我正在开发一个FUSE驱动程序,当我将它作为守护进程运行时(没有-f或-d标志),通过libcurl发出的所有https请求都会失败.我能够通过发出https请求,分叉和返回父进程,然后从新进程发出第二个请求来重现错误.如果我删除fork调用或发出http请求,则没有错误. 我现在正在制作官方错误报告,但是有谁知道我怎么能让它发挥作用? 这是我的代码和(logfile)输出: 注意:如果您运行我的 我正在开发一个FUSE驱动程序,当我将它作为守护进程运行时(没有-f或-d标志),通过libcurl发出的所有https请求都会失败.我能够通过发出https请求,分叉和返回父进程,然后从新进程发出第二个请求来重现错误.如果我删除fork调用或发出http请求,则没有错误.

我现在正在制作官方错误报告,但是有谁知道我怎么能让它发挥作用?

这是我的代码和(logfile)输出:

注意:如果您运行我的程序,请管道到/ dev / null,因为libcurl默认将接收到的缓冲区发送到stdout.

#include <curl/curl.h>#include <string>#include <unistd.h>#include <iostream>using namespace std;voID log(string str){   //Todo: remove    static const char logfile[] = "/home/austin/megalog";    file *f = fopen(logfile,"a");    fwrite(str.data(),str.size(),1,f);    fclose(f);    cout << str;}int main(int argc,char *argv[]){    string url = "https://www.Google.com/";    char errBuf[1024];    CURLcode err;    curl_global_init(CURL_GLOBAL_DEFAulT);    CURL *handle = curl_easy_init();    curl_easy_setopt(handle,CURLOPT_URL,url.c_str());    curl_easy_setopt(handle,CURLOPT_ERRORBUFFER,errBuf);    if ((err = curl_easy_perform(handle)))    {        log("first request Failed\n");        return 1;    }    curl_easy_cleanup(handle);    if(fork())        return 0;    handle = curl_easy_init();    curl_easy_setopt(handle,errBuf);    if ((err = curl_easy_perform(handle)))    {        log(string("curl error while sending: (") + to_string(err) + ") " + curl_easy_strerror(err) + "\n");        log(errBuf);    }    else        log("no error\n");    return 0;}

……和输出:

$g++ -std=c++11 main.cpp -lcurl$rm -f log$./a.out > /dev/null$cat logcurl error while sending: (35) SSL connect errorA PKCS #11 module returned CKR_DEVICE_ERROR,indicating that a problem has occurred with the token or slot.

我正在使用(最新的)libcurl版本7.29.0,(最新的)openssl版本1.0.1e,我正在使用内核版本3.7.4运行Fedora 18.

解决方法 要使其工作,您需要在fork之前调用curl_global_cleanup,在fork之后再次调用curl_global_init. libcurl邮件列表中的某个人提到在初始化需要初始化的库之后调用fork时这是一个常见问题. 总结

以上是内存溢出为你收集整理的linux – fork()后的libCurl SSL错误全部内容,希望文章能够帮你解决linux – fork()后的libCurl SSL错误所遇到的程序开发问题。

如果觉得内存溢出网站内容还不错,欢迎将内存溢出网站推荐给程序员好友。

欢迎分享,转载请注明来源:内存溢出

原文地址:https://www.54852.com/yw/1049956.html

(0)
打赏 微信扫一扫微信扫一扫 支付宝扫一扫支付宝扫一扫
上一篇 2022-05-25
下一篇2022-05-25

发表评论

登录后才能评论

评论列表(0条)

    保存