Netfilter - Netfilter

Netfilter
Тұрақты шығарылым5.9.12[1] (24 қараша 2020); 12 күн бұрын (2020-11-24)) [±]
Алдын ала қарау5.10-rc6[2] (30 қараша 2020); 6 күн бұрын (2020-11-30)) [±]
ЖазылғанC
Операциялық жүйеLinux
Түрі
ЛицензияGNU GPL
Веб-сайтнетфильтр.org

Netfilter Бұл жақтау ұсынған Linux ядросы бұл әр түрлі мүмкіндік береді желілік -байланысты өңдеушілер түрінде жүзеге асырылатын операциялар. Netfilter әр түрлі функциялар мен әрекеттерді ұсынады пакетті сүзу, желі мекенжайын аудару, және порт аудармасы, бұл пакеттерді желі арқылы бағыттауға қажетті функционалдылықты қамтамасыз етеді тыйым салу пакеттің желі ішіндегі сезімтал орындарға жетуі.

Netfilter жиынтығын білдіреді ілгектер арнайы мүмкіндік беретін Linux ядросының ішінде ядро модульдері тіркелу қайта телефон соғу ядроның желілік стегімен жұмыс істейді. Әдетте трафикке сүзу және модификациялау ережелері түрінде қолданылатын функциялар желілік стек ішіндегі тиісті ілгекті айналып өтетін әрбір пакетке арналған.[3]

Тарих

Әр түрлі Netfilter компоненттерінің байланысы

Rusty Russell басталды netfilter / iptables жобасы 1998 жылы; ол сондай-ақ жобаның алдыңғы авторын жазды, ipchains. Жоба өсе келе ол негізін қалады Netfilter негізгі командасы (немесе жай коретам1999 жылы. Олар шығарған бағдарламалық жасақтама (деп аталады) нетфильтр бұдан әрі) GNU жалпыға ортақ лицензиясы (GPL) лицензиясы және 2000 жылдың наурызында ол 2.4.x нұсқасына біріктірілді Linux ядросының негізгі сызығы.

2003 жылдың тамызында Харальд Уэлт корпорацияның төрағасы болды. 2004 жылдың сәуірінде, жобаның бағдарламалық жасақтамасын таратушыларға қатысты жобаның қатаң бақылауынан кейін ендірілген жылы маршрутизаторлар GPL талаптарын сақтамай, а Неміс сот Вельтеге тарихи жағдай жасады бұйрық қарсы Sitecom GPL шарттарын орындаудан бас тартқан Германия (қараңыз) GPL-ге байланысты даулар ). 2007 жылдың қыркүйегінде корпорацияның жаңа төрағасы болып өткен жылдардағы дамуды басқарған Патрик МакХарди сайланды.

IPptable-ге дейін Linux брандмауэрін құруға арналған бағдарламалық жасақтама пакеттері басым болды ipchains Linux ядросында 2.2.x және ipfwadm Linux ядросында 2.0.x, ол өз кезегінде негізделген BSD Келіңіздер ipfw. Екі ipchains және ipfwadm екеуі де желілік кодты өзгертеді, сондықтан олар пакеттерді басқара алады, өйткені Linux ядросында Netfilter енгізілгенге дейін пакеттерді басқарудың жалпы құрылымы болмады.

Ipchains және ipfwadm пакеттік сүзгілеуді және NAT-ті біріктіреді (атап айтқанда, үш нақты түрі) НАТ, деп аталады маскарадтау, портты бағыттау, және қайта бағыттау), Netfilter пакеттік әрекеттерді төменде сипатталған бірнеше бөлікке бөледі. Әрқайсысы пакеттерге қол жеткізу үшін әр түрлі нүктелердегі Netfilter ілгектеріне қосылады. Қосылымды бақылау және NAT ішкі жүйелері ipchains және ipfwadm ішіндегі бастапқы нұсқаларға қарағанда анағұрлым жалпы және қуатты.

2017 жылы IPv4 және IPv6 ағынды жүктеме инфрақұрылымы қосылды, бұл бағдарламалық жасақтаманың ағын кестесін қайта жіберуді және аппараттық жүктемені қолдауды жылдамдатуға мүмкіндік берді.[4][5]

