서로 다른 네트워크 인터페이스를 사용하여 동일한 IP에 액세스하는 방법

서로 다른 네트워크 인터페이스를 사용하여 동일한 IP에 액세스하는 방법

내 RaspberryPi에 연결된 세 개의 WLAN 인터페이스가 있습니다.

  • wlan0
  • wlan1
  • wlan2

각각은 다음과 연결되어 있습니다.다른 SSID:

  • gopro-0
  • gopro-1
  • gopro-2

GoPro 카메라가 WiFi 라우터로 설정됨항상 동일한 IP 주소: 10.5.5.9.

이 구성을 사용하여 호출하면 다음과 같습니다.

curl http://10.5.5.9

그런 다음 wlan0첫 번째 인터페이스가 사용됩니다(가정 단순화). 카메라를 호출하려면 다음과 같이 gopro-2호출해야 합니다.

curl http://10.5.5.9 --interface wlan2

효과가있다. 그러나 모든 명령에서 인터페이스를 지정할 수 있는 것은 아니라는 문제가 있습니다(즉 ffmpeg, 또는 인터페이스를 모릅니다).

어떻게 든 Linux를 속일 수 있습니까?대표하다특정 IP 주소를 10.5.5.9특정 인터페이스로 전달해야 합니까?

예를 들어:

10.5.4.100 -> 10.5.5.9 @ wlan0
10.5.4.101 -> 10.5.5.9 @ wlan1
10.5.4.102 -> 10.5.5.9 @ wlan2

나는 일반적인 HTTP GET/POST 메소드를 사용하여 다른 인터페이스에서 동일한 IP를 호출할 수 있게 해주는 솔루션이나 다른 메소드를 기대하고 있습니다.

답변1

다른 유형의 장치에서도 동일한 문제가 발생하여 해결 방법을 찾았습니다. iptables mangle과 ip Route의 조합이 필요합니다.

각 인터페이스에 장치와 동일한 서브넷에 있는 고유 IP를 할당합니다(아래 192.168.44.8). 이 예에서 첫 번째 장치의 가상 IP는 192.168.44.9입니다.

192.168.44.1에 물리적 장치에 대한 4개의 서로 다른 인터페이스가 있으며 이 모드와 가상 IP를 사용하면 모든 장치와 안정적으로 통신할 수 있습니다.

iptables -t mangle -A PREROUTING -d 192.168.44.9 -j MARK --set-mark 0x01

iptables -t nat -A PREROUTING -m mark --mark 0x01 -d 192.168.44.9 -j DNAT --to-destination 192.168.44.1

iptables -t nat -A POSTROUTING -m mark --mark 0x01 --destination 192.168.44.1 -j SNAT --to-source 192.168.44.8

이 작업을 완료한 후에는 이제 다음 경로를 추가하세요.

ip route add 192.168.44.0/24 dev eth4 table 1
ip rule add from all fwmark 1 table 1
ip route flush cache

이 패턴은 원하는 만큼 반복할 수 있습니다. 보유하고 있는 인터페이스 수에 따라 태그와 주소를 계속 추가하면 됩니다.

이것이 다른 네트워크 인터페이스에서 중복된 주소를 다루는 다른 사람들에게 유용하길 바랍니다.

답변2

방법은 iptables를 사용하고 라우팅을 설정하는 것입니다. 귀하의 질문에 대한 비슷한 답변은 다음과 같습니다.

https://serverfault.com/questions/345111/iptables-target-to-route-packet-to-특이적-인터페이스

이는 OpenBSD/pf에서는 약간 더 간단합니다.

답변3

이 스레드에는 똑같은 문제가 설명되어 있습니다. https://forum.developer.parrot.com/t/multiple-parrot-anafi-control-via-olympe-on-linux-configure-ip/9590/2

iptables규칙과 라우팅을 사용하는 완벽한 솔루션을 제공합니다.

관련 정보