|
|||||||
|
|
|
![]() |
|
|
Strumenti |
|
|
#1 |
|
Senior Member
Iscritto dal: Jan 2001
Città: Villanova di Guidonia (RM)
Messaggi: 1079
|
[C] select() e ricezione di SIGTERM
Ciao a tutti!
Ho un ciclo strutturato in questo modo: Codice:
...
while(!shutDown){
FD_SET(POP3Socket,&rfds);
FD_SET(SMTPSocket,&rfds);
timeout.tv_sec = 3;
timeout.tv_usec = 0;
selRet=select(nfds,&rfds,NULL,NULL,&timeout);
if (selRet < 0 && errno != EINTR){
PrintError("select() error: ");
}
else if(selRet < 0)
continue;
else if(selRet==0){
FD_SET(POP3Socket,&rfds);
FD_SET(SMTPSocket,&rfds);
timeout.tv_sec = 3;
timeout.tv_usec = 0;
}
else if(FD_ISSET(POP3Socket,&rfds)){
POP3Conn(&pArgs[idx[0]]);
}
else if(FD_ISSET(SMTPSocket,&rfds)){
SMTPConn(&pArgs[idx[1]]);
}
}
LinuxMPShutDown(pArgs);
...
__________________
Intel Core 2 Duo Q6600 G0, 4GB DDR2-800 A-Data, ABIT AB9, XFX GeForce 8800 GTS 320MB, Sound Blaster X-Fi Extreme Music, Seagate 320GB SATA2, Maxtor 80GB ATA-133, Western Digital 1TB SATA2 Ho concluso affari positivamente con: scandalf, Sinclair63, mstella, checcodag, wilson |
|
|
|
|
|
#2 |
|
Senior Member
Iscritto dal: Mar 2009
Messaggi: 753
|
... mmm ... come prima soluzione mi verrebbe in mente di istruire l'handler che viene chiamato quando arriva SIGTERM che setti il timeout a 0. In questo modo select() riprende ma va subito in timeout.
Allora quando controlli il valore di SelRetl che sarà 0 potesti aggiungere un'altro controllo su un'altra variabile, o meglio su un flag, che verrà settato ad uno dal signal handler. Se è 1 allora fai un bel break o quel che vuoi fare insomma.. Se è 0 è perchè c'è stato un timeout effettivo e prosegue come da copione. (Non credo sia un problema cambire timeout in quel momento.... dovresti provare...) Può andar bene? Magari pensandoci su si può perfezionare però dovrebbe andare così e fare quel che hai chiesto... Ultima modifica di Teo@Unix : 14-04-2010 alle 23:24. |
|
|
|
|
|
#3 |
|
Senior Member
Iscritto dal: Apr 2000
Città: Vicino a Montecatini(Pistoia) Moto:Kawasaki Ninja ZX-9R Scudetti: 29
Messaggi: 53971
|
Nel handler del segnale setta anche un flag che ti permette di rilevare che il programma deve essere terminato. Quindi se la select fallisce con quel flag settato allora non stampi alcun errore e termini l'esecuzione.
|
|
|
|
|
|
#4 |
|
Senior Member
Iscritto dal: Jan 2001
Città: Villanova di Guidonia (RM)
Messaggi: 1079
|
Io nel signal handler setto il flag di shutDown e infatti mi accorgo che esce da quel ciclo e lancia la LinuxMPShutDown (ho un log file dove scrivo tutte le operazioni che faccio). Il problema strano è che dopo aver eseguito questa funzione, invece di uscire dal programma riesegue la select() e questa non ritorna -1 ma rileva che è stato settato il socket POP3 (cioè arriva a questo punto FD_ISSET(POP3Socket,&rfds)); in quel caso chiama la POP3Conn (che si occupa di accettare la connessione tramite accept(), ma la accept ritorna errore perché il socket era stato chiuso dalla precedente chiamata a LinuxMPShutDown). Quindi in realtà non è la select() che fallisce. Spero di essere stato più chiaro.
__________________
Intel Core 2 Duo Q6600 G0, 4GB DDR2-800 A-Data, ABIT AB9, XFX GeForce 8800 GTS 320MB, Sound Blaster X-Fi Extreme Music, Seagate 320GB SATA2, Maxtor 80GB ATA-133, Western Digital 1TB SATA2 Ho concluso affari positivamente con: scandalf, Sinclair63, mstella, checcodag, wilson |
|
|
|
|
|
#5 |
|
Senior Member
Iscritto dal: Apr 2000
Città: Vicino a Montecatini(Pistoia) Moto:Kawasaki Ninja ZX-9R Scudetti: 29
Messaggi: 53971
|
Puoi comunque controllare il flag shutDown prima della accept. Poi se la accept ti ritorna un errore (perché può comunque capitare) se è settato il flag non lo consideri un errore, ma lo gestisci come la normale chiusura di una sessione.
|
|
|
|
|
|
#6 |
|
Senior Member
Iscritto dal: Jan 2001
Città: Villanova di Guidonia (RM)
Messaggi: 1079
|
Niente da fare. Sembra come se tornasse alla situazione precedente all'invio di SIGTERM (e quindi shutDown lo vede non settato persino prima della accept()). Questo è il log:
Codice:
Thu Apr 15 12:26:01 2010 [Process 2001|Thread 2001] - [MULTIPROCESS] Creating server socket... Thu Apr 15 12:26:01 2010 [Process 2001|Thread 2001] - [MULTIPROCESS] Server socket created. Thu Apr 15 12:26:01 2010 [Process 2001|Thread 2001] - Listening on new POP3 connection... Thu Apr 15 12:26:01 2010 [Process 2001|Thread 2001] - Listening on new SMTP connection... Thu Apr 15 12:26:12 2010 [Process 2001|Thread 2001] - Accepting connection from 127.0.0.1:25 Thu Apr 15 12:26:12 2010 [Process 2001|Thread 2001] - Listening on new SMTP connection... Thu Apr 15 12:26:23 2010 [Process 2001|Thread 2001] - Exiting from myMailServerd... Thu Apr 15 12:26:23 2010 [Process 2001|Thread 2001] - Deallocating resources... Thu Apr 15 12:26:25 2010 [Process 2001|Thread 2001] - All server resources deallocated. Thu Apr 15 12:26:29 2010 [Process 2008|Thread 2008] - Listening on new SMTP connection... Process 2008|Thread 2008 - POP3 accept() error:Transport endpoint is not connected
__________________
Intel Core 2 Duo Q6600 G0, 4GB DDR2-800 A-Data, ABIT AB9, XFX GeForce 8800 GTS 320MB, Sound Blaster X-Fi Extreme Music, Seagate 320GB SATA2, Maxtor 80GB ATA-133, Western Digital 1TB SATA2 Ho concluso affari positivamente con: scandalf, Sinclair63, mstella, checcodag, wilson |
|
|
|
|
|
#7 |
|
Senior Member
Iscritto dal: Jan 2001
Città: Villanova di Guidonia (RM)
Messaggi: 1079
|
Ho trovato il problema!!
In pratica quando chiamavo la SMTPConn (o la POP3Conn a seconda del tipo di connessione che arrivava), dentro tale funzione facevo la accept() e poi facevo la fork() per gestire la nuova connessione con un nuovo processo. Il problema nasceva dal fatto che nel processo figlio lanciavo una funzione e al ritorno da quella funzione invece di uscire dal processo facevo return. Ovviamente così facendo il padre terminava ma il figlio ritornava in quel famoso ciclo rifacendo la select() (di qui l'errore). Grazie a tutti lo stesso.
__________________
Intel Core 2 Duo Q6600 G0, 4GB DDR2-800 A-Data, ABIT AB9, XFX GeForce 8800 GTS 320MB, Sound Blaster X-Fi Extreme Music, Seagate 320GB SATA2, Maxtor 80GB ATA-133, Western Digital 1TB SATA2 Ho concluso affari positivamente con: scandalf, Sinclair63, mstella, checcodag, wilson |
|
|
|
|
| Strumenti | |
|
|
Tutti gli orari sono GMT +1. Ora sono le: 06:39.


