Пайдаланушы кеңістігінің бағдарламалары

Бұрынғы iptables пакеттік сүзгісімен Netfilter арқылы желілік пакеттердің ағымы

iptables

Аталған ядро ​​модульдері ip_tables, ip6_tables, arp_tables (астын сызу атаудың бөлігі), және ebtables Netfilter ілгегі жүйесінің бұрынғы пакеттік сүзу бөлігінен тұрады. Олар пакеттерді сүзуге немесе түрлендіруге болатын брандмауэр ережелерін анықтауға арналған кестеге негізделген жүйені ұсынады. Кестелерді қолданушы кеңістігі құралдары арқылы басқаруға болады iptables, ip6 кестелер, арктикалық заттар, және ebtables. Байқаңыз, ядро ​​модульдерінің де, қолданушы кеңістігінің де атаулары ұқсас болғанымен, олардың әрқайсысы әр түрлі функционалдығы бар жеке тұлға.

Әр кесте іс жүзінде өзінің ілгегі болып табылады және әр кесте белгілі бір мақсатқа қызмет ету үшін енгізілген. Netfilter-ге келетін болсақ, ол басқа кестелерге қатысты белгілі бір кестені белгілі бір тәртіпте орындайды. Кез-келген кесте өз-өзіне қоңырау шала алады, сонымен қатар ол өз ережелерін орындай алады, бұл қосымша өңдеу мен қайталануға мүмкіндік береді.

Ережелер тізбектерге, басқаша айтқанда, «ережелер тізбегіне» ұйымдастырылған. Бұл тізбектер алдын ала анықталған атаулармен, соның ішінде КІРІС, ШЫҒАРУ және АЛҒА. Бұл тізбек атаулары Netfilter стегіндегі шығу тегі туралы айтуға көмектеседі. Пакетті қабылдау, мысалы, түсіп кетеді ӨНДІРУ, ал КІРІС жергілікті жеткізілген деректерді білдіреді, және қайта жіберілген трафик АЛҒА шынжыр. Жергілікті өндірілген өнім. Арқылы өтеді ШЫҒАРУ және жіберілетін пакеттер бар БАСҚАРУ шынжыр.

Кестелерде реттелмеген Netfilter модульдері (төменде қараңыз) олардың жұмыс режимін таңдау үшін шығу тегі туралы тексеруге қабілетті.

iptable_raw модуль
Жүктелген кезде кез келген басқа Netfilter ілмегінің алдында шақырылатын ілмекті тіркейді. Ол деп аталатын кестені ұсынады шикі дестелерді, мысалы, қосылымды қадағалау сияқты жадты қажет ететін операцияларға қол жеткізбестен бұрын сүзуге болады.
iptable_mangle модуль
Ілмекті және тіркейді қателік Байланысты бақылаудан кейін іске қосылатын кесте (төменде қараңыз) (бірақ кез-келген басқа кестеден бұрын), сондықтан пакетке өзгертулер енгізілуі мүмкін. Бұл NAT немесе одан әрі сүзу сияқты ережелер бойынша қосымша өзгертулер енгізуге мүмкіндік береді.
iptable_nat модуль
Екі ілмекті тіркейді: желілік мекенжай аудармасына негізделген түрлендірулер («DNAT») сүзгі ілмегінен бұрын қолданылады, содан кейін бастапқы желілік мекенжай аудармасына негізделген түрлендірулер («SNAT») қолданылады. The желі мекенжайын аудару iptables үшін қол жетімді кесте (немесе «nat») тек «конфигурация дерекқоры» болып табылады НАТ тек кез-келген түрдегі сүзгілеуге арналмаған кескіндер.
iptable_filter модуль
Тіркеледі сүзгі кесте, жалпы мақсаттағы сүзгілеу үшін қолданылады (брандмауэр).
қауіпсіздік_фильтрі модуль
Міндетті қол жетімділікті (MAC) желілік ережелер үшін қолданады, мысалы, SECMARK және КҮНГЕРУ мақсаттар. (Бұлар «мақсат» деп аталатындар қауіпсіздіктің жақсартылған Linux маркерлеріне сілтеме жасайды.) Міндетті қатынасты басқару SELinux сияқты Linux қауіпсіздік модульдерімен жүзеге асырылады. Қауіпсіздік кестесі кез-келген MAC ережелерінен бұрын күшіне енуге мүмкіндік беретін сүзгі кестесіндегі кез-келген Дискретті Қатынауды Басқару (DAC) ережелеріне мүмкіндік беретін сүзгі кестесінің шақыруынан кейін аталады. Бұл кестеде келесі кіріктірілген тізбектер берілген: КІРІС (компьютерге келетін пакеттер үшін), ШЫҒАРУ (маршрутизацияға дейін жергілікті өндірілген пакеттерді өзгерту үшін), және АЛҒА (компьютер арқылы жіберілетін пакеттерді өзгерту үшін).

