![У меня работает SSH-прокси, теперь мне нужно выбрать другой исходящий IP для моего клиента.](https://rvso.com/image/504124/%D0%A3%20%D0%BC%D0%B5%D0%BD%D1%8F%20%D1%80%D0%B0%D0%B1%D0%BE%D1%82%D0%B0%D0%B5%D1%82%20SSH-%D0%BF%D1%80%D0%BE%D0%BA%D1%81%D0%B8%2C%20%D1%82%D0%B5%D0%BF%D0%B5%D1%80%D1%8C%20%D0%BC%D0%BD%D0%B5%20%D0%BD%D1%83%D0%B6%D0%BD%D0%BE%20%D0%B2%D1%8B%D0%B1%D1%80%D0%B0%D1%82%D1%8C%20%D0%B4%D1%80%D1%83%D0%B3%D0%BE%D0%B9%20%D0%B8%D1%81%D1%85%D0%BE%D0%B4%D1%8F%D1%89%D0%B8%D0%B9%20IP%20%D0%B4%D0%BB%D1%8F%20%D0%BC%D0%BE%D0%B5%D0%B3%D0%BE%20%D0%BA%D0%BB%D0%B8%D0%B5%D0%BD%D1%82%D0%B0..png)
У меня настроен SSH-туннель к моему выделенному серверу через Putty, который я использую как socks-прокси. Проблема в том, что мне нужно использовать другой исходящий IP-адрес, нежели основной IP выделенного сервера. У меня есть блок из 30 ips для этого сервера, но даже если я настрою веб-прокси (php), он будет использовать основной IP-адрес сервера.
Кто-нибудь знает решение?
Спасибо!
решение1
Обычно ОС предполагает, что исходный IP-адрес для соединения (то, что вы назвали «исходящим IP») равен основному адресу исходящего интерфейса (см. ifconfig -a
). Исходящий интерфейс определяется путем поиска соответствующей записи в таблице маршрутизации (см. netstat -rn
или route
).
Вы можете поиграться с добавлением/изменением записей в таблице маршрутизации. Есть вероятность, что это заставит ОС выбрать другой исходящий интерфейс, и, в свою очередь, есть вероятность, что это заставит вашу ОС выбрать другой исходный IP-адрес.
Кроме того, если ваш сервер работает на базе Linux, вы можете обойти эту проблему, используя SNAT (см. iptables
).
решение2
Во-первых, настроили ли вы псевдоним для своей сетевой карты?
Что произойдет, если вы подключитесь по ssh, используя псевдоним IP?
Для прокси-сервера веб-базы вы должны иметь возможность указать, к какому IP-адресу привязываться. В Apache вы просто устанавливаете опцию Listen. Вы пробовали?
В качестве альтернативы, как упомянул kubanskamac, используйте iptables.