Torna indietro   Hardware Upgrade Forum > Software > Programmazione

Roborock Qrevo Curv 2 Flow: ora lava con un rullo
Roborock Qrevo Curv 2 Flow: ora lava con un rullo
Qrevo Curv 2 Flow è l'ultima novità di casa Roborock per la pulizia di casa: un robot completo, forte di un sistema di lavaggio dei pavimenti basato su rullo che si estende a seguire il profilo delle pareti abbinato ad un potente motore di aspirazione con doppia spazzola laterale
Alpine A290 alla prova: un'auto bella che ti fa innamorare, con qualche limite
Alpine A290 alla prova: un'auto bella che ti fa innamorare, con qualche limite
Abbiamo guidato per diversi giorni la Alpine A290, la prima elettrica del nuovo corso della marca. Non è solo una Renault 5 sotto steroidi, ha una sua identità e vuole farsi guidare
Recensione HONOR Magic 8 Lite: lo smartphone indistruttibile e instancabile
Recensione HONOR Magic 8 Lite: lo smartphone indistruttibile e instancabile
Abbiamo provato a fondo il nuovo Magic 8 Lite di HONOR, e per farlo siamo volati fino a Marrakech , dove abbiamo testato la resistenza di questo smartphone in ogni condizione possibile ed immaginabile. Il risultato? Uno smartphone praticamente indistruttibile e con un'autonomia davvero ottima. Ma c'è molto altro da sapere su Magic 8 Lite, ve lo raccontiamo in questa recensione completa.
Tutti gli articoli Tutte le news

Vai al Forum
Rispondi
 
Strumenti
Old 15-05-2006, 09:51   #1
Venticello
Senior Member
 
L'Avatar di Venticello
 
Iscritto dal: Jun 2005
Messaggi: 1376
[C/C++ Linux Suse] Monitoraggio di un PID

Salve a tutti, ho bisogno di tenere sotto controllo un eseguibile, rilanciandolo se va giù o chiudendolo se si determina una certa situazione, pensavo quindi di realizzare un eseguibile che lancia questa applicazione e ne monitorizza il pid, rilanciandola se si chiude. Entrambe queste applicazioni poi devono essere lanciate in background da uno script e terminate da un altro. Non essendo pratico di createprocess e simili potete darmi una mano?
Ciao
__________________
Butta giù le mano sa!!
NO ALL'ABOLIZIONE DELLA PARATA DEL 2 GIUGNO
Venticello è offline   Rispondi citando il messaggio o parte di esso
Old 15-05-2006, 13:31   #2
71104
Bannato
 
L'Avatar di 71104
 
Iscritto dal: Feb 2005
Città: Roma
Messaggi: 7029
CreateProcess su Linux...?
su Linux c'è solo fork/exec
71104 è offline   Rispondi citando il messaggio o parte di esso
Old 15-05-2006, 15:18   #3
DanieleC88
Senior Member
 
L'Avatar di DanieleC88
 
Iscritto dal: Jun 2002
Città: Dublin
Messaggi: 5989
Usa fork() e quando controlli il valore di ritorno con wait() verifica che sia un valore accettabile e non un codice di errore, in tal caso ripeti l'operazione e lanci di nuovo l'eseguibile. Non dovrebbe essere molto difficile.
__________________

C'ho certi cazzi Mafa' che manco tu che sei pratica li hai visti mai!
DanieleC88 è offline   Rispondi citando il messaggio o parte di esso
Old 15-05-2006, 15:56   #4
sottovento
Senior Member
 
L'Avatar di sottovento
 
Iscritto dal: Nov 2005
Città: Texas
Messaggi: 1722
Ciao,
generalmente questi tipi di problemi si risolvono facilmente con uno script: ti basta fare un ps -ef | grep nome_eseguibile e se il ritorno e' nullo, rilanci l'applicazione
__________________
In God we trust; all others bring data
sottovento è offline   Rispondi citando il messaggio o parte di esso
Old 15-05-2006, 19:18   #5
Venticello
Senior Member
 
L'Avatar di Venticello
 