nftables

nftables - Netfilter-дің пакетті сүзетін жаңа бөлігі. nft ауыстыратын жаңа пайдаланушылар кеңістігінің утилитасы болып табылады iptables, ip6 кестелер, арктикалық заттар және ebtables.

nftables ядролық қозғалтқышы қарапайым қосады виртуалды машина желілік пакетті тексеру үшін байт кодын орындай алатын және сол пакетті қалай өңдеу керектігі туралы шешім қабылдауға қабілетті Linux ядросына. Осы виртуалды машинамен жүзеге асырылатын әрекеттер әдейі негізгі болып саналады: ол пакеттің өзінен деректер ала алады, байланысты метадеректерге көз жүгірте алады (мысалы, кіріс интерфейсі) және байланысты бақылау деректерін басқарады. Сол мәліметтер негізінде шешім қабылдау үшін арифметикалық, разрядтық және салыстыру операторларын пайдалануға болады. Виртуалды машина сонымен қатар бірнеше салыстыру операцияларын бір жиынтық іздеумен ауыстыруға мүмкіндік беретін мәліметтер жиынтығымен (әдетте IP-адрестермен) манипуляция жасауға қабілетті.[6]

Бұл бұрынғы Xtables (iptables және т.б.) кодынан айырмашылығы бар, оның протоколға терең енгендігі соншалық, оны төрт рет қайталауға тура келді - IPv4, IPv6, ARP және Ethernet көпірі үшін - брандмауэр сияқты қозғалтқыштар жалпыға бірдей қолдану үшін протоколға тән.[6] Негізгі артықшылықтар iptables бұл Linux ядросын жеңілдету ABI, азайту кодтың қайталануы, жақсартылған қате туралы есеп беру, және неғұрлым тиімді орындау, сақтау және ұлғайту, атомдық сүзу ережелерінің өзгеруі.

Дестені дефрагментациялау

The nf_defrag_ipv4 модуль IPv4 пакеттерін Netfilter қосылымын бақылауға жетпестен бұрын дефрагментациялайды (nf_conntrack_ipv4 модуль). Бұл ядро ​​ішіндегі қосылымды бақылау және NAT көмекші модульдері үшін қажет (олар «мини-» нысаны болып табылады)ALGs «) тек бөлшектерде емес, бүкіл пакеттерде ғана жұмыс істейді.

IPv6 дефрагментациялау модуль емес, ол интеграцияланған nf_conntrack_ipv6 модуль.

Байланысты бақылау

Netfilter фреймворкінің жоғарғы жағында жасалған маңызды ерекшеліктердің бірі - бұл қосылымды қадағалау.[7] Қосылымды қадағалау ядроға барлық логикалық желілік қосылыстарды бақылауға мүмкіндік береді немесе сессиялар және осымен байланысты құрайтын барлық пакеттерді байланыстырыңыз. NAT барлық байланысты пакеттерді дәл осылай аудару үшін осы ақпаратқа сүйенеді және iptables бұл ақпаратты мемлекетаралық брандмауэр ретінде пайдалану үшін қолдана алады.

