10 lsof Kommando Beispiller am Linux
Dëst ass eis lafend Serie vu Linux Kommandoen an an dësem Artikel wäerte mir lsof Kommando mat praktesche Beispiller iwwerpréiwen. lsof Bedeitung 'LiSt Open Files' gëtt benotzt fir erauszefannen wéi eng Dateie mat deem Prozess opgemaach sinn.
Wéi mir all wëssen, betruecht Linux/Unix alles als Datei (Päifen, Sockets, Verzeechnes, Apparater, etc). Ee vun de Grënn fir de lsof Kommando ze benotzen ass wann eng Disk net demontéiert ka ginn well et seet datt d'Dateien benotzt ginn. Mat der Hëllef vun dësem Kommando kënne mir einfach d'Dateien identifizéieren déi am Gebrauch sinn.
Am Beispill hei ënnen weist et eng laang Oplëschtung vun oppene Dateien, e puer vun hinnen ginn extrahéiert fir e bessert Verständnis ze weisen, déi d'Saile wéi Command, PID, USER, FD, TYPE, etc.
# lsof COMMAND PID USER FD TYPE DEVICE SIZE/OFF NODE NAME init 1 root cwd DIR 253,0 4096 2 / init 1 root rtd DIR 253,0 4096 2 / init 1 root txt REG 253,0 145180 147164 /sbin/init init 1 root mem REG 253,0 1889704 190149 /lib/libc-2.12.so init 1 root 0u CHR 1,3 0t0 3764 /dev/null init 1 root 1u CHR 1,3 0t0 3764 /dev/null init 1 root 2u CHR 1,3 0t0 3764 /dev/null init 1 root 3r FIFO 0,8 0t0 8449 pipe init 1 root 4w FIFO 0,8 0t0 8449 pipe init 1 root 5r DIR 0,10 0 1 inotify init 1 root 6r DIR 0,10 0 1 inotify init 1 root 7u unix 0xc1513880 0t0 8450 socket
Sektiounen an hir Wäerter si selbstverständlech. Wéi och ëmmer, mir iwwerpréiwen FD & TYPE Kolonnen méi präzis.
FD - steet fir e Dateideskriptor a kann e puer vun de Wäerter gesinn wéi:
- cwd aktuellen Aarbechtsverzeichnis
- rtd Root Verzeechnes
- txt Programmtext (Code an Daten)
- Mem Memory-mapped Datei
Och an der FD Kolonnnummeren wéi 1u ass den aktuellen Dateideskriptor a gefollegt vun u, r, w vu sengem Modus als:
- r fir liesen Zougang.
- w fir Schreifzougang.
- u fir Lies- a Schreifzougang.
TYPE - vu Fichieren an et ass Identifikatioun.
- DIR – Directory
- REG - Regelméisseg Datei
- CHR – Charakterspezial Datei.
- FIFO - Éischt Eréischt Eraus
De Kommando ënnen weist d'Lëscht vun all opgemaachte Dateie vum Benotzer tecmint.
# lsof -u tecmint COMMAND PID USER FD TYPE DEVICE SIZE/OFF NODE NAME sshd 1838 tecmint cwd DIR 253,0 4096 2 / sshd 1838 tecmint rtd DIR 253,0 4096 2 / sshd 1838 tecmint txt REG 253,0 532336 188129 /usr/sbin/sshd sshd 1838 tecmint mem REG 253,0 19784 190237 /lib/libdl-2.12.so sshd 1838 tecmint mem REG 253,0 122436 190247 /lib/libselinux.so.1 sshd 1838 tecmint mem REG 253,0 255968 190256 /lib/libgssapi_krb5.so.2.2 sshd 1838 tecmint mem REG 253,0 874580 190255 /lib/libkrb5.so.3.3
Fir all déi lafend Linux Prozesser vun engem spezifesche Port erauszefannen, benotzt just de folgende Kommando mat der Optioun -i. Dat Beispill hei ënnen wäert all déi lafend Prozesser vum Port 22 oplëschten.
# lsof -i TCP:22 COMMAND PID USER FD TYPE DEVICE SIZE/OFF NODE NAME sshd 1471 root 3u IPv4 12683 0t0 TCP *:ssh (LISTEN) sshd 1471 root 4u IPv6 12685 0t0 TCP *:ssh (LISTEN)
Am Beispill hei ënnen weist nëmmen IPv4 an IPv6 Netzwierkdateien op mat getrennten Kommandoen.
# lsof -i 4 COMMAND PID USER FD TYPE DEVICE SIZE/OFF NODE NAME rpcbind 1203 rpc 6u IPv4 11326 0t0 UDP *:sunrpc rpcbind 1203 rpc 7u IPv4 11330 0t0 UDP *:954 rpcbind 1203 rpc 8u IPv4 11331 0t0 TCP *:sunrpc (LISTEN) avahi-dae 1241 avahi 13u IPv4 11579 0t0 UDP *:mdns avahi-dae 1241 avahi 14u IPv4 11580 0t0 UDP *:58600 # lsof -i 6 COMMAND PID USER FD TYPE DEVICE SIZE/OFF NODE NAME rpcbind 1203 rpc 9u IPv6 11333 0t0 UDP *:sunrpc rpcbind 1203 rpc 10u IPv6 11335 0t0 UDP *:954 rpcbind 1203 rpc 11u IPv6 11336 0t0 TCP *:sunrpc (LISTEN) rpc.statd 1277 rpcuser 10u IPv6 11858 0t0 UDP *:55800 rpc.statd 1277 rpcuser 11u IPv6 11862 0t0 TCP *:56428 (LISTEN) cupsd 1346 root 6u IPv6 12112 0t0 TCP localhost:ipp (LISTEN)
Fir all de lafende Prozess vun oppene Dateien vum TCP Port ze lëschten rangéiert vun 1-1024.
# lsof -i TCP:1-1024 COMMAND PID USER FD TYPE DEVICE SIZE/OFF NODE NAME rpcbind 1203 rpc 11u IPv6 11336 0t0 TCP *:sunrpc (LISTEN) cupsd 1346 root 7u IPv4 12113 0t0 TCP localhost:ipp (LISTEN) sshd 1471 root 4u IPv6 12685 0t0 TCP *:ssh (LISTEN) master 1551 root 13u IPv6 12898 0t0 TCP localhost:smtp (LISTEN) sshd 1834 root 3r IPv4 15101 0t0 TCP 192.168.0.2:ssh->192.168.0.1:conclave-cpp (ESTABLISHED) sshd 1838 tecmint 3u IPv4 15101 0t0 TCP 192.168.0.2:ssh->192.168.0.1:conclave-cpp (ESTABLISHED) sshd 1871 root 3r IPv4 15842 0t0 TCP 192.168.0.2:ssh->192.168.0.1:groove (ESTABLISHED) httpd 1918 root 5u IPv6 15991 0t0 TCP *:http (LISTEN) httpd 1918 root 7u IPv6 15995 0t0 TCP *:https (LISTEN)
Hei hu mir de Root Benotzer ausgeschloss. Dir kënnt e bestëmmte Benotzer ausschléissen mat '^' mam Kommando wéi hei uewen gewisen.
# lsof -i -u^root COMMAND PID USER FD TYPE DEVICE SIZE/OFF NODE NAME rpcbind 1203 rpc 6u IPv4 11326 0t0 UDP *:sunrpc rpcbind 1203 rpc 7u IPv4 11330 0t0 UDP *:954 rpcbind 1203 rpc 8u IPv4 11331 0t0 TCP *:sunrpc (LISTEN) rpcbind 1203 rpc 9u IPv6 11333 0t0 UDP *:sunrpc rpcbind 1203 rpc 10u IPv6 11335 0t0 UDP *:954 rpcbind 1203 rpc 11u IPv6 11336 0t0 TCP *:sunrpc (LISTEN) avahi-dae 1241 avahi 13u IPv4 11579 0t0 UDP *:mdns avahi-dae 1241 avahi 14u IPv4 11580 0t0 UDP *:58600 rpc.statd 1277 rpcuser 5r IPv4 11836 0t0 UDP *:soap-beep rpc.statd 1277 rpcuser 8u IPv4 11850 0t0 UDP *:55146 rpc.statd 1277 rpcuser 9u IPv4 11854 0t0 TCP *:32981 (LISTEN) rpc.statd 1277 rpcuser 10u IPv6 11858 0t0 UDP *:55800 rpc.statd 1277 rpcuser 11u IPv6 11862 0t0 TCP *:56428 (LISTEN)
Dat Beispill hei ënnen weist datt de Benotzer tecmint Kommandoe benotzt wéi Ping an /etc Verzeichnis.
# lsof -i -u tecmint COMMAND PID USER FD TYPE DEVICE SIZE/OFF NODE NAME bash 1839 tecmint cwd DIR 253,0 12288 15 /etc ping 2525 tecmint cwd DIR 253,0 12288 15 /etc
De folgende Kommando mat der Optioun '-i' weist d'Lëscht vun all Netzwierkverbindungen 'LISTENING & ESTABLISHED'.
# lsof -i COMMAND PID USER FD TYPE DEVICE SIZE/OFF NODE NAME rpcbind 1203 rpc 6u IPv4 11326 0t0 UDP *:sunrpc rpcbind 1203 rpc 7u IPv4 11330 0t0 UDP *:954 rpcbind 1203 rpc 11u IPv6 11336 0t0 TCP *:sunrpc (LISTEN) avahi-dae 1241 avahi 13u IPv4 11579 0t0 UDP *:mdns avahi-dae 1241 avahi 14u IPv4 11580 0t0 UDP *:58600 rpc.statd 1277 rpcuser 11u IPv6 11862 0t0 TCP *:56428 (LISTEN) cupsd 1346 root 6u IPv6 12112 0t0 TCP localhost:ipp (LISTEN) cupsd 1346 root 7u IPv4 12113 0t0 TCP localhost:ipp (LISTEN) sshd 1471 root 3u IPv4 12683 0t0 TCP *:ssh (LISTEN) master 1551 root 12u IPv4 12896 0t0 TCP localhost:smtp (LISTEN) master 1551 root 13u IPv6 12898 0t0 TCP localhost:smtp (LISTEN) sshd 1834 root 3r IPv4 15101 0t0 TCP 192.168.0.2:ssh->192.168.0.1:conclave-cpp (ESTABLISHED) httpd 1918 root 5u IPv6 15991 0t0 TCP *:http (LISTEN) httpd 1918 root 7u IPv6 15995 0t0 TCP *:https (LISTEN) clock-app 2362 narad 21u IPv4 22591 0t0 TCP 192.168.0.2:45284->www.gov.com:http (CLOSE_WAIT) chrome 2377 narad 61u IPv4 25862 0t0 TCP 192.168.0.2:33358->maa03s04-in-f3.1e100.net:http (ESTABLISHED) chrome 2377 narad 80u IPv4 25866 0t0 TCP 192.168.0.2:36405->bom03s01-in-f15.1e100.net:http (ESTABLISHED)
Dat Beispill hei ënnen weist nëmmen deem säi PID 1 [One] ass.
# lsof -p 1 COMMAND PID USER FD TYPE DEVICE SIZE/OFF NODE NAME init 1 root cwd DIR 253,0 4096 2 / init 1 root rtd DIR 253,0 4096 2 / init 1 root txt REG 253,0 145180 147164 /sbin/init init 1 root mem REG 253,0 1889704 190149 /lib/libc-2.12.so init 1 root mem REG 253,0 142472 189970 /lib/ld-2.12.so
Heiansdo musst Dir all Prozesser fir e spezifesche Benotzer ëmbréngen. De Kommando ënnen wäert all d'Prozesser vum Tecmint Benotzer ëmbréngen.
# kill -9 `lsof -t -u tecmint`
Notiz: Hei ass et net méiglech Beispiller vun all verfügbaren Optiounen ze ginn, dëse Guide ass nëmme fir ze weisen wéi lsof Kommando ka benotzt ginn. Dir kënnt d'Man Säit vum lsof Kommando verweisen fir méi doriwwer ze wëssen. Deelt et w.e.g. wann Dir dësen Artikel nëtzlech fannt duerch eis Kommentarfeld hei drënner.