Iscritto dal: Jun 2005
Messaggi: 1376
Intanto grazie a tutti per le risposte.
Lo script che fa questa cosa con il ps già c'è (tra l'altro non è così facile perchè se l'eseguibile non è in esecuzione cmq tra i processi ti fa vedere il grep...), il problema è che a sua volta deve essere chiuso da un altro script e non si riesce a fare perchè il ps non so per quale motivo non lo "vede", per questo volevo usare un eseguibile invece di uno script. La fork non va bene perchè sono 2 eseguibili diversi (oppure sono io che non so come usarla, ma dal man mi pare di aver capito che posso "forkare" solo all'interno dello stesso eseguibile e non lanciarne un altro). Cmq ho risolto facendo scrivere dall'applicazione il timestamp ogni secondo in un file e controllandolo dall'altro applicativo, quando non mi scrive più per 20" vuol dire che è giù e lo rilancio. E' un pò brutto ma per quello che mi serve va bene. Piuttosto ora ho altri 2 problemi: l'applicazione principale mi da anche il suo pid, che io utilizzo in caso di chiusura (sempre dall'applicazione che monitorizza) lanciando

system ("kill xxxx");

il problema è che non termina. Il pid è giusto, tanto è vero che se lo faccio da console funziona, invece chiamato tramite system non va. Altra questione, come faccio a sapere (in codice C) se un eseguibile è già in esecuzione, per evitare di lanciare più istanze?
Ciao e grazie della pazienza
__________________
Butta giù le mano sa!!
NO ALL'ABOLIZIONE DELLA PARATA DEL 2 GIUGNO
Venticello è offline   Rispondi citando il messaggio o parte di esso
Old 15-05-2006, 21:19   #6
k0nt3
Senior Member
 
Iscritto dal: Dec 2005
Messaggi: 7262
devi usare una exec se vuoi lanciare un eseguibile esterno

ps. ma ps (scusa il gioco di parole) con che opzioni lo lanci? se scrivi solo ps infatti ti mostra solo i processi lanciati da quella shell.. io uso l'opzione -A se vuoi più dettagli usa -ef come ha detto prima sottovento

Ultima modifica di k0nt3 : 15-05-2006 alle 21:22.
k0nt3 è offline   Rispondi citando il messaggio o parte di esso
Old 15-05-2006, 21:41   #7
Venticello
Senior Member
 
L'Avatar di Venticello
 
Iscritto dal: Jun 2005
Messaggi: 1376
Quote:
Originariamente inviato da k0nt3
devi usare una exec se vuoi lanciare un eseguibile esterno
Ho provato anche quella, il problema è che non ritorna, inoltre non mi riporta il pid.

Quote:
ps. ma ps (scusa il gioco di parole) con che opzioni lo lanci? se scrivi solo ps infatti ti mostra solo i processi lanciati da quella shell.. io uso l'opzione -A se vuoi più dettagli usa -ef come ha detto prima sottovento
io uso ps -ef | grep nome_applicazione.
__________________
Butta giù le mano sa!!
NO ALL'ABOLIZIONE DELLA PARATA DEL 2 GIUGNO
Venticello è offline   Rispondi citando il messaggio o parte di esso
Old 15-05-2006, 21:51   #8
k0nt3
Senior Member
 
Iscritto dal: Dec 2005
Messaggi: 7262
se usi exec il pid è lo stesso del programma che lancia la exec perchè non fa altro che sostituire il segmento di codice nuovo dentro il processo.
quindi per risolvere il tuo problema dovresti fare una fork e nel figlio fare una exec (in questo modo conosci il pid che ti viene restituito dalla funzione getpid() dentro il figlio)
k0nt3 è offline   Rispondi citando il messaggio o parte di esso
Old 15-05-2006, 21:58   #9
k0nt3
Senior Member
 
Iscritto dal: Dec 2005
Messaggi: 7262
una cosa di questo tipo per intenderci:

Codice:
...
pid = fork();
if(pid == 0)
{
  // figlio
  pidFiglio = getpid();
  execl("/path/nome_eseguibile", "parametro1", "parametro2", NULL);
  exit(0);
}
else
{
  // padre
  fai qualcosa con il pid del figlio;
  exit(0);
}
k0nt3 è offline   Rispondi citando il messaggio o parte di esso
Old 15-05-2006, 22:08   #10
k0nt3
Senior Member
 
Iscritto dal: Dec 2005
Messaggi: 7262
adesso che ci penso la variabile pidFiglio non conterrà il pid del figlio quando sei nel padre.. però potresti scriverlo tipo in un file. sarebbe più elegante usare i thread altrimenti
k0nt3 è offline   Rispondi citando il messaggio o parte di esso
Old 15-05-2006, 22:25   #11
beppegrillo
Senior Member
 
L'Avatar di beppegrillo
 
