Рейтинг:0

Когда Netfilter выполняет фильтрацию в сетевом стеке ядра TCP/IP?

флаг ng

У меня вопрос о том, где Netfilter находится в сетевом стеке в ядре Linux.

Я знаю, что это сетевой уровень, сетевой фильтр, а затем уровень TCP. Фактически, после декапсуляции пакета на уровне IP в ядре он будет проанализирован Netfilter, а затем декапсулирован в TCP. Поэтому мне интересно, как он может фильтровать пакеты на основе номера порта, как в заголовке TCP.

Рейтинг:2
флаг us

Netfilter не маршрутизирует пакеты, маршрутизация происходит в отдельной части сетевого стека.

https://en.wikipedia.org/wiki/Netfilter#/media/File:Netfilter-packet-flow.svg показывает поток пакетов в подсистеме Netfilter.

Внутри Netfilter работает со структурами skb, которые содержат либо кадры L2, либо пакеты L3 и связанные с ними метаданные.

флаг ng
Спасибо за ответ. Но мне интересно, как будет происходить фильтрация пакетов по порту? Я имею в виду, если мы рассмотрим путь, по которому пакет проходит через сетевой стек в ядре, чтобы достичь приложения, где именно происходит фильтрация пакетов? после tcp слоя? после IP-уровня?
флаг us
Это происходит в нескольких местах на пути обработки пакетов, как показано на диаграмме. Нет простого ответа типа «после TCP» или «после IP». Например, сетевой стек не выполняет никакой обработки TCP, если конечной точкой подключения не является сама система.

Ответить или комментировать

Большинство людей не понимают, что склонность к познанию нового открывает путь к обучению и улучшает межличностные связи. В исследованиях Элисон, например, хотя люди могли точно вспомнить, сколько вопросов было задано в их разговорах, они не чувствовали интуитивно связи между вопросами и симпатиями. В четырех исследованиях, в которых участники сами участвовали в разговорах или читали стенограммы чужих разговоров, люди, как правило, не осознавали, что задаваемый вопрос повлияет — или повлиял — на уровень дружбы между собеседниками.