Увод у Лсоф

Под Линуком, многи објекти се сматрају датотеком, без обзира да ли је објекат заправо датотека, уређај, директоријум или сокет. Навођење датотеке је лако, за то је уграђена шкољка ls. Али шта ако корисник жели да види које датотеке тренутно отвара процес веб сервера? Или ако је тај корисник желео да сазна које су датотеке отворене у одређеном директоријуму? Ту lsofдолази у обзир. Замислите lsofкао lsса додатком "отворених датотека".

Имајте на уму да иако БСД-ови имају другачији услужни програм за овај посао fstat, неколико других укуса Уник-а (Соларис, на пример) такође поседује lsof. Опције и заставице су различите на другим платформама, као и изглед излаза, али генерално знање из овог чланка би требало да буде применљиво и на њих.

Прво, хајде да погледамо формат lsofизлаза и како треба да се чита. Уобичајени излаз lsofбез икаквих параметара би личио на следеће. Ово је исечено ради читљивости.

COMMAND    PID  TID       USER   FD      TYPE             DEVICE  SIZE/OFF       NODE NAME
init         1            root  cwd       DIR              254,1      4096          2 /
init         1            root  rtd       DIR              254,1      4096          2 /
init         1            root  txt       REG              254,1     36992    7077928 /sbin/init
init         1            root  mem       REG              254,1     14768    7340043 /lib/x86_64-linux-gnu/libdl-2.13.so
init         1            root  mem       REG              254,1   1603600    7340040 /lib/x86_64-linux-gnu/libc-2.13.so
init         1            root  mem       REG              254,1    126232    7340078 /lib/x86_64-linux-gnu/libselinux.so.1
init         1            root  mem       REG              254,1    261184    7340083 /lib/x86_64-linux-gnu/libsepol.so.1
init         1            root  mem       REG              254,1    136936    7340037 /lib/x86_64-linux-gnu/ld-2.13.so
init         1            root   10u     FIFO               0,14       0t0       4781 /run/initctl

Ове колоне значе следеће:

  • КОМАНДА - Процес коме припада отворена датотека, у овом примеру све је повезано са init.
  • ПИД - идентификациони број процеса наведеног процеса.
  • КОРИСНИК - Корисник под којим се процес покреће. Јер init, скоро увек је root.
  • ФД - Дескриптор датотеке, најчешћи је:
    • cwd- Тренутни радни директоријум (можда ћете приметити сличност са pwdкомандом која штампа тренутни радни директоријум).
    • rtd - Основни директоријум процеса.
    • txt- А text file, ово може значити или конфигурациону датотеку која се односи на процес или "изворни код" који се односи на (или припада) процесу.
    • mem - Такозвана "меморија мапирана датотека", што значи сегмент виртуелне меморије (читај: РАМ) који је додељен датотеци.
    • Број - број представља стварни дескриптор датотеке, знак иза броја је начин у којем се датотека отвара:
    • r - Читати.
    • w - Пишите.
    • u - Читају и пишу.
  • ТИПЕ - Одређује стварни тип датотеке, најчешћи су:
    • REG - Обичан досије.
    • DIR - Именик.
    • FIFO - Први улази - први излази.
  • УРЕЂАЈ – Главни и споредни број уређаја који држи датотеку.
  • ВЕЛИЧИНА - Величина датотеке, у бајтовима.
  • НОДЕ - Иноде број датотеке.
  • НАМЕ - Име датотеке.

Ово би за сада могло бити мало неодољиво, али ако радите са њима lsofнеколико пута, брзо ће вам утонути у мозак.

Као што је горе поменуто, излаз lsofје овде скраћен. Без икаквих аргумената или филтера, lsofпроизводи стотине линија излаза који ће вас само збунити.

Постоје два основна приступа за решавање овог проблема:

  • Користите једну или више lsofопција командне линије да бисте сузили резултате.
  • Проведите излаз кроз, на пример, grep.

Иако ова друга опција може звучати угодније јер нећете морати да памтите lsofопције командне линије, генерално није тако флексибилна и ефикасна, па ћемо се задржати на првој.

