6. maaliskuuta 2008
Luokittelu ja avainsanat: GNU/Linux, etäyhteys, komentojono, komentojonot, komentojonotiedosto, komentojonotiedostot, nohup, suorittaminen, suoritus, uloskirjautuminen
- Lähtökohta
- Olen SSH-asiakasohjelman avulla etäyhteydessä tietokoneeseeni. Käynnistän etäyhteyden kautta tietokoneeni komentotulkissa
komentojono.sh -nimisen komentojonotiedoston. Komentojonotiedoston suorittaminen kestää kauan, ja lopulta minun täytyy sulkea SSH-yhteys ennen kuin komentojonotiedoston suoritus on päättynyt.
- Ongelma
- Kun kirjaudun ulos, komentojonotiedoston suorittaminen loppuu ennen aikojaan. Haluan, että komentojonotiedoston suorittaminen jatkuu loppuun saakka eikä katkea, kun katkaisen etäyhteyden.
- Ratkaisu
-
Käytän komentojonotiedoston käynnistämiseen nohup-komentoa:
nohup komentojono.sh > komentojonon_tuloste.txt &
Kun tämän jälkeen katkaisen SSH-yhteyden, komentojonon suorittaminen ei lopu ennenaikaisesti.
- Huomautus
- On myös ainakin periaatteessa mahdollista kaapata alun perin ilman nohup-komentoa käynnistetty komentojono suoritettavaksi ikään kuin se olisikin ajettu nohup-komennon alaisuudessa.
Yksi kommentti »
12. helmikuuta 2008
Luokittelu ja avainsanat: sovellukset, cron, crontab, komentojenhakupolku, komentojenhakupolut, komentojono, komentojonot, komentojonotiedosto, komentojonotiedostot, komentoriviprofiili, PATH-muuttuja, polku, suoritus
- Lähtökohta
-
Olen luonut komentojonotiedoston komentojono1, joka kutsuu komentojonotiedostoa komentojono2 seuraavanlaisella rivillä:
komentojono2 parametri1 parametri2
Olen tallentanut molemmat komentojonotiedostot kotihakemistoni alla olevaan bin-alihakemistoon. Bin-alihakemisto on määritelty komentojenhakupolkujen (PATH-muuttuja) joukkoon komentoriviprofiilissani. Olen muuttanut molempien komentojonotiedostojen oikeuksia niin, että molemmat toimivat komentoriviltä suoritettuina.
Olen lisännyt komentojono1:n crontab-tiedostooni siten, että se suoritetaan kerran minuutissa:
* * * * * /home/jani/bin/komentojono1
- Ongelma
- Kerran minuutissa automaattisesti suoritettuna komentojono1 ei toimi odottamallani tavalla, niin kuin se toimii komentoriviltä suoritettuna.
- Ongelman syy
- Olen kutsunut komentojono1:ssä komentojono2:ta ilman täyttä hakemistopolkua sen edessä. Kun
cron suorittaa komentojono1:n, se ei lue komentoriviprofiiliani sitä ennen, eikä siksi tiedä etsiä komentojono2:ta kotihakemistoni alla olevasta bin-hakemistosta.
- Ratkaisu
-
Muutan komentojono1:tä niin, että komentojono2:n kutsu tehdään käyttämällä täyttä hakemistopolkua itse tiedoston nimen edessä:
/home/jani/bin/komentojono2 parametri1 parametri2
Tämän jälkeen komentojono1:n automaattinen suoritus toimii tarkoittamallani tavalla.
- Huomautuksia
-
- Yleisesti ottaen cronin suoritus poikkeaa vuorovaikutteisesta komentorivisuorituksesta siksi, että Ubuntussa käytettävien vuorovaikutteisten komentorivien tulkkina toimii
Bash, ja cron taas puolestaan käyttää /bin/sh -komentoa, joka on symbolinen linkki dash-tulkkiin. Kun cron ajaa dashin ei-vuorovaikutteisena, se ei lue mitään profiilitiedostoja, ja siten nämä kaksi ympäristöä (crontab ja vuorovaikutteinen komentorivitulkkisovellus kuten Pääte) voivat poiketa toisistaan huomattavastikin.
-
Pitemmän päälle tässä kuvattua elegantimpi ratkaisu olisi luultavasti luoda komentojonotiedosto cron-suoritus, joka ottaa parametrinä komentojonotiedoston parametreineen. Cron-suoritus lukisi komentoriviprofiilini ja lisäksi selvittäisi DBUS_SESSION_BUS_ADDRESS -muuttujan arvon ennen kuin suorittaisi sille komentorivillä annetun komentojonotiedoston parametreineen.
Sen jälkeen lisäisin /home/jani/bin/cron-suoritus -komentojonon aina varsinaisen komentojonotiedoston ja sen parametrien eteen aina, kun haluaisin suorittaa komentojonotiedoston crontabin kautta automaattisesti. Silloin crontabin suorittamien komentojonotiedostojen ajo muistuttaisi enemmän niiden suorittamista komentoriviltä ilman, että jokaiseen komentojonotiedostoon täytyisi tehdä crontabista ajamisen huomioonottavia tarkennuksia ja erityisehtoja.
Koska cron-suoritus lukisi komentoriviprofiilini ennen sille annetun komentojonon suorittamista, ei tämän komentojonon eteen tarvitsisi crontabissa lisätä täyttä hakemistopolkua:
* * * * * /home/jani/bin/cron-suoritus komentojono parametri
2 kommenttia »