Увод у Лсоф

Под Линуком, многи објекти се сматрају датотеком, без обзира да ли је објекат заправо датотека, уређај, директоријум или сокет. Навођење датотеке је лако, за то је уграђена шкољка 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на вашем систему.


Leave a Comment

Инсталирајте Плеск на ЦентОС 7

Инсталирајте Плеск на ЦентОС 7

Користите другачији систем? Плеск је власничка контролна табла веб хоста која омогућава корисницима да управљају својим личним и/или клијентским веб локацијама, базама података

Подесите Цацти на Дебиан Јессие

Подесите Цацти на Дебиан Јессие

Увод Цацти је алатка отвореног кода за праћење и графику која је у потпуности заснована на РРД подацима. Преко Цацтуса можете надгледати скоро сваку врсту уређаја

Инсталирајте Летс Енцрипт ССЛ на ВордПресс апликацију једним кликом

Инсталирајте Летс Енцрипт ССЛ на ВордПресс апликацију једним кликом

Увод Летс Енцрипт је услуга ауторитета за сертификате која нуди бесплатне ТЛС/ССЛ сертификате. Цертбот поједностављује процес инсталације,

Подесите иРедМаил на Дебиан Вхеези

Подесите иРедМаил на Дебиан Вхеези

Користите другачији систем? Овај водич ће вам показати како да инсталирате групни софтвер иРедМаил на нову инсталацију Дебиан Вхеези-а. Требало би да користите сервис

Креирање Јекилл блога на Убунту 16.04

Креирање Јекилл блога на Убунту 16.04

Користите другачији систем? Јекилл је одлична алтернатива ВордПресс-у за блоговање или дељење садржаја. Не захтева никакве базе података и веома је лако и

Како подесити надоградње без надзора на Дебиан 9 (протежу)

Како подесити надоградње без надзора на Дебиан 9 (протежу)

Користите другачији систем? Ако купите Дебиан сервер, увек би требало да имате најновије безбедносне закрпе и ажурирања, без обзира да ли спавате или не

Како инсталирати и конфигурисати ПХП 7.0 или ПХП 7.1 на Убунту 16.04

Како инсталирати и конфигурисати ПХП 7.0 или ПХП 7.1 на Убунту 16.04

ПХП и повезани пакети су најчешће коришћене компоненте приликом постављања веб сервера. У овом чланку ћемо научити како да подесите ПХП 7.0 или ПХП 7.1 о

Како инсталирати Скуид проки на ЦентОС

Како инсталирати Скуид проки на ЦентОС

Скуид је популаран, бесплатни Линук програм који вам омогућава да креирате веб проки за прослеђивање. У овом водичу ћете видети како да инсталирате Скуид на ЦентОС да вас преокрене

Како инсталирати Лигхттпд (ЛЛМП Стацк) на ЦентОС 6

Како инсталирати Лигхттпд (ЛЛМП Стацк) на ЦентОС 6

Увод Лигхттпд је форк Апацхе-а који има за циљ да буде много мање интензиван према ресурсима. Лаган је, отуда и његово име, и прилично је једноставан за употребу. Инсталлин

Три бесплатна контролна панела сервера (брза инсталација)

Три бесплатна контролна панела сервера (брза инсталација)

1. Виртуалмин/Вебмин Виртуалмин је моћна и флексибилна контролна табла за веб хостинг за Линук и УНИКС системе заснована на добро познатој веб бази отвореног кода

Подешавање Иии апликације на Убунту 14.04

Подешавање Иии апликације на Убунту 14.04

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

Коришћење екрана на Убунту 14.04

Коришћење екрана на Убунту 14.04

Сцреен је апликација која омогућава вишеструку употребу терминалских сесија унутар једног прозора. Ово вам омогућава да симулирате више прозора терминала где је ма

Подесите сопствени ДНС сервер на Дебиан/Убунту

Подесите сопствени ДНС сервер на Дебиан/Убунту

Овај водич објашњава како да подесите ДНС сервер користећи Бинд9 на Дебиан-у или Убунту-у. У целом чланку замените иоур-домаин-наме.цом у складу са тим. Ат тх

Коришћење Логротате за управљање датотекама евиденције

Коришћење Логротате за управљање датотекама евиденције

Увод Логротате је Линук услужни програм који поједностављује администрацију датотека евиденције. Обично се покреће једном дневно преко црон посла и управља базом евиденције

Конфигурисање статичког умрежавања и ИПв6 на ЦентОС 7

Конфигурисање статичког умрежавања и ИПв6 на ЦентОС 7

ВУЛТР је недавно направио измене на њиховој страни, и сада би све требало да ради добро из кутије са омогућеним НетворкМанагер-ом. Ако желите да онемогућите

Модификовање Ицинга2 да користи модел Мастер/Цлиент на ЦентОС 6 или ЦентОС 7

Модификовање Ицинга2 да користи модел Мастер/Цлиент на ЦентОС 6 или ЦентОС 7

Ицинга2 је моћан систем за праћење, и када се користи у моделу мастер-цлиент, може да замени потребу за провером праћења заснованом на НРПЕ. Главни клијент

Подесите Ред5 Медиа Сервер на Убунту 16.04

Подесите Ред5 Медиа Сервер на Убунту 16.04

Користите другачији систем? Ред5 је медијски сервер отвореног кода имплементиран у Јави који вам омогућава да покренете Фласх вишекорисничке апликације као што је ливе стреамин

Компајлирајте и инсталирајте Нгинк са модулом ПагеСпеед на Дебиан 8

Компајлирајте и инсталирајте Нгинк са модулом ПагеСпеед на Дебиан 8

У овом чланку ћемо видети како да компајлирате и инсталирате Нгинк маинлине из званичних извора Нгинк-а помоћу модула ПагеСпеед, који вам омогућава да

Како инсталирати Апацхе Цассандра 3.11.к на Убунту 16.04 ЛТС

Како инсталирати Апацхе Цассандра 3.11.к на Убунту 16.04 ЛТС

Користите другачији систем? Апацхе Цассандра је бесплатан систем за управљање НоСКЛ базом података отвореног кода који је дизајниран да обезбеди скалабилност, високу

Како инсталирати Ванилла Форум на Убунту 16.04

Како инсталирати Ванилла Форум на Убунту 16.04

Користите другачији систем? Ванилла форум је апликација отвореног кода написана у ПХП-у. Потпуно је прилагодљив, једноставан за коришћење и подржава екстерне

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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