Ero sivun ”Signaali” versioiden välillä

Linux.fista
Siirry navigaatioon Siirry hakuun
(tällainen perusasiasivu)
 
 
(4 välissä olevaa versiota 3 käyttäjän tekeminä ei näytetä)
Rivi 1: Rivi 1:
Linuxissa ohjelmat voivat lähettää toisilleen erityyppisiä viestejä signaaleilla. Signaalien avulla saadaan ohjelmat tekemään tiettyjä asioita, ja useimmiten niitä käytetään ohjelmien lopettamiseen.
Ohjelmat eli [[prosessi]]t voivat Linuxissa saada toisensa tekemään tiettyjä asioita lähettämällä toisilleen signaaleita. Niitä käytetään yleisimmin ohjelmien sulkemiseen eli tappamiseen (engl. ''kill''). Erilaisista virhe- ja erikoistilanteista ilmoitetaan myös usein signaaleita lähettämällä.


Useimpien signaalien oletusvaikutus on ohjelman lopettaminen, mutta ohjelma voi määritellä oman tapansa suhtautua eri signaaleihin. Esimerkiksi [[komentorivi]]ohjelmalle lähetetään näppäinyhdistelmällä ctrl+c signaali 15 (''TERM''), joka tarkoittaa sitä, että ohjelma saa tallentaa tilansa ja sen jälkeen sen on sulkeuduttava. Tämä signaali esimerkiksi lähetetään kaikille ohjelmille järjestelmän sammuessa. Ohjelman ei kuitenkaan ole pakko totella tällaista signaalia.
Eri signaaleja voi lähettää [[komentorivi]]ltä joko näppäinyhdistelmillä (signaalit INT, QUIT ja STP) tai [[kill]]-komennolla. Ohjelmista käsin signaalien lähettäminen tapahtuu <tt>kill</tt>-järjestelmäkutsulla.


Signaali numero 9 (''KILL'') on ainoa signaali, jonka vaikutusta ohjelma ei voi muuttaa, vaan tämä signaali lopettaa kyseisen ohjelman suorituksen välittömästi. Esimerkiksi lopetettaessa ohjelmia [[kill]]-komennolla voidaan oletuksena käytettävän signaalin 15 sijasta käyttää voimakkaampaa signaalia 9 antamalla se parametrina:
Useimpien signaalien oletusvaikutus on ohjelman lopettaminen, mutta ohjelma voi määritellä oman tapansa suhtautua eri signaaleihin. Esimerkiksi näppäinyhdistelmällä <tt>Ctrl+C</tt> lähetetään signaali 2 (INT), joka tarkoittaa, että ohjelma saa tallentaa tilansa ja sen jälkeen sen pitäisi sulkeutua. Useat ohjelmat eivät kuitenkaan tämän signaalin saatuaan sulkeudu, vaan esimerkiksi vain kehottavat käyttäjää sulkemaan ohjelman sen oman käyttöliittymän kautta.
kill -9 ohjelman_pid


Edellä mainittujen signaalien lisäksi eräs yleinen signaali on signaali numero 1 (''HUP''). Se lähetetään ohjelmalle tilanteessa jossa yhteys, jonka kautta ohjelmaa käytettiin, katkeaa. Tämä tapahtuu esimerkiksi silloin kun [[pääte-emulaattori|päätteessä]] ajetaan komentoriviohjelmaa ja pääte suljetaan tai jos ohjelmaa ajetaan etäkoneella [[SSH]]-yhteyden yli. Monet ohjelmat reagoivat ''HUP''-signaaliin samalla tavalla kuin ''TERM''-signaaliin.
Eräs yleinen signaali on signaali numero 1 (HUP). Se lähetetään ohjelmalle tilanteessa jossa yhteys, jonka kautta ohjelmaa käytettiin, katkeaa. Tämä tapahtuu esimerkiksi silloin kun [[pääte-emulaattori]]ssa ajetaan komentoriviohjelmaa ja pääte-emulaattori suljetaan tai jos ohjelmaa ajetaan etäkoneella [[SSH]]-yhteyden yli. Monet ohjelmat reagoivat HUP-signaaliin samalla tavalla kuin signaaliin TERM.
 
Signaalit numero 9 (KILL) ja 19 (STOP) ovat ainoat signaalit, joiden vaikutusta ohjelma ei voi muuttaa, vaan nämä signaalit lopettavat (KILL) tai pysäyttävät (STOP) kyseisen ohjelman suorituksen välittömästi.
 
KILL-signaali annetaan yleensä koneen sulkemisen yhteydessä, kun ensin on varoitettu ohjelmia TERM-signaalilla. Sillä voi myös sulkea rikkinäisen ohjelman, joka ei tottele muita signaaleja. Koska ohjelmalle ei tällöin jää mahdollisuutta sulkeutua hallitusta ja esimerkiksi tallentaa keskeneräisiä töitä, on tätä signaalia yleensä syytä käyttää vasta viimeisenä vaihtoehtona ohjelman sulkemiseen.
 
