5

FUSE ドライバーを開発していますが、それをデーモンとして (-f または -d フラグなしで) 実行すると、libcurl を介して作成されたすべての https 要求が失敗します。https リクエストを作成し、フォークして親プロセスを返し、新しいプロセスから 2 番目のリクエストを作成することで、エラーを再現できました。呼び出しを削除するforkか、http 要求を行うと、エラーは発生しません。

現在、公式のバグレポートを作成していますが、どうすれば機能するか知っている人はいますか?

これが私のコードと(ログファイル)出力です:

注: 私のプログラムを実行する場合は、/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, CURLOPT_URL, url.c_str());
    curl_easy_setopt(handle, CURLOPT_ERRORBUFFER, 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 log
curl error while sending: (35) SSL connect error
A 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 を実行しています。

4

1 に答える 1

4

これを機能させるには、 のcurl_global_cleanup前後に呼び出す必要がforkありcurl_global_initますforkforklibcurl メーリング リストの誰かが、これは、初期化が必要なライブラリを初期化した後に呼び出すときによくある問題であると述べました。

于 2013-03-18T00:22:53.650 に答える