UDP-трафик через SSH-туннель
Название в значительной степени подводит итог. Я хотел бы отправлять трафик UDP через туннель SSH. В частности, мне нужно иметь возможность отправлять UDP-пакеты через туннель, и сервер должен отправлять их мне обратно на другой стороне. Я знаю, как это сделать для TCP-соединений. Это возможно с UDP?
9 ответов
В этом небольшом руководстве рассказывается, как отправлять UDP-трафик через SSH с помощью инструментов, которые входят в стандартную комплектацию (ssh, nc, mkfifo) с большинством UNIX-подобных операционных систем.
Выполнение туннелирования UDP через соединение SSH
Шаг за шагом Откройте порт пересылки TCP с вашим SSH-соединением
На локальном (локальном) компьютере подключитесь к удаленному компьютеру (серверу) по SSH с дополнительной опцией -L, чтобы SSH с переадресацией порта TCP:
local# ssh -L 6667:localhost:6667 server.foo.com
Это позволит перенаправлять TCP-соединения на порт 6667 вашего локального компьютера на порт 6667 на server.foo.com через защищенный канал. Настройте пересылку TCP на UDP на сервере
На сервере мы открываем прослушиватель на TCP-порту 6667, который перенаправляет данные на UDP-порт 53 указанного IP-адреса. Если вы хотите сделать переадресацию DNS, как я, вы можете взять IP первого сервера имен, который вы найдете в /etc/resolv.conf. Но сначала нам нужно создать fifo. FIFO необходим для двусторонней связи между двумя каналами. Простая оболочка передает только стандартный ввод левого процесса "стандартный вывод в правый процесс".
server# mkfifo /tmp/fifo
server# nc -l -p 6667 < /tmp/fifo | nc -u 192.168.1.1 53 > /tmp/fifo
Это позволит перенаправлять трафик TCP через порт 6667 сервера в трафик UDP через порт 53 192.168.1.1 и получать ответы. Настройте переадресацию UDP на TCP на вашем компьютере
Теперь нам нужно сделать противоположное тому, что было сделано выше на локальной машине. Вам нужен привилегированный доступ для привязки UDP-порта 53.
local# mkfifo /tmp/fifo
local# sudo nc -l -u -p 53 < /tmp/fifo | nc localhost 6667 > /tmp/fifo
Это позволит перенаправлять трафик UDP на порт 53 локальной машины на трафик TCP на порт 6667 локальной машины. Наслаждайтесь вашим локальным DNS-сервером:)
Как вы уже, наверное, догадались, когда DNS-запрос будет выполняться на локальном компьютере, например, на локальном UDP-порту 53, он будет перенаправлен на локальный TCP-порт 6667, затем на TCP-порт сервера 6667, затем на DNS-сервер сервера. UDP-порт 53 из 192.168.1.1. Чтобы пользоваться услугами DNS на вашем локальном компьютере, укажите следующую строку в качестве первого сервера имен в вашем /etc/resolv.conf:
nameserver 127.0.0.1
Этот пример (я думаю, что ответ Джона указывает на то же самое в другом месте), описывает, как получить доступ к службам UDP/DNS другого компьютера через соединение TCP/SSH.
Мы будем перенаправлять локальный трафик UDP/53 в TCP, затем трафик TCP с механизмом переадресации портов SSH на другую машину, затем TCP в UDP/53 на другом конце.
Как правило, вы можете сделать это с openvpn.
Но здесь мы сделаем это с более простыми инструментами, только openssh и netcat.
В конце этой страницы есть еще один комментарий со ссылкой на socat
",
Тот же UDP/DNS-доступ осуществляется с помощью
Сторона сервера:
socat tcp4-listen:5353,reuseaddr,fork UDP:nameserver:53
Сторона клиента:socat udp4-listen:53,reuseaddr,fork tcp:localhost:5353
См. Примеры сокатов для большего.
Или вы можете просто использовать ssf (который был разработан для этого варианта использования) с помощью простой команды:
Сторона клиента:
#>./ssfc -U 53:192.168.1.1:53 server.foo.com
Эта команда перенаправляет локальный порт 53 (dns) на порт 192.168.1.1 через безопасный туннель между localhost и server.foo.com.
Вам понадобится ssf-сервер (вместо вашего сервера ssh или рядом с ним):
#>./ssfs
Кстати, клиентская и серверная части ssf работают на Windows / Linux / Mac. Это пользовательское приложение, поэтому вам не нужно настраивать / подключать или использовать VPN.
Чтобы перенаправить порт 53, вам потребуются права администратора - независимо от того, какой инструмент вы используете.
Для получения дополнительной информации, подробностей, варианта использования или загрузки: https://securesocketfunneling.github.io/ssf/
SSH (по крайней мере, OpenSSH) поддерживает простые VPN. С использованием -w
или же Tunnel
вариант в ssh
клиент, вы можете создать tun
устройство на обоих концах, которое может использоваться для пересылки любого вида IP-трафика. (Смотрите также Tunnel
на странице руководства ssh_config(5)
.) Обратите внимание, что для этого требуется OpenSSH (и, вероятно, привилегии root) на обоих концах.
Я не мог получить nc
работать для SNMP, потому что клиенты SNMP продолжают выбирать новый исходный порт UDP, и несколько могут быть активны одновременно.
Вместо этого я написал пост, описывающий, как это сделать с socat
в этом сообщении, используя SNMP в качестве примера. По сути, используя два терминала, начиная с обзора:
Терминал один:
client$ ssh -L 10000:localhost:10000 server
server$ socat -T10 TCP4-LISTEN:10000,fork UDP4:switch:161
Это создает пересылку SSH TCP-порта 10000 и запускает socat на сервере. Обратите внимание, как IP-адрес коммутатора упоминается в командной строке socat как "коммутатор".
Терминал два:
client$ sudo socat UDP4-LISTEN:161,fork TCP4:localhost:10000
Это настраивает сокат на клиенте. Это должно сделать это.
VPN - лучшее решение, если у вас есть доступ к порту UDP.
Если у вас есть доступ только к TCP-порту SSH, то SSH-туннель так же хорош, как VPN, по крайней мере, для проверки связи и обратного отслеживания пакетов.
на ssh-сервере:
sudo ip tuntap add dev tun7 mode tun user SSHUSER
sudo ip addr add 192.168.7.1/30 dev tun7
sudo iptables -t nat -A PREROUTING -p udp -i eth0 --dport PUBLIC_PORT -j DNAT --to-destination 192.168.7.2:LOCAL_PORT
sudo iptables -t filter -A FORWARD -i eth0 -p udp -d 192.168.7.2 --dport LOCAL_PORT -j ACCEPT
sudo iptables -t filter -A FORWARD -i tun7 -o eth0 -j ACCEPT
sudo iptables -t nat -A POSTROUTING -o tun7 -j MASQUERADE
# set "PermitTunnel point-to-point" for user SSHUSER in /etc/ssh/sshd_config
sudo sshd -t && sudo systemctl restart sshd
заменятьeth0
с интерфейсом, подключенным к Интернету
на ssh-клиенте, на котором работает udp-сервер:
sudo ip tuntap add dev tun8 mode tun user LOCALUSER
sudo ip addr add 192.168.7.2/30 dev tun8
ssh -v -w 8:7 SSHUSER@REMOTEHOST
вам также может понадобитьсяsudo ip link set tun7 up
на удаленном хосте иsudo ip link set tun8 up
на локальном хосте.
вдохновлен комментарием UDP-трафика через SSH-туннель
Опытный специалист из красной команды заставил это работать и доказал с помощью Wireshark, но ему пришлось изменить пакеты UDP на пакеты TCP, затем перенаправить их в туннель ssh, а затем преобразовать их из пакетов TCP обратно в пакеты UDP на UDP-порт прослушивателя приложения. .