Қосылу күйі TCP немесе SCTP күйі сияқты кез-келген жоғарғы деңгейден толығымен тәуелсіз. Мұның бір себебі мынада: жай пакеттерді жібергенде, яғни жергілікті жеткізілім болмаса, TCP қозғалтқышы міндетті түрде шақырылмауы мүмкін. Тіпті қосылымсыз режимдер сияқты UDP, IPsec (AH / ESP), GRE және басқа да туннельдеу протоколдары , кем дегенде, жалған байланыс күйіне ие болыңыз. Мұндай хаттамаларға арналған эвристикалық көбінесе әрекетсіздік үшін алдын-ала орнатылған күту уақытының мәніне негізделген, оның мерзімі аяқталғаннан кейін Netfilter байланысы тоқтатылады.

Әрбір Netfilter байланысы (деңгей-3 протоколы, бастапқы мекен-жай, тағайындалған мекен-жай, қабат-4 протоколы, деңгей-4 кілті) кортежімен ерекше түрде анықталады. 4-деңгей кілті тасымалдау протоколына байланысты; TCP / UDP үшін бұл порт нөмірлері, туннельдер үшін бұл олардың туннель идентификаторы болуы мүмкін, әйтпесе кортеждің бөлігі болмағандай нөлге тең болады. TCP портын барлық жағдайда тексеру үшін пакеттер міндетті түрде дефрагментацияланады.

Netfilter байланыстарын қолданушы кеңістігінің құралымен басқаруға болады қосылу.

iptables дестелерді сүзу ережелерін күштірек және басқаруды жеңілдету үшін қосылыстың күйлері, күйлері және басқалары сияқты ақпаратты тексеруді қолдана алады. Ең көп таралған мемлекеттер:

ЖАҢА
жаңа байланыс жасауға тырысуда
ОРНАТЫЛДЫ
бұрыннан бар байланыстың бөлігі
БАЙЛАНЫСТЫ
жаңа қосылуды бастайтын және «күтілген» пакетке тағайындалған; жоғарыда аталған мини-АЛГ-лар осындай үміттерді орнатады, мысалы, егер nf_conntrack_ftp модулі көреді FTP "PASV«команда
ЖАРЫМСЫЗ
пакет анықталды жарамсыз, мысалы. ол ұстанбайды TCP күйі диаграмма
ҚАЗАҚ
белгілі бір дестеге қосылуды қадағалауды айналып өту үшін әкімші тағайындай алатын ерекше күй (жоғарыдағы кестені қараңыз).

Кәдімгі мысал, қосылыстың ішкі жүйесі көретін бірінші пакет «жаңа», жауап «орнатылған» және ICMP қате «байланысты» болады. Белгілі бір байланысқа сәйкес келмеген ICMP қате пакеті «жарамсыз» болады.

Байланысты бақылау бойынша көмекшілер

Плагин модульдерін қолдану арқылы қосылымды қадағалауға қолданбалы деңгей хаттамалары туралы білім беруге болады және осылайша екі немесе одан да көп қосылыстардың «байланысты» екенін түсінуге болады. Мысалы, FTP хаттама. Басқару байланысы орнатылады, бірақ деректер берілген сайын оны беру үшін бөлек байланыс орнатылады. Қашан nf_conntrack_ftp модуль жүктелді, FTP деректер қосылымының бірінші пакеті «жаңа» орнына «байланысты» ретінде жіктеледі, өйткені бұл логикалық тұрғыдан бұрыннан бар қосылыстың бөлігі болып табылады.

Көмекшілер бір уақытта тек бір пакетті тексереді, сондықтан қосылуды бақылау үшін маңызды ақпарат екі пакетке бөлінсе, немесе IP фрагментациясы немесе TCP сегментациясы болса, көмекші заңдылықтарды мойындамайды, сондықтан оның жұмысын орындамайды. IP фрагментациясы дефрагментациялауды қажет ететін қосылымды қадағалау ішкі жүйесімен айналысады TCP сегментациясы өңделмеген. FTP жағдайында сегменттеу команданың «жанында» болмайды деп саналады PASV стандартты сегмент өлшемдерімен, сондықтан Netfilter-де қарастырылмайды.

Желілік адрес аудармасы

