Torna indietro   Hardware Upgrade Forum > Software > Programmazione

Ecovacs Deebot X11 Omnicyclone: niente più sacchetto per lo sporco
Ecovacs Deebot X11 Omnicyclone: niente più sacchetto per lo sporco
Deebot X11 Omnicyclone implementa tutte le ultime tecnologie Ecovacs per l'aspirazione dei pavimenti di casa e il loro lavaggio, con una novità: nella base di ricarica non c'è più il sacchetto di raccolta dello sporco, sostituito da un aspirapolvere ciclonico che accumula tutto in un contenitore rigido
Narwal Flow: con il mocio orizzontale lava i pavimenti al meglio
Narwal Flow: con il mocio orizzontale lava i pavimenti al meglio
Grazie ad un mocio rotante che viene costantemente bagnato e pulito, Narwal Flow assicura un completo e capillare lavaggio dei pavimenti di casa. La logica di intellignza artificiale integrata guida nella pulizia tra i diversi locali, sfruttando un motore di aspirazione molto potente e un sistema basculante per la spazzola molto efficace sui tappeti di casa
Panasonic 55Z95BEG cala gli assi: pannello Tandem e audio senza compromessi
Panasonic 55Z95BEG cala gli assi: pannello Tandem e audio senza compromessi
Con un prezzo di 2.999 euro, il Panasonic Z95BEG entra nella fascia ultra-premium dei TV OLED: pannello Primary RGB Tandem, sistema di raffreddamento ThermalFlow, audio Technics integrato e funzioni gaming avanzate lo pongono come un punto di riferimento
Tutti gli articoli Tutte le news

Vai al Forum
Rispondi
 
Strumenti
Old 12-07-2007, 11:59   #1
Edde
Senior Member
 
Iscritto dal: Oct 2001
Città: Prov. di Frosinone
Messaggi: 948
[JAVA] Fare il redirect dell'output di un processo

Ciao

Ho il seguente codice:

Codice:
Process proc = rt.exec(cmd, null, new File(jboss_home + "Generated/Crawler"));
cmd è un array di stringhe, il File è la directory di lavoro del processo.

Con questa riga di codice vado ad avviare un jar esterno, che eseguirà una serie di operazioni. Ora, in un utilizzo normale, il programma contenuto nel jar (che implementa i commons-logging di apache) stampa delle informazioni di log sulla shell da cui viene chiamato.

In questo caso però il nuovo processo non ha una propria shell su cui stampare, e quindi tutte quelle informazioni, che a me piacerebbe tenere, vanno perse.

Aggiungendo questo codice riesco quasi a risolvere il problema:

Codice:
StreamGobbler errorGobbler = new 
            StreamGobbler(proc.getErrorStream(), "ERROR");            
        
            // any output?
            StreamGobbler outputGobbler = new 
            StreamGobbler(proc.getInputStream(), "OUTPUT");
            
            // kick them off
            PrintStream out = new PrintStream(new FileOutputStream(new File("Generated/" + localID + "/Nutch/crawling.log")));
            
            errorGobbler.run(out);
            outputGobbler.run(out);
            
            out.close();          


int exitVal = proc.waitFor();
				System.out.println("Process exitValue: " + exitVal);
Dove StreamGobbler è una semplice classe che stampa su out le informazioni provenienti dai due stream. Dico "quasi risolto" per due ragioni:

- Ovviamente in questo modo l'applicazione principale rimane in attesa che il processo finisca, e ciò non è bello. Il nuovo processo deve andare per la sua strada, in maniera assolutamente parallela all'applicazione principale
- La stampa del log avviene sull' "ErrorStream", e non ne capisco il motivo...

La soluzione che io considererei ideale è questa:
Il nuovo processo parte per conto suo, e stampa tutte le sue belle informazioni di log sia su una shell che viene aperta (in modo che io, se lo desidero, possa seguire l'evolversi dell'operazione in tempo reale) sia in un file di log (in modo da rendere permanenti quelle informazioni.

Nel programma contenuto del jar il LOG viene creato con questa chiamata:

Codice:
public static final Log LOG = LogFactory.getLog(MyCrawl.class);
Se fosse possibile settare come voglio l'output di quell'oggetto, io credo che si potrebbe risolvere il problema, ma non mi sembra che esistano modi per farlo...

Vi ringrazio molto
Edde è offline   Rispondi citando il messaggio o parte di esso
Old 13-07-2007, 09:00   #2
Edde
Senior Member
 
Iscritto dal: Oct 2001
Città: Prov. di Frosinone
Messaggi: 948
Uppo
Edde è offline   Rispondi citando il messaggio o parte di esso
 Rispondi


Ecovacs Deebot X11 Omnicyclone: niente più sacchetto per lo sporco Ecovacs Deebot X11 Omnicyclone: niente più...
Narwal Flow: con il mocio orizzontale lava i pavimenti al meglio Narwal Flow: con il mocio orizzontale lava i pav...
Panasonic 55Z95BEG cala gli assi: pannello Tandem e audio senza compromessi Panasonic 55Z95BEG cala gli assi: pannello Tande...
HONOR Magic V5: il pieghevole ultra sottile e completo! La recensione HONOR Magic V5: il pieghevole ultra sottile e co...
Recensione Google Pixel 10 Pro XL: uno zoom 100x assurdo sempre in tasca (e molto altro) Recensione Google Pixel 10 Pro XL: uno zoom 100x...
Leica M-A no.5000000 'Papa Francesco': u...
Il nuovo Sony Xperia 10 VII si mostra on...
Samsung raddoppia: il Galaxy Z Fold 8 sa...
Gli smartphone premium sono sempre pi&ug...
Fusione nucleare, l'Italia entra in gioc...
AMD protagonista al CES 2026: il keynote...
Invia il tuo nome intorno alla Luna con ...
Apple presenta i nuovi iPhone 17 Pro e P...
Apple presenta iPhone 17: fotocamera Cen...
Apple annuncia l''impossibilmente sottil...
Apple Watch Series 11 ufficiale: il più ...
Apple svela Watch Ultra 3 e Watch SE 3: ...
AirPods Pro 3 ufficiali: cancellazione d...
Kia EV3 è una Xbox 'che fa brum':...
Nel 2026 cambiano le regole della F1. Me...
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: 06:47.


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