Torna indietro   Hardware Upgrade Forum > Software > Programmazione

MSI Maestro 500 Wireless: ANC e 90 ore di autonomia a 70 euro
MSI Maestro 500 Wireless: ANC e 90 ore di autonomia a 70 euro
Wireless 2.4 GHz, Bluetooth 5.4, cancellazione attiva del rumore, design pieghevole e un'autonomia che mette in imbarazzo prodotti che costano il doppio. Le Maestro 500 non eccellono in nulla, ma offrono tutto. E a questo prezzo è difficile chiedere di più
NL-LC1 è il primo dissipatore a liquido AIO di Noctua: silenzio è la parola d'ordine
NL-LC1 è il primo dissipatore a liquido AIO di Noctua: silenzio è la parola d'ordine
Dopo anni di attesa e una lunga fase di sviluppo, Noctua entra nel mercato dei dissipatori a liquido AIO con la nuova serie NL-LC1. Forte dell'esperienza maturata nel raffreddamento ad aria, l'azienda austriaca promette di portare la propria filosofia fatta di qualità costruttiva, attenzione ai dettagli e silenziosità anche in questo segmento. Abbiamo provato il nuovo sistema per scoprire se riesce a distinguersi in un mercato ormai molto competitivo.
Boox Go 10.3 (Gen II) Lumi: il tablet e-ink con Android 15 e penna, dal prezzo super
Boox Go 10.3 (Gen II) Lumi: il tablet e-ink con Android 15 e penna, dal prezzo super
Arrivato sul mercato italiano a fine marzo, la serie Boox Go 10.3 (Gen II) offre Android 15, penna da 4096 livelli e retroilluminazione opzionale (nel modello da noi provato, Lumi, presente). La serie si compone di due tablet ePaper che fanno da e-reader, blocco note digitale e persino browser, tutto a un prezzo che fa dimenticare i prodotti di brand più blasonati
Tutti gli articoli Tutte le news

Vai al Forum
Rispondi
 
Strumenti
Old 14-04-2010, 21:38   #1
Manugal
Senior Member
 
L'Avatar di Manugal
 
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);
...
Il problema sorge quando gli invio il segnale SIGTERM (lo uso per chiudere l'applicazione). Se è ancora in corso la select(), come da documentazione, si interrompe, chiama il signal handler e poi riprende. Il fatto è che lui esegue la LinuxMPShutDown (che chiude i socket) che si trova fuori dal ciclo, ma poi comunque riprende la select() e ovviamente va in errore perché i socket sono stati chiusi. Come posso ovviare a questo problema? Non c'è proprio il modo di evitare che select() riparta?
__________________
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
Manugal è offline   Rispondi citando il messaggio o parte di esso
Old 14-04-2010, 22:17   #2
Teo@Unix
Senior Member
 
L'Avatar di Teo@Unix
 
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 22:24.
Teo@Unix è offline   Rispondi citando il messaggio o parte di esso
Old 15-04-2010, 09:06   #3
cionci
Senior Member
 
L'Avatar di cionci
 
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.
cionci è offline   Rispondi citando il messaggio o parte di esso
Old 15-04-2010, 10:56   #4
Manugal
Senior Member
 
L'Avatar di Manugal
 
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
Manugal è offline   Rispondi citando il messaggio o parte di esso
Old 15-04-2010, 11:16   #5
cionci
Senior Member
 
L'Avatar di cionci
 
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.
cionci è offline   Rispondi citando il messaggio o parte di esso
Old 15-04-2010, 11:29   #6
Manugal
Senior Member
 
L'Avatar di Manugal
 
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
Exiting from myMailServerd viene stampato nel momento in cui invio SIGTERM. Deallocating resources e All server resources deallocated vengono stampati dalla LinuxMPShutDown() (che viene chiamata appunto per fare lo shutdown dell'applicazione). Il problema strano è che rientra dentro al ciclo dopo aver chiamato questa funzione.
__________________
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
Manugal è offline   Rispondi citando il messaggio o parte di esso
Old 15-04-2010, 12:31   #7
Manugal
Senior Member
 
L'Avatar di Manugal
 
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
Manugal è offline   Rispondi citando il messaggio o parte di esso
 Rispondi


MSI Maestro 500 Wireless: ANC e 90 ore di autonomia a 70 euro MSI Maestro 500 Wireless: ANC e 90 ore di autono...
NL-LC1 è il primo dissipatore a liquido AIO di Noctua: silenzio è la parola d'ordine NL-LC1 è il primo dissipatore a liquido A...
Boox Go 10.3 (Gen II) Lumi: il tablet e-ink con Android 15 e penna, dal prezzo super Boox Go 10.3 (Gen II) Lumi: il tablet e-ink con ...
Gigabyte MO32U24 OLED: il 4K a 240Hz su un pannello OLED ideale per il gaming Gigabyte MO32U24 OLED: il 4K a 240Hz su un panne...
Recensione realme 16 5G: lo smartphone con Selfie Mirror ha una batteria da 6550mAh Recensione realme 16 5G: lo smartphone con Selfi...
Tim Cook avverte gli utenti Apple: gli a...
Pentagono: il modello Grok di xAI impieg...
Senua usato come biglietto da visita: le...
Elon Musk incassa da Tesla 115 miliardi ...
Disney+ rimuove il supporto a Dolby Visi...
Rivoluzione su Edge: l'account Microsoft...
Google archivia Nest Mini e Nest Audio: ...
Apple rinvia il prossimo Air: nel 2027 c...
Super sconti Smart TV LG: c'è l'OLED C5 ...
Sopresa: l'erede di Dacia Spring si chia...
OpenAI brucia 3,7 miliardi di dollari al...
Trump anticipa l'accordo: Intel produrr&...
L'infrastruttura come fondamento dell'IA...
HONOR Watch 6 debutta in Italia: design ...
Paradromics avvia la sperimentazione uma...
Chromium
GPU-Z
OCCT
LibreOffice Portable
Opera One Portable
Opera One 106
CCleaner Portable
CCleaner Standard
Cpu-Z
Driver NVIDIA GeForce 546.65 WHQL
SmartFTP
Trillian
Google Chrome Portable
Google Chrome 120
VirtualBox
Tutti gli articoli Tutte le news Tutti i download

Strumenti

Regole
Non Puoi aprire nuove discussioni
Non Puoi rispondere ai messaggi
Non Puoi allegare file
Non Puoi modificare i tuoi messaggi

Il codice vB è On
Le Faccine sono On
Il codice [IMG] è On
Il codice HTML è Off
Vai al Forum


Tutti gli orari sono GMT +1. Ora sono le: 11:08.


Powered by vBulletin® Version 3.6.4
Copyright ©2000 - 2026, Jelsoft Enterprises Ltd.
Served by www3v