Проброс портов и не только
Добавлено: 19 апр 2016, 06:21
Короче теорию писать смысла нет про Ip-пакеты и заголовки и т.п. все есть тут
https://ru.wikipedia.org/wiki/IP
https://ru.wikipedia.org/wiki/TCP
Единственное что напишу это:
SRC-ADDR - адрес источника
DST-ADDR - адрес назначения
Существует инструмент в том числе и для изменения зоголовков Ip-пакета и имя ему НАТ.
Сразу говорю что пишу все ну очень грубо но для товарищей которые не могут настроить пробросы портов думаю будет нормально
SRC-NAT
Что происходит когда вы из вашей домашней сети ломитесь скажем на ya.ru ?
1. отправляем запрос y ДНС и получаем ИП адрес ресурса
2. Смотрим локальную таблицу маршрутизации
3. Формируем соединение с некого рандомного порта и отправляем все это на ваш шлюз который указан в таблице маршрутизации
4. Ваш маршрутизатор принимает данное безобразие и смотрит свою таблицу маршрутизации
5. Далее в работу включается НАТ
Т.к. данный адрес находится за пределами вашей сети, а ваш адрес на ПК серый то нам необходимо подменить адрес источника. Яндексу же нужно куда то ответы свои слать
НАТ в вашем заголовке заменяет SRC-ADDR на адрес который у него прописан на внешнем интерфейсе, так же заменяет порт на который нужно прислать ответ, помещает это все себе в табличку и отправляет ваше соеденение в Мир
Когда от яндекса приходит ответ то все в обратном порядке
Вот так вы попадаете на всякие там контактики, однокласники и т.п. Повторяюсь, описание грубое если нужно подробнее то в интернетах полно информации
DST-NAT
И так, теперь мы понимаем как у нас трафик ходит наружу но разумно предположить что НАТу можно сказать выполнять аналогичные действя снаружи в вашу сеть.
Конечно можно
Предположим что у вас в сети есть некая железка которая отдает некий контент с 80 (HTTP) порта
И вот вы где то там набираете в строке браузера свой внешний ип ииии данyое соединение прилетает на порт вашего роутера.
И чего же происходит?
Упускаем всякие детали. НАТ смотрит свою табличку и находит в ней статическую запись в которой сказанно что при определенных условиях необходимо в заголовке соединения заменить адрес назначения (DST-ADDR) ну и порт (если требуется) и отправить это дальше. Собственно все
Совсем просто то:
Из сети в Мир заменяем адрес источника и порт (если требуется) - SRC-NAT
Из Мира в сеть заменяем назначения и порт (если требуется) - DST-NAT
Если уж вообще по быдлянски то
SRC-NAT - проброс из сети в Мир
DST-NAT - проброс из Мира в сеть
Для блондинок
SRC-NAT - вот эта коробочка отправляет пакетики из вот этой желтенькой дырочки с надписью LAN в синенькую с надписью WAN
DST-NAT - Коробочка из синенькой дырочки с надписью WAN Отправляет в желтенькую с надписью LAN
https://ru.wikipedia.org/wiki/IP
https://ru.wikipedia.org/wiki/TCP
Единственное что напишу это:
SRC-ADDR - адрес источника
DST-ADDR - адрес назначения
Существует инструмент в том числе и для изменения зоголовков Ip-пакета и имя ему НАТ.
Сразу говорю что пишу все ну очень грубо но для товарищей которые не могут настроить пробросы портов думаю будет нормально
SRC-NAT
Что происходит когда вы из вашей домашней сети ломитесь скажем на ya.ru ?
1. отправляем запрос y ДНС и получаем ИП адрес ресурса
2. Смотрим локальную таблицу маршрутизации
3. Формируем соединение с некого рандомного порта и отправляем все это на ваш шлюз который указан в таблице маршрутизации
4. Ваш маршрутизатор принимает данное безобразие и смотрит свою таблицу маршрутизации
5. Далее в работу включается НАТ
Т.к. данный адрес находится за пределами вашей сети, а ваш адрес на ПК серый то нам необходимо подменить адрес источника. Яндексу же нужно куда то ответы свои слать
НАТ в вашем заголовке заменяет SRC-ADDR на адрес который у него прописан на внешнем интерфейсе, так же заменяет порт на который нужно прислать ответ, помещает это все себе в табличку и отправляет ваше соеденение в Мир
Когда от яндекса приходит ответ то все в обратном порядке
Вот так вы попадаете на всякие там контактики, однокласники и т.п. Повторяюсь, описание грубое если нужно подробнее то в интернетах полно информации
DST-NAT
И так, теперь мы понимаем как у нас трафик ходит наружу но разумно предположить что НАТу можно сказать выполнять аналогичные действя снаружи в вашу сеть.
Конечно можно
Предположим что у вас в сети есть некая железка которая отдает некий контент с 80 (HTTP) порта
И вот вы где то там набираете в строке браузера свой внешний ип ииии данyое соединение прилетает на порт вашего роутера.
И чего же происходит?
Упускаем всякие детали. НАТ смотрит свою табличку и находит в ней статическую запись в которой сказанно что при определенных условиях необходимо в заголовке соединения заменить адрес назначения (DST-ADDR) ну и порт (если требуется) и отправить это дальше. Собственно все
Совсем просто то:
Из сети в Мир заменяем адрес источника и порт (если требуется) - SRC-NAT
Из Мира в сеть заменяем назначения и порт (если требуется) - DST-NAT
Если уж вообще по быдлянски то
SRC-NAT - проброс из сети в Мир
DST-NAT - проброс из Мира в сеть
Для блондинок

SRC-NAT - вот эта коробочка отправляет пакетики из вот этой желтенькой дырочки с надписью LAN в синенькую с надписью WAN
DST-NAT - Коробочка из синенькой дырочки с надписью WAN Отправляет в желтенькую с надписью LAN