Әр байланыстың жиынтығы бар түпнұсқа мекен-жайлар және жауап мекенжайлары, бастапқыда бірдей басталады. NAT Netfilter-де жауап мекенжайын, қалаған жерінде портты өзгерту арқылы жүзеге асырылады. Дестелер алынған кезде, олардың байланыс кортежі жауап адрес жұбымен (және порттармен) салыстырылады. Бөлшектерден ада болу да NAT үшін талап болып табылады. (Егер қажет болса, IPv4 пакеттері қалыпты, Netfilter емес, IPv4 стегімен қайта жаңартылуы мүмкін.)

NAT көмекшілері

Қосылуды қадағалау көмекшілеріне ұқсас, NAT көмекшілері пакеттерді тексеріп, бастапқы мекен-жайларды пайдалы жүктемедегі жауап адрестерімен алмастырады.

Netfilter жобалары

Netfilter кодын тікелей қолданатын ядро ​​модульдері болмаса да, Netfilter жобасы бірнеше назар аударарлық бағдарламалық жасақтаманы орналастырады.

conntrack-құралдар

conntrack-құралдар - бұл жүйелік администраторларға Connection Tracking жазбалары мен кестелерімен өзара әрекеттесуге мүмкіндік беретін Linux үшін қолданушы кеңістігінің құралдары жиынтығы. Пакет құрамында conntrackd демон және командалық жол интерфейсі қосылу. Пайдаланушылар кеңістігі демоны conntrackd қол жетімділігі жоғары кластерге негізделген күйдегі брандмауэрлерді қосу үшін және брандмауэрді пайдалану статистикасын жинау үшін пайдалануға болады. Пәрмен жолының интерфейсі қосылу ескіргенге қарағанда қосылымды қадағалау жүйесіне икемді интерфейс ұсынады / proc / net / nf_conntrack.

ipset

Қосылымды қадағалау сияқты басқа кеңейтімдерден айырмашылығы, ipset[8] қатысты iptables Netfilter кодына қарағанда. ipset мысалы, Netfilter ілгектерін қолданбайды, бірақ шын мәнінде iptables IP жиынтықтарына минималды модификацияларды (жиынтық / таза) сәйкестендіретін модуль.

Пайдаланушы кеңістігінің құралы шақырылды ipset Linux ядросында «IP жиынтықтары» деп аталатын баптау, қолдау және тексеру үшін қолданылады. IP жиынтығында әдетте жиынтығы болады IP мекенжайлары, сонымен қатар оның «түріне» байланысты басқа желілік сандар жиынтығын қамтуы мүмкін. Бұл жиынтықтар жалаңашқа қарағанда әлдеқайда тиімді iptables ережелер, бірақ, әрине, жадтың ізі үлкен болуы мүмкін. Әр түрлі сақтау алгоритмдері (жадыдағы мәліметтер құрылымы үшін) берілген ipset пайдаланушыға оңтайлы шешімді таңдау үшін.

Бір жиынтықтағы кез-келген жазба басқа жиынтықпен байланыстырылуы мүмкін, бұл күрделі сәйкестендіруге мүмкіндік береді. Егер жоқ болса, жиынтықты жоюға (жоюға) болады iptables оған қатысты ережелер немесе басқа жиынтықтар.

SYN прокси-сервері

СИНПРОКСИЯ мақсат үлкен өңдеуді жасайды SYN су тасқыны Мұндай жағдайларда қосылымды қадағалаудың үлкен айыппұлдарынсыз мүмкін. Бастапқы бағыттау арқылы SYN сұраныстары СИНПРОКСИЯ мақсат, байланыстар тіркелген финалға жеткенге дейін қосылымды бақылау кезінде тіркелмейді ACK қосылымды қадағалаудан босату, ақаулы болуы мүмкін көптеген қосылыстарды есепке алу. Бұл өте үлкен SYN су тасқынын тиімді жолмен жеңуге болады.[9]

2013 жылдың 3 қарашасында, SYN прокси-функционалдығы Netfilter-ге біріктіріліп, Linux ядросының негізгі сызығының 3.12 нұсқасы шығарылды.[10][11]

