NIC dupla para acesso NAT reverso

NIC dupla para acesso NAT reverso

Precisa de ajuda com este objetivo:

Internet
    <-- TP_LINK Router(192.168.0.1)
        <-- PC1(eth0:192.168.0.8)
        <-- PC2(eth0:192.168.0.81)

Quando eu uso o cabo para conectar PC2 eth1 a PC3 eth0 e defino as configurações de PC2 eth1 IPV4 como "compartilhado com outros computadores", então PC2 e PC3 ficam abaixo dos IPs:

    PC2(eth1:10.42.0.1)
        <-- PC3(eth0: 10.42.0.169)

Agora quero fazer algo no route ou no iptables para poder "pingar 10.42.0.169" no PC1.

Isso é possível? Abaixo está o que eu tentei:

  • Configure a tabela de rotas estáticas do roteador TP_LINK: 10.42.0.0(destino) - 255.255.255.0(máscara de rede) - 192.168.0.81(gateway).

Agora obtenho o resultado no PC1:

$ traceroute 10.42.0.169
traceroute to 10.42.0.169 (10.42.0.169), 64 hops max, 52 byte packets
1  192.168.0.1 (192.168.0.1)  4.018 ms  0.905 ms  0.768 ms
2  ay11 (192.168.0.81)  1.140 ms  1.273 ms  1.482 ms
3  ay11 (192.168.0.81)  1.104 ms  1.041 ms  1.127 ms

Podemos ver que se o PC2 puder encaminhar pacotes para 10.42.0.0/24, talvez tudo fique perfeito?

Aqui estão as configurações no PC2:

$ route
default         192.168.0.1     0.0.0.0         UG    100    0        0 eth1
10.42.0.0       *               255.255.255.0   U     100    0        0 eth0
link-local      *               255.255.0.0     U     1000   0        0 eth1
192.168.0.1     *               255.255.255.255 UH    100    0        0 eth1

$ sudo iptables -L
[sudo] password for mlhch: 
Chain INPUT (policy ACCEPT)
target     prot opt source               destination         
ACCEPT     udp  --  anywhere             anywhere             udp dpt:bootps
ACCEPT     tcp  --  anywhere             anywhere             tcp dpt:bootps
ACCEPT     udp  --  anywhere             anywhere             udp dpt:domain
ACCEPT     tcp  --  anywhere             anywhere             tcp dpt:domain

Chain FORWARD (policy ACCEPT)
target     prot opt source               destination         
ACCEPT     all  --  anywhere             10.42.0.0/24         state RELATED,ESTABLISHED
ACCEPT     all  --  10.42.0.0/24         anywhere            
ACCEPT     all  --  anywhere             anywhere            
REJECT     all  --  anywhere             anywhere             reject-with icmp-port-unreachable
REJECT     all  --  anywhere             anywhere             reject-with icmp-port-unreachable

Chain OUTPUT (policy ACCEPT)
target     prot opt source               destination

O que devo fazer com rota ou iptables?

Obrigado!

Responder1

Tente ativar isso. PC2A primeira coisa a fazer é ativar o encaminhamento de IP. Isto é feito usando

echo "1" > /proc/sys/net/ipv4/ip_forward

Então, adicionaremos uma regra informando para encaminhar o tráfego

sudo iptables -A FORWARD -i eth1 -o eth0 -j ACCEPT
sudo iptables -A FORWARD -i eth0 -o eth1 -m state --state ESTABLISHED,RELATED -j ACCEPT

Responder2

Obrigada pelos teus esforços.

Para /proc/sys/net/ipv4/ip_forward, já era "1" e eu tinha configurado net.ipv4.ip_forward=1 em /etc/sysctl.conf

Eu executei seus comandos iptables, eles apenas acrescentam 2 linhas abaixo na seção Chain FORWARD:

ACCEPT     all  --  anywhere             anywhere            
ACCEPT     all  --  anywhere             anywhere             state RELATED,ESTABLISHED

Então nenhum milagre acontece. Mas isso me fez notar as 2 linhas REJECT

REJECT     all  --  anywhere             anywhere             reject-with icmp-port-unreachable
REJECT     all  --  anywhere             anywhere             reject-with icmp-port-unreachable

Eu os apago e tudo funciona perfeitamente! Na verdade, eu também excluo as linhas recém-adicionadas e mantenho apenas 1 linha "ACEITAR tudo - em qualquer lugar, em qualquer lugar".

informação relacionada