==Yleisimpiä signaaleita==
* '''HUP''' ("hangup"): yhteys käyttäjään katkennut. Kun Unix-koneita käytettiin puhelinverkon välityksellä, annettiin tämä signaali yhteyden katketessa. Nykyään tyypillinen syy on [[pääte-emulaattori|pääteikkunan]] sulkeminen. Palvelinohjelmistoja voi usein pyytää lukemaan asetustietonsa uudestaan tällä signaalilla.
* '''INT''' ("interrupt"): käyttäjä on painanut Ctrl+C. Ohjelma sulkeutuu (useimmissa tapauksissa).
* '''QUIT''': käyttäjä on painanut näppäinyhdistelmää Ctrl+D (katso [[stty]]). Ohjelma sulkeutuu, mutta jättää [[core]]-tiedoston ohjelman toiminnan tutkimiseksi.
* '''KILL''': ydin lopettaa ohjelman ilman varoitusta
* '''USR1''', '''USR2''': ohjelmakohtaisesti määritelty
* '''SEGV''': väärä muistinosoitus eli vika ohjelmassa, muistipiireissä tms.
* '''TERM''': ohjelma pyydetään sulkeutumaan, esimerkiksi [[shutdown]]-käskyn takia
* '''STOP''': ydin pysäyttää ohjelman
* '''CONT''': ohjelman annetaan jatkaa
Signaalien nimet esitetään usein muodossa SIG + signaalinnimi, esimerkiksi SIGHUP.


== Katso myös ==
== Katso myös ==
*[[Dbus]]
*[[D-Bus]]
*[[Kill]]
*[[Kill]]
*[[Killall]]
*[[Killall]]
*[[Pkill]]
*[[Prosessi]]
*[[Prosessi]]


[[Luokka:Järjestelmä]]
[[Luokka:Järjestelmä]]
[[Luokka:Käsitteet]]
[[Luokka:Käsitteet]]

Nykyinen versio 16. helmikuuta 2021 kello 08.37

Ohjelmat eli prosessit voivat Linuxissa saada toisensa tekemään tiettyjä asioita lähettämällä toisilleen signaaleita. Niitä käytetään yleisimmin ohjelmien sulkemiseen eli tappamiseen (engl. kill). Erilaisista virhe- ja erikoistilanteista ilmoitetaan myös usein signaaleita lähettämällä.

Eri signaaleja voi lähettää komentoriviltä joko näppäinyhdistelmillä (signaalit INT, QUIT ja STP) tai kill-komennolla. Ohjelmista käsin signaalien lähettäminen tapahtuu kill-järjestelmäkutsulla.

Useimpien signaalien oletusvaikutus on ohjelman lopettaminen, mutta ohjelma voi määritellä oman tapansa suhtautua eri signaaleihin. Esimerkiksi näppäinyhdistelmällä Ctrl+C lähetetään signaali 2 (INT), joka tarkoittaa, että ohjelma saa tallentaa tilansa ja sen jälkeen sen pitäisi sulkeutua. Useat ohjelmat eivät kuitenkaan tämän signaalin saatuaan sulkeudu, vaan esimerkiksi vain kehottavat käyttäjää sulkemaan ohjelman sen oman käyttöliittymän kautta.

Eräs yleinen signaali on signaali numero 1 (HUP). Se lähetetään ohjelmalle tilanteessa jossa yhteys, jonka kautta ohjelmaa käytettiin, katkeaa. Tämä tapahtuu esimerkiksi silloin kun pääte-emulaattorissa ajetaan komentoriviohjelmaa ja pääte-emulaattori suljetaan tai jos ohjelmaa ajetaan etäkoneella SSH-yhteyden yli. Monet ohjelmat reagoivat HUP-signaaliin samalla tavalla kuin signaaliin TERM.

Signaalit numero 9 (KILL) ja 19 (STOP) ovat ainoat signaalit, joiden vaikutusta ohjelma ei voi muuttaa, vaan nämä signaalit lopettavat (KILL) tai pysäyttävät (STOP) kyseisen ohjelman suorituksen välittömästi.

KILL-signaali annetaan yleensä koneen sulkemisen yhteydessä, kun ensin on varoitettu ohjelmia TERM-signaalilla. Sillä voi myös sulkea rikkinäisen ohjelman, joka ei tottele muita signaaleja. Koska ohjelmalle ei tällöin jää mahdollisuutta sulkeutua hallitusta ja esimerkiksi tallentaa keskeneräisiä töitä, on tätä signaalia yleensä syytä käyttää vasta viimeisenä vaihtoehtona ohjelman sulkemiseen.

Yleisimpiä signaaleita[muokkaa]

  • HUP ("hangup"): yhteys käyttäjään katkennut. Kun Unix-koneita käytettiin puhelinverkon välityksellä, annettiin tämä signaali yhteyden katketessa. Nykyään tyypillinen syy on pääteikkunan sulkeminen. Palvelinohjelmistoja voi usein pyytää lukemaan asetustietonsa uudestaan tällä signaalilla.
  • INT ("interrupt"): käyttäjä on painanut Ctrl+C. Ohjelma sulkeutuu (useimmissa tapauksissa).
  • QUIT: käyttäjä on painanut näppäinyhdistelmää Ctrl+D (katso stty). Ohjelma sulkeutuu, mutta jättää core-tiedoston ohjelman toiminnan tutkimiseksi.
  • KILL: ydin lopettaa ohjelman ilman varoitusta
  • USR1, USR2: ohjelmakohtaisesti määritelty
  • SEGV: väärä muistinosoitus eli vika ohjelmassa, muistipiireissä tms.
  • TERM: ohjelma pyydetään sulkeutumaan, esimerkiksi shutdown-käskyn takia
  • STOP: ydin pysäyttää ohjelman
  • CONT: ohjelman annetaan jatkaa

Signaalien nimet esitetään usein muodossa SIG + signaalinnimi, esimerkiksi SIGHUP.

Katso myös[muokkaa]