Как перенести порт с firewalld в зависимости от исходного IP

Я запускаю SSH на порт 5678.

Для моего исходного IP-адреса 1.2.3.4 - я хочу подключиться к порту 22 и перевести порт firewalld на номер 5687.

Никакие другие исходные IP-адреса не получают переадресацию портов.

Какую строку firewall-cmd я бы набрал для достижения этой цели?

2 ответа

Решение

Догадаться:

CUSTOMPORT=$(netstat -tlpn | grep 0.0.0.0.*ssh | cut -d: -f2 | cut -f1 -d\ )
SOURCE_IP=1.2.3.4
firewall-cmd --zone=public --permanent --query-masquerade
firewall-cmd --zone=public --permanent --add-masquerade
firewall-cmd --zone=public --permanent --add-rich-rule="rule family=\"ipv4\" source address=\"${SOURCE_IP}\" forward-port port=\"22\" protocol=\"tcp\" to-port=\"${CUSTOMPORT}\""
firewall-cmd --reload

Вы просто создаете правило firewalld для разрешения трафика, а затем настраиваете NAT для трафика. По сути, вы создаете ACL, чтобы определить, какой трафик разрешен, и затем вы создаете правило NAT, чтобы сказать, что разрешенный трафик должен быть преобразован.

firewall-cmd --permanent --zone=public --add-rich-rule="rule 
family="ipv4" \
source address="1.2.3.4/32" \
port protocol="tcp" port="22" accept"
firewall-cmd --permanent --zone=public --add-forward-port=port=22:proto=tcp:toport=5678:toaddr=*private translated IP address*
firewall-cmd --reload

Как открыть порт для определенного IP-адреса с помощью firewall-cmd на CentOS?

http://www.certdepot.net/rhel7-get-started-firewalld/

Другие вопросы по тегам