curl multithread 에서 사용시 질문입니다.
curl 라이브러리를 링크하고 있는 AAA라이브러리
class AAA
{
protected:
char m_buf[65536];
unsitned int m_nWriteSize;
}
AAA 라이브러리에서는 멤버 변수를 들고 있으며
멀티스레드 환겨에서 사용하기 위하여
extern "C" size_t AAA::writer( void *source , size_t size , size_t nmemb , void *userData)
{
AAA* pAAA = (AAA*)userData;
if(pAAA == NULL)
return -1;
const int SIZE = size * nmemb;
pAAA->Write((char*)source, SIZE);
return SIZE;
}
int AAA::Write(char* pBuf, int size)
{
-> if(m_nWriteSize+size > M_PKT_DATA)
size = M_PKT_DATA-m_nWriteSize;
memcpy(m_buf+m_nWriteSize, pBuf, size);
m_nWriteSize += size;
return 0;
}
init()
{
g_sharecurl = curl_share_init();
curl_share_setopt(g_sharecurl,CURLSHOPT_LOCKFUNC, lock);
curl_share_setopt(g_sharecurl,CURLSHOPT_UNLOCKFUNC, unlock);
curl_share_setopt(g_sharecurl,CURLSHOPT_SHARE,CURL_LOCK_DATA_SHARE);
curl_share_setopt(g_sharecurl,CURLSHOPT_USERDATA,0);
g_easycurl = curl_easy_init();
if( g_easycurl == NULL )
{
curl_share_cleanup(g_sharecurl);
curl_global_cleanup();
return CERTIFY_ERR_CURL_INIT;
}
curl_easy_setopt(g_easycurl,CURLOPT_SHARE,g_sharecurl);
}
share 함수를 이용하여 lock, unlock 함수를 콜백함수로 등록하였습니다
Send(char* url, char* pBuf)
{
curl_easy_setopt(g_easycurl, CURLOPT_URL, url ) ;// 긁어올 url을 명시하고, url이 URL정보임을 알려준다.
curl_easy_setopt(g_easycurl, CURLOPT_NOPROGRESS , TRUE ) ;// no progress bar:
curl_easy_setopt(g_easycurl, CURLOPT_HEADER , FALSE ) ; //헤더를 받지않겠다.
curl_easy_setopt(g_easycurl, CURLOPT_WRITEDATA , this ) ;// body 데이터는 표준출력 하도록 한다.
curl_easy_setopt(g_easycurl, CURLOPT_WRITEFUNCTION , writer ) ;// body 데이터는 표준출력 하도록 한다.
//curl_easy_setopt(g_easycurl, CURLOPT_WRITEFUNCTION, WriteMemoryCallback);
//curl_easy_setopt(g_easycurl, CURLOPT_WRITEDATA, (void*)&chunk);
curl_easy_setopt(g_easycurl, CURLOPT_FOLLOWLOCATION , TRUE ) ;//위치 헤더가 존재하면 따라간다.
curl_easy_setopt(g_easycurl, CURLOPT_SSL_VERIFYPEER, FALSE);// 인증서 체크같은데 true 시 안되는 경우가 많다.
curl_easy_setopt(g_easycurl, CURLOPT_SSLVERSION,3); // SSL 버젼 (https 접속시에 필요)
curl_easy_setopt(g_easycurl, CURLOPT_TIMEOUT, TIMEOUT); // TimeOut 값
const CURLcode rc = curl_easy_perform( g_easycurl ) ;
if(m_nWriteSize > 0)
{
memcpy(pBuf,m_buf,m_nWriteSize);
m_nWriteSize = 0;
}
}
멀티스레드에서 Send() 호출시 두번째 처리 중 Write() 함수 첫번째 줄에서 브레이크 포인트가 잡힙니다
멀티스레드가 AAA 클래스를 각각 선언하여 사용하고 있구요
lock/unlock 함수에 로그를 넣어봐도 최초 등록시에만 호출이 되고
핸들 사용시 락 함수가 콜백되지 않습니다
그리고 CURLOPT_WRITEFUNCTION 콜백 함수에서 자꾸 죽는데...
원인이 뭘까요? 그리고 멀티스레드 환경에서 어떻게 써야 하는건가요?
답변 부탁드리겟습니다.
댓글 달기