2016-07-26 8 views
0

서버에서 데이터를 게시하기 위해 스레딩을 사용하고 있습니다. 스레딩이 잘 작동하고 데이터가 서버에서 수신되고 있지만 매회마다 모든 요청에 ​​대해 세그먼트 오류/코어 덤프 예외이 발생합니다.스레딩 in Apache2.2

내 스레드 기능

void* APR_THREAD_FUNC thread_init(apr_thread_t *thd,void *data) 
{ 
DATA_INFO_SOCK *dt=(DATA_INFO_SOCK*)data; 
apr_status_t result; 
result=apr_socket_sendto(dt->new_sock,dt->addr,0,dt->payload,dt->len); 
if(result==APR_SUCCESS) 
{ 
result=apr_socket_recvfrom(dt->addr,dt->new_sock,0,dt->resp,dt->rec_len); 
} 
result=apr_socket_close(dt->new_sock); 
apr_thread_exit(thd, APR_SUCCESS); 
} 

내 스레드를 시작하는 C 코드 당신은 R을 사용할 수 없습니다

int post_data_async(request_rec *r, char *host,char *encoded_data,int timout) 
{ 
apr_status_t result; 
apr_thread_t *thrd; 
apr_threadattr_t *thrdattr; 
char *final_msg; 
apr_socket_t *new_sock; 
apr_sockaddr_t *addr; 
DATA_INFO_SOCK *dt=apr_palloc(r->pool,sizeof(DATA_INFO_SOCK)); 
char *hostname=host; 
char *msg = "POST /getRequestData HTTP/1.1\r\n"\ 
      "HOST: %s\r\n" \ 
      "Accept: */*\r\n"\ 
      "Connection: keep-alive\r\n"\ 
      "Content-Length: %d\r\n"\ 
      "Content-Type: application/x-www-form-urlencoded\r\n\n%s"; 
apr_port_t port_no=80; 
apr_interval_time_t tmout=timout; 
apr_size_t *size=apr_palloc(r->pool,sizeof(apr_size_t)); 
apr_size_t *rcv=apr_palloc(r->pool,sizeof(apr_size_t)); 
final_msg=apr_psprintf(r->pool,msg,host,strlen(encoded_data),encoded_data); 
result=apr_socket_create(&dt->new_sock,APR_INET,SOCK_STREAM,APR_PROTO_TCP,r->pool); 
result=apr_sockaddr_info_get(&dt->addr,hostname,APR_INET,port_no,0,r->pool); 
result=apr_socket_connect(dt->new_sock,dt->addr); 
//result=apr_socket_timeout_set(dt->new_sock,tmout); 
*size=strlen(final_msg); 
//data preparation for thread 
dt->r=r; 
dt->resp=apr_palloc(r->pool,sizeof(char)*1024); 
dt->payload=final_msg; 
dt->len=size; 
dt->rec_len=rcv; 
result=apr_thread_create(&thrd,NULL,thread_init,(void*)dt,r->pool); 
ap_rputs("resule after thread",r); 
return 0; 
} 

답변

0

또는 비동기 요청이 완료 현재 완료를 차단하지 않습니다 R-> 풀 경우 의뢰. 그렇지 않으면 메모리가 재사용되어 segfault가 발생할 수 있습니다.

는 4 월 코드를 사용해야하는 경우 비동기 작업 항목에 대한

당신은 만들어야합니다 (비 R->를 풀 하위 풀) 풀 (가 블록 요청 완료를했다면, 아마 약간은 비동기 할 이유가) 그 안에.

+0

감사합니다. –