улог

улог - бұл Netfilter ішкі жүйелерінен пакеттер мен оқиғалар туралы хабарламаларды қабылдау және тіркеу журналының қолданушысы. ip_tables пакеттерді кезек күту тетігі арқылы жеткізе алады және қосылымды қадағалау өзара әрекеттесе алады улог дестелер немесе оқиғалар туралы қосымша ақпарат алмасу үшін (мысалы, қосылымды жою, NAT орнату).

Пайдаланушылар кеңістігінің кітапханалары

Netfilter сонымен қатар кітапханалар жиынтығын ұсынады libnetfilter пайдаланушылар кеңістігінен әртүрлі тапсырмаларды орындау үшін қолдануға болатын олардың аттарының префиксі ретінде. Бұл кітапханалар GNU GPL 2 нұсқасы бойынша шығарылған, атап айтқанда, олар:

libnetfilter_queue
пайдаланушылар кеңістігінің пакеттік кезегін iptable-мен бірге орындауға мүмкіндік береді; негізінде libnfnetlink
libnetfilter_conntrack
пайдаланушылар кеңістігінен қосылымды қадағалау жазбаларын басқаруға мүмкіндік береді; негізінде libnfnetlink
libnetfilter_log
iptables жасаған журналдық хабарламаларды жинауға мүмкіндік береді; негізінде libnfnetlink
libnl-3-netfilter
кезектерде, қосылуды қадағалауда және журналдарда операцияларға мүмкіндік береді; бөлігі libnl жоба[12]
libiptc
iptables брандмауэр ережелеріне өзгерістер енгізуге мүмкіндік береді; ол кез-келгеніне негізделмеген желілік сілтеме кітапхана және оның API ішінен қолданылады iptables коммуналдық қызметтер
libipset
IP жиынтықтарындағы операцияларға мүмкіндік береді; негізінде libmnl.

Netfilter шеберханалары

Netfilter жобасы әзірлеушілер үшін жыл сайынғы кездесу ұйымдастырады, ол ағымдағы зерттеулер мен әзірлемелерді талқылау үшін қолданылады. Netfilter 2018 семинары Германияның Берлин қаласында 2018 жылдың маусым айында өтті.[13]

Сондай-ақ қараңыз

Пайдаланылған әдебиеттер

  1. ^ Кроах-Хартман, Грег (2 желтоқсан 2020). «Linux 5.9.12». LKML (Тарату тізімі). Алынған 2 желтоқсан 2020.
  2. ^ Торвальдс, Линус (30 қараша 2020). «Linux 5.10-rc6». LKML (Тарату тізімі). Алынған 30 қараша 2020.
  3. ^ «netfilter / iptables жобасының басты беті - netfilter.org жобасы». netfilter.org. Алынған 2014-07-04.
  4. ^ «Ағынды жүктеме инфрақұрылымы». LWN.net.
  5. ^ «Ағынды жүктеме инфрақұрылымы». LWN.net.
  6. ^ а б Джонатан Корбет (2013-08-20). «Ұсталдарды қайтару». LWN.net. Алынған 2013-10-22.
  7. ^ Нейра Аюсо, Пабло (2006 ж. 14 маусым). «Netfilter байланысын бақылау жүйесі» (PDF).
  8. ^ «IP жиындары». ipset.netfilter.org. Алынған 2014-07-04.
  9. ^ Патрик МакХарди (2013-08-07). «netfilter: SYN прокси-серверін іске қосу». LWN.net. Алынған 2013-11-05.
  10. ^ «netfilter: SYNPROXY core / target қосу». kernel.org. 2013-08-27. Алынған 2013-11-05.
  11. ^ «netfilter: IPv6 SYNPROXY мақсатты қосу». kernel.org. 2013-08-27. Алынған 2013-11-05.
  12. ^ «Netfilter кітапханасы (libnl-nf)». infradead.org. 2013-04-02. Алынған 2013-12-28.
  13. ^ «14-ші Netfilter шеберханасы». seminar.netfilter.org. 2018-09-26. Алынған 2018-09-26.

Сыртқы сілтемелер