Замислимо да желите да отворите датотеку својим омиљеним уређивачем текста и да вам уређивач текста каже да се може отворити само у режиму само за читање јер јој други програм већ приступа. lsofпомоћи ће вам да сазнате ко је починилац:

lsof /path/to/your/file

Ово ће произвести излаз сличан овоме:

COMMAND   PID USER   FD   TYPE DEVICE SIZE/OFF    NODE NAME
vim 2679 root    5w   REG  254,1   121525 6035622 /root/lsof.txt

Очигледно сте заборавили да затворите и старију сесију! Веома сличан проблем се дешава када покушате да искључите НФС дељење и umountкаже вам да не може јер нешто још увек приступа монтираној фасцикли. Опет, lsofможе вам помоћи да идентификујете кривца:

lsof +D /path/to/your/directory/

Обратите пажњу на задњу косу црту, то је важно. У супротном lsofће се претпоставити да мислите на обичан фајл. Немојте да вас збуни +ознака испред - lsofима толико опција командне линије да су му потребне +поред уобичајених -. Излаз би изгледао овако:

COMMAND  PID USER   FD   TYPE DEVICE SIZE/OFF      NODE NAME
mocp    5637  music    4r   REG   0,19 10147719 102367344 /home/Music/RMS_GNU_SONG.ogg

То значи да је процес mocpса ПИД-ом 5637који припада кориснику musicотворио датотеку под називом RMS_GNU_SONG.ogg. Међутим, чак и након затварања тог процеса, и даље постоји проблем - НФС волумен се не може искључити.

lsofима -cзаставицу која приказује датотеке отворене са произвољним именом процеса.

lsof -c mocp

То би произвело излаз који би изгледао овако:

mocp    9383  music    4r   REG   0,19 10147719 102367344 /home/Music/ANOTHER_RMS_GNU_SONG.ogg

У овом примеру постоји још један пример mocpпокретања, који вас спречава да искључите дељење. Након што искључите тај процес, желите да се уверите да корисник musicнема отворених других потенцијално проблематичних датотека. lsofима -uзаставицу за приказивање датотека које је отворио одређени корисник. Запамтите, датотека није увек само обична датотека на вашем чврстом диску!

lsof -u music

Такође можете проследити неколико корисника, одвојених зарезима:

lsof -u music,moremusic

Важна напомена на подразумевано понашање lsof: резултати су ИЛИ базиран, што значи да ћете видети фајл резултате које је отворио процесима који су у власништву или корисника music, односно корисника moremusic. Ако желите да видите резултате који се подударају са процесима који су у власништву оба корисника, онда бисте морали да пренесете заставицу -a:

lsof -au music, moremusic

Пошто су оба корисника у групи musicusers, можете и да наведете датотеке на основу групе:

lsof -g musicusers

Такође можете комбиновати ознаке командне линије:

lsof -u music,moremusic -c mocp

or

lsof -u ^music +D /home/Music

У последњем реду смо додали још једну специјалну заставицу - ^, која означава логично НЕ . Ако је излаз празан након покретања те команде, онда ће демонтажа највероватније бити успешна.

У претходним примерима смо углавном гледали обичне датотеке. Шта је са утичницама и мрежним везама?

За листу свих тренутних мрежних веза lsofима -iзаставицу:

lsof -i

Резултат изгледа слично ономе што смо до сада видели...

COMMAND    PID USER   FD   TYPE DEVICE SIZE/OFF NODE NAME
owncloud  3509  myuser   25u  IPv4  44946      0t0  TCP strix.local:34217->myserver.vultr.com:https (ESTABLISHED)
firefox   3612  myuser   82u  IPv4  49663      0t0  TCP strix.local:43897->we-in-f100.1e100.net:https (ESTABLISHED)
ssh       3784  myuser    3u  IPv4  10437      0t0  TCP strix.local:51416->someserver.in:ssh (ESTABLISHED)
wget      4140  myuser    3w  IPv4  45586      0t0  TCP strix.local:54460->media.ccc.de:http (CLOSE_WAIT)

... осим једне разлике: уместо имена датотека или директоријума, колона NAMEсада приказује информације о вези. Свака веза се састоји од следећих делова:

  • Протокол.
  • Локално име хоста.
  • Изворни порт везе.
  • ДНС име одредишта.
  • Одредишна лука.
  • Статус везе.

