|
|
cURL Mailing List Monthly Index Single Mail
curl-tracker mailing list Archives
[ curl-Bugs-1634515 ] Large Virtual Memory size
From: SourceForge.net <noreply_at_sourceforge.net>
Date: Thu, 18 Jan 2007 14:35:06 -0800
Bugs item #1634515, was opened at 2007-01-13 04:32
Please note that this message will contain a full copy of the comment thread,
Initial Comment:
I am a first time user of the libcurl library.
I run into an issue that when launching libcurl from threads, if the number of threads is above 9 the virtual memory consumption increases disproportionatly.
In the code sample below:
#include <fstream>
using namespace std;
pthread_mutex_t COUNTER_MUTEX = PTHREAD_MUTEX_INITIALIZER;
void* executeStuff (void* arg )
CURL* easyhandle = curl_easy_init();
char execStr[128];
curl_easy_setopt(easyhandle, CURLOPT_URL, execStr);
cout << "Executing : " << execStr << " Reslut ( 0 = OK): " << success << endl;
curl_easy_cleanup(easyhandle);
pthread_mutex_lock(&COUNTER_MUTEX);
int main ()
pthread_t thread_id;
for ( int i=0; i<9; ++i)
pthread_mutex_lock(&COUNTER_MUTEX);
while ( THREAD_COUNTER > 0 )
cout << "Done!" << endl;
return 0;
the amount of virtual memory consumed will be 90 MB, on the other hand if there are only 8 threads launched, only 80K of virtual memory be consumed.
Please advise,
Is this a normal behaviour or do I have problem with my code.
Thank you very much.
----------------------------------------------------------------------
Comment By: Daniel Stenberg (bagder)
Message:
Given that the posted examples have been pretty bad libcurl-using
Can you please provide an updated example that repeats this claimed
----------------------------------------------------------------------
Comment By: Dan Fandrich (dfandrich)
Message:
The pointer in write_data should definitely NOT be freed in the callback.
Beyond that, I don't know what else could be causing the problem. Can you
----------------------------------------------------------------------
Comment By: nickt (ntopilski)
Message:
I've modified the code to handle write callback:
size_t write_data ( void* ptr, size_t size, size_t nmemb, void *stream )
return size*nmemb;
void* executeStuff (void* arg )
CURL* easyhandle = curl_easy_init();
char execStr[128];
curl_easy_setopt(easyhandle, CURLOPT_URL, execStr);
cout << "Executing : " << execStr << " Reslut ( 0 = OK): " << success <<
curl_easy_cleanup(easyhandle);
pthread_mutex_lock(&COUNTER_MUTEX);
But the issue still persists. Since the IPs that I have
----------------------------------------------------------------------
Comment By: Dan Fandrich (dfandrich)
Message:
You're also not setting your own write callback function, so the default
----------------------------------------------------------------------
Comment By: nickt (ntopilski)
Message:
Dan,
I've followed your advice and added
curl_global_init(CURL_GLOBAL_ALL);
right at the top of main and
----------------------------------------------------------------------
Comment By: Dan Fandrich (dfandrich)
Message:
You need to call curl_global_init in main() before starting any threads.
----------------------------------------------------------------------
You can respond by visiting:
These mail archives are generated by hypermail. |
Page updated November 12, 2010.
web site info