Kuinka selvittää, kuka käyttää tiedostoa Linuxissa


Tässä artikkelissa selitämme, kuinka voit selvittää, kuka käyttää tiettyä tiedostoa Linuxissa. Tämä auttaa sinua tuntemaan järjestelmän käyttäjän tai prosessin, joka käyttää avointa tiedostoa.

Voimme käyttää lsof-komentoa tietääksemme, käyttääkö joku tiedostoa, ja jos he käyttävät, kuka. Se lukee ytimen muistia etsiessään avoimia tiedostoja ja auttaa sinua listaamaan kaikki avoimet tiedostot. Tässä tapauksessa avoin tiedosto voi olla tavallinen tiedosto, hakemisto, lohkoerikoistiedosto, merkkien erikoistiedosto, stream, verkkotiedosto ja monia muita – koska Linuxissa kaikki on tiedostoa.

Lsofia käytetään tiedostojärjestelmässä tunnistamaan, kuka käyttää kyseisessä tiedostojärjestelmässä olevia tiedostoja. Voit suorittaa lsof-komennon Linux-tiedostojärjestelmässä ja tulos tunnistaa tiedostoa käyttävien prosessien omistajan ja prosessin tiedot seuraavassa tulosteessa.

lsof /dev/null
COMMAND    PID    USER   FD   TYPE DEVICE SIZE/OFF NODE NAME
systemd   1480 tecmint    0r   CHR    1,3      0t0    6 /dev/null
sh        1501 tecmint    0r   CHR    1,3      0t0    6 /dev/null
sh        1501 tecmint    1w   CHR    1,3      0t0    6 /dev/null
dbus-daem 1530 tecmint    0u   CHR    1,3      0t0    6 /dev/null
xfce4-ses 1603 tecmint    0r   CHR    1,3      0t0    6 /dev/null
xfce4-ses 1603 tecmint    1w   CHR    1,3      0t0    6 /dev/null
at-spi-bu 1604 tecmint    0r   CHR    1,3      0t0    6 /dev/null
dbus-daem 1609 tecmint    0u   CHR    1,3      0t0    6 /dev/null
at-spi2-r 1611 tecmint    0u   CHR    1,3      0t0    6 /dev/null
xfconfd   1615 tecmint    0u   CHR    1,3      0t0    6 /dev/null
xfwm4     1624 tecmint    0r   CHR    1,3      0t0    6 /dev/null
xfwm4     1624 tecmint    1w   CHR    1,3      0t0    6 /dev/null
xfce4-pan 1628 tecmint    0r   CHR    1,3      0t0    6 /dev/null
xfce4-pan 1628 tecmint    1w   CHR    1,3      0t0    6 /dev/null
Thunar    1630 tecmint    0r   CHR    1,3      0t0    6 /dev/null
Thunar    1630 tecmint    1w   CHR    1,3      0t0    6 /dev/null
xfdesktop 1632 tecmint    0r   CHR    1,3      0t0    6 /dev/null
xfdesktop 1632 tecmint    1w   CHR    1,3      0t0    6 /dev/null
....

Listaa käyttäjäkohtaiset avatut tiedostot suorittamalla seuraava komento korvaamalla tecmint todellisella käyttäjänimellä.

lsof -u tecmint
COMMAND    PID    USER   FD      TYPE             DEVICE  SIZE/OFF       NODE NAME
systemd   1480 tecmint  cwd       DIR                8,3      4096          2 /
systemd   1480 tecmint  rtd       DIR                8,3      4096          2 /
systemd   1480 tecmint  txt       REG                8,3   1595792    3147496 /lib/systemd/systemd
systemd   1480 tecmint  mem       REG                8,3   1700792    3150525 /lib/x86_64-linux-gnu/libm-2.27.so
systemd   1480 tecmint  mem       REG                8,3    121016    3146329 /lib/x86_64-linux-gnu/libudev.so.1.6.9
systemd   1480 tecmint  mem       REG                8,3     84032    3150503 /lib/x86_64-linux-gnu/libgpg-error.so.0.22.0
systemd   1480 tecmint  mem       REG                8,3     43304    3150514 /lib/x86_64-linux-gnu/libjson-c.so.3.0.1
systemd   1480 tecmint  mem       REG                8,3     34872    2497970 /usr/lib/x86_64-linux-gnu/libargon2.so.0
systemd   1480 tecmint  mem       REG                8,3    432640    3150484 /lib/x86_64-linux-gnu/libdevmapper.so.1.02.1
systemd   1480 tecmint  mem       REG                8,3     18680    3150450 /lib/x86_64-linux-gnu/libattr.so.1.1.0
systemd   1480 tecmint  mem       REG                8,3     18712    3150465 /lib/x86_64-linux-gnu/libcap-ng.so.0.0.0
systemd   1480 tecmint  mem       REG                8,3     27112    3150489 /lib/x86_64-linux-gnu/libuuid.so.1.3.0
systemd   1480 tecmint  mem       REG                8,3     14560    3150485 /lib/x86_64-linux-gnu/libdl-2.27.so
...

Toinen tärkeä lsof:n käyttötarkoitus on selvittää tietyn portin kuunteluprosessi. Tunnista esimerkiksi prosessin kuuntelu portissa 80 käyttämällä seuraavaa komentoa.

sudo lsof -i TCP:80
COMMAND  PID   USER   FD   TYPE DEVICE SIZE/OFF NODE NAME
httpd    903   root    4u  IPv6  20222      0t0  TCP *:http (LISTEN)
httpd   1320 apache    4u  IPv6  20222      0t0  TCP *:http (LISTEN)
httpd   1481 apache    4u  IPv6  20222      0t0  TCP *:http (LISTEN)
httpd   1482 apache    4u  IPv6  20222      0t0  TCP *:http (LISTEN)
httpd   1493 apache    4u  IPv6  20222      0t0  TCP *:http (LISTEN)
httpd   1763 apache    4u  IPv6  20222      0t0  TCP *:http (LISTEN)
httpd   2027 apache    4u  IPv6  20222      0t0  TCP *:http (LISTEN)
httpd   2029 apache    4u  IPv6  20222      0t0  TCP *:http (LISTEN)
httpd   2044 apache    4u  IPv6  20222      0t0  TCP *:http (LISTEN)
httpd   3199 apache    4u  IPv6  20222      0t0  TCP *:http (LISTEN)
httpd   3201 apache    4u  IPv6  20222      0t0  TCP *:http (LISTEN)

Huomaa: koska lsof lukee ytimen muistia etsiessään avoimia tiedostoja, nopeat muutokset ytimen muistissa voivat johtaa arvaamattomiin tulosteisiin. Tämä on yksi lsof-komennon käytön suurimmista haitoista.

Lisätietoja on lsof -manuaalisivulla:

man lsof

Siinä kaikki! Tässä artikkelissa olemme selittäneet kuinka tietää, kuka käyttää tiettyä tiedostoa Linuxissa. Olemme näyttäneet kuinka tunnistaa omistaja ja käsitellä tietoja prosesseille avoimen tiedoston avulla. Alla olevalla palautelomakkeella voit ottaa meihin yhteyttä, jos sinulla on kysyttävää tai kommentteja.