2016-07-26 1 views
0

J'utilise threading pour publier des données sur le serveur. Threading fonctionne très bien et les données sont reçues sur le serveur, mais chaque fois que je reçois Segmentation Fault/core dump exception pour chaque demande.Threading dans Apache2.2

Ma fonction fil

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); 
} 

Mon fils initiant le code C

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; 
} 

Répondre

0

Vous ne pouvez pas utiliser r ou r-> piscine si Avancement de votre demande async ne bloque pas l'achèvement du courant demande. Sinon, votre mémoire est susceptible d'être réutilisée, provoquant des erreurs de segmentation.

(Si elle a fait la demande bloc achèvement, il y a probablement peu de raisons de le faire async)

Vous devez créer un (non r-> piscine sous-pool) piscine pour votre travail async produit si vous avez besoin d'utiliser le code avril dedans.

+0

merci pour la solution. –