Iscritto dal: Mar 2004
Messaggi: 1455
Quote:
Originariamente inviato da k0nt3
adesso che ci penso la variabile pidFiglio non conterrà il pid del figlio quando sei nel padre.. però potresti scriverlo tipo in un file. sarebbe più elegante usare i thread altrimenti
scusa perchè il padre non ha la pid del figlio?
__________________
Ciao ~ZeRO sTrEsS~
beppegrillo è offline   Rispondi citando il messaggio o parte di esso
Old 15-05-2006, 22:29   #12
k0nt3
Senior Member
 
Iscritto dal: Dec 2005
Messaggi: 7262
Quote:
Originariamente inviato da beppegrillo
scusa perchè il padre non ha la pid del figlio?
si hai ragione! è nella variabile pid! scusate è parecchio che non uso la fork comunque sia nella variabile pidFiglio non leggi il pid del figlio perchè la assegni dentro il figlio e le due memorie sono distinte (duplicate dalla fork). ok ora dovrebbe funzionare
k0nt3 è offline   Rispondi citando il messaggio o parte di esso
Old 15-05-2006, 22:59   #13
beppegrillo
Senior Member
 
L'Avatar di beppegrillo
 
Iscritto dal: Mar 2004
Messaggi: 1455
Quote:
Originariamente inviato da k0nt3
si hai ragione! è nella variabile pid! scusate è parecchio che non uso la fork comunque sia nella variabile pidFiglio non leggi il pid del figlio perchè la assegni dentro il figlio e le due memorie sono distinte (duplicate dalla fork). ok ora dovrebbe funzionare
Non sò a quale memoria tu ti riferisca, ma dopo la fork entrambi i processi hanno una copia del processo che chiama la fork, poi da quel punto ogni processo figlio ha una copia locale di tale memoria, se fai una execl non rilanci una fork ma semplicemente sovrascrivi lo spazio di memoria assegnato.
__________________
Ciao ~ZeRO sTrEsS~
beppegrillo è offline   Rispondi citando il messaggio o parte di esso
Old 16-05-2006, 00:10   #14
71104
Bannato
 
L'Avatar di 71104
 
Iscritto dal: Feb 2005
Città: Roma
Messaggi: 7029
intendeva solo dire che essendosi creato un nuovo processo, ora esistono due spazi di memoria distinti.
71104 è offline   Rispondi citando il messaggio o parte di esso
Old 16-05-2006, 15:27   #15
k0nt3
Senior Member
 
Iscritto dal: Dec 2005
Messaggi: 7262
Quote:
Originariamente inviato da beppegrillo
Non sò a quale memoria tu ti riferisca, ma dopo la fork entrambi i processi hanno una copia del processo che chiama la fork, poi da quel punto ogni processo figlio ha una copia locale di tale memoria, se fai una execl non rilanci una fork ma semplicemente sovrascrivi lo spazio di memoria assegnato.
si mi sono spiegato male ma è esattamente quello che intendevo
k0nt3 è offline   Rispondi citando il messaggio o parte di esso
 Rispondi


Roborock Qrevo Curv 2 Flow: ora lava con un rullo Roborock Qrevo Curv 2 Flow: ora lava con un rull...
Alpine A290 alla prova: un'auto bella che ti fa innamorare, con qualche limite Alpine A290 alla prova: un'auto bella che ti fa ...
Recensione HONOR Magic 8 Lite: lo smartphone indistruttibile e instancabile Recensione HONOR Magic 8 Lite: lo smartphone ind...
Sony WF-1000X M6: le cuffie in-ear di riferimento migliorano ancora Sony WF-1000X M6: le cuffie in-ear di riferiment...
Snowflake porta l'IA dove sono i dati, anche grazie a un accordo con OpenAI Snowflake porta l'IA dove sono i dati, anche gra...
Windows 11 avrà a breve uno Speed...
Ask Intel: l'assistente IA che ti aiuta ...
Nasce Freedom.gov: il portale USA per ag...
Bose QuietComfort SC a 179,95€: ANC legg...
Attenzione ai conti: confermata falla sf...
30.000 Pa e lavaggio a 100°C: DREAME...
Nioh 3 vola oltre 1 milione di copie, la...
AMD Radeon RX 9060 XT: staccato (di molt...
WhatsApp introduce la condivisione della...
iPad con chip A16 a 339€: l'11'' con 128...
OpenClaw spaventa le aziende: perch&eacu...
Samsung T7 2TB crolla su Amazon: SSD por...
Tutte le JBL a prezzi da non perdere su ...
PS6 e RDNA 5: la GPU sarà 'quasi ...
Meta cambia rotta sul metaverso: Horizon...
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: 16:22.


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