Као и код многих других алата, можете да одустанете од решавања ДНС имена и портова ( -nи -P, респективно). Застава -iузима додатне параметре. Можете да одредите да ли желите да прикажете tcp, udpили icmpвезе или одређене портове:

lsof -i :25
or
lsof -i :smtp

Опет, параметри се могу комбиновати. Следећи пример...

lsof -i tcp:80

... ће вам показати само ТЦП везе користећи порт 80. Можете га комбиновати и са опцијама које већ знате из "класичних" датотека:

lsof -a -u httpd -i tcp

Ово ће вам показати све ТЦП везе које је отворио корисник httpd. Обратите пажњу на -aзаставицу, која мења подразумевано понашање lsof(као што је раније поменуто). Као и код већине алата командне линије, можете ићи изузетно дубоко. Следеће ће вам показати само ТЦП везе чије је стање „УСПОСТАВЉЕНО“:

lsof -i -s TCP:ESTABLISHED

У овом тренутку, требало би да имате основно разумевање о томе како lsofфункционише, заједно са неким уобичајеним случајевима употребе. За даље читање, погледајте ман страницу lsofна вашем систему.

Остави коментар

Успон машина: Примене вештачке интелигенције у стварном свету

Успон машина: Примене вештачке интелигенције у стварном свету

Вештачка интелигенција није у будућности, она је овде управо у садашњости. У овом блогу Прочитајте како су апликације вештачке интелигенције утицале на различите секторе.

ДДОС напади: кратак преглед

ДДОС напади: кратак преглед

Да ли сте и ви жртва ДДОС напада и збуњени сте методама превенције? Прочитајте овај чланак да бисте решили своја питања.

Да ли сте се икада запитали како хакери зарађују новац?

Да ли сте се икада запитали како хакери зарађују новац?

Можда сте чули да хакери зарађују много новца, али да ли сте се икада запитали како зарађују толики новац? Хајде да причамо.

Гоогле-ови револуционарни изуми који ће вам олакшати живот.

Гоогле-ови револуционарни изуми који ће вам олакшати живот.

Да ли желите да видите револуционарне изуме Гугла и како су ти изуми променили живот сваког људског бића данас? Затим читајте на блогу да бисте видели Гооглеове изуме.

Фридаи Ессентиал: Шта се десило са аутомобилима које покреће вештачка интелигенција?

Фридаи Ессентиал: Шта се десило са аутомобилима које покреће вештачка интелигенција?

Концепт самовозећих аутомобила који путују на путеве уз помоћ вештачке интелигенције је сан који већ неко време имамо. Али упркос неколико обећања, њих нема нигде. Прочитајте овај блог да сазнате више…

Технолошка сингуларност: далека будућност људске цивилизације?

Технолошка сингуларност: далека будућност људске цивилизације?

Како се наука развија великом брзином, преузимајући многе наше напоре, расте и ризик да се подвргнемо необјашњивој сингуларности. Прочитајте шта би сингуларност могла да значи за нас.

Функционалности слојева референтне архитектуре великих података

Функционалности слојева референтне архитектуре великих података

Прочитајте блог да бисте на најједноставнији начин упознали различите слојеве у архитектури великих података и њихове функционалности.

Еволуција складиштења података – Инфографика

Еволуција складиштења података – Инфографика

Методе складиштења података су се развијале можда од рођења података. Овај блог покрива еволуцију складиштења података на основу инфографике.

6 невероватних предности поседовања паметних кућних уређаја у нашим животима

6 невероватних предности поседовања паметних кућних уређаја у нашим животима

У овом дигиталном свету, паметни кућни уређаји постали су кључни део живота. Ево неколико невероватних предности паметних кућних уређаја о томе како они чине наш живот вредним живљења и једноставнијим.

Ажурирање додатка за мацОС Цаталина 10.15.4 изазива више проблема него што их решава

Ажурирање додатка за мацОС Цаталина 10.15.4 изазива више проблема него што их решава

Недавно је Аппле издао мацОС Цаталина 10.15.4 додатак за исправку проблема, али изгледа да ажурирање изазива више проблема који доводе до квара Мац машина. Прочитајте овај чланак да бисте сазнали више