Назад | Перейти на главную страницу

Проблема маршрутизации OpenVPN

Я запускаю сервер OpenVPN на VPS под управлением Debian 5 и клиент OpenVPS на рабочем столе Ubuntu 11.04. Я хочу, чтобы весь исходящий трафик от клиента проходил через VPN-сервер.

Я могу инициировать соединение от клиента к серверу и успешно пинговать между ними, но когда я пытаюсь получить доступ к внешним IP-адресам от клиента, мне это не удается.

Например, при пинге google по IP:

ping -n 74.125.91.106
PING 74.125.91.106 (74.125.91.106) 56(84) bytes of data.
^C
--- 74.125.91.106 ping statistics ---
7 packets transmitted, 0 received, 100% packet loss, time 6048ms

На стороне сервера я вижу, что через туннель поступают запросы ping, но не возвращаются ответы:

tcpdump -i tun0
tcpdump: verbose output suppressed, use -v or -vv for full protocol decode
listening on tun0, link-type RAW (Raw IP), capture size 65535 bytes
21:24:59.384736 IP 10.8.0.6 > qy-in-f106.1e100.net: ICMP echo request, id 7537, seq 1,  length 64
21:25:00.391970 IP 10.8.0.6 > qy-in-f106.1e100.net: ICMP echo request, id 7537, seq 2, length 64
21:25:01.400394 IP 10.8.0.6 > qy-in-f106.1e100.net: ICMP echo request, id 7537, seq 3, length 64
21:25:02.408914 IP 10.8.0.6 > qy-in-f106.1e100.net: ICMP echo request, id 7537, seq 4, length 64
21:25:03.416378 IP 10.8.0.6 > qy-in-f106.1e100.net: ICMP echo request, id 7537, seq 5, length 64
21:25:04.424289 IP 10.8.0.6 > qy-in-f106.1e100.net: ICMP echo request, id 7537, seq 6, length 64
21:25:05.431804 IP 10.8.0.6 > qy-in-f106.1e100.net: ICMP echo request, id 7537, seq 7, length 64

Я также вижу их на интерфейсе venet0 на сервере:

tcpdump -i venet0:0 'icmp[icmptype] == icmp-echo or icmp[icmptype] == icmp-echoreply' 
tcpdump: verbose output suppressed, use -v or -vv for full protocol decode
listening on venet0:0, link-type LINUX_SLL (Linux cooked), capture size 65535 bytes
21:39:11.397967 IP 10.8.0.6 > qy-in-f106.1e100.net: ICMP echo request, id 7588, seq 1, length 64
21:39:12.407609 IP 10.8.0.6 > qy-in-f106.1e100.net: ICMP echo request, id 7588, seq 2, length 64
21:39:13.415194 IP 10.8.0.6 > qy-in-f106.1e100.net: ICMP echo request, id 7588, seq 3, length 64
21:39:14.423050 IP 10.8.0.6 > qy-in-f106.1e100.net: ICMP echo request, id 7588, seq 4, length 64
21:39:15.431005 IP 10.8.0.6 > qy-in-f106.1e100.net: ICMP echo request, id 7588, seq 5, length 64
21:39:16.439687 IP 10.8.0.6 > qy-in-f106.1e100.net: ICMP echo request, id 7588, seq 6, length 64
21:39:17.446949 IP 10.8.0.6 > qy-in-f106.1e100.net: ICMP echo request, id 7588, seq 7, length 64

Я также могу успешно пинговать Google с сервера.

Есть идеи, что может быть причиной этого?

Файл конфигурации сервера:

dev tun
server 10.8.0.0 255.255.255.0
ifconfig-pool-persist ipp.txt
ca ca.crt
cert server.crt
key server.key
dh dh1024.pem
push "route 10.8.0.0 255.255.255.0"
push "redirect-gateway"
comp-lzo
keepalive 10 60
ping-timer-rem
persist-tun
persist-key
group daemon
daemon

Файл конфигурации клиента:

remote <<server IP>>
dev tun
comp-lzo
ca ca.crt
cert client1.crt
key client1.key
route-delay 2
route-method exe
redirect-gateway def1
dhcp-option DNS 10.8.0.1
verb 3

Вам необходимо отобразить «входящий» трафик, чтобы он правильно направлялся к клиенту. Т.е. вам необходимо установить трансляцию NAT на сервере для IP (VPN) клиента.

Вы видите, что сервер не знает, как пересылать ответы.

Вот инструкции, как это сделать: http://openvpn.net/index.php/open-source/documentation/howto.html#redirect - посмотрите конфигурацию iptables на сервере.

Переадресация IP включена? Источник, определяющий клиентов vpn?

Определение источника - это перевод адресов (vpn-клиента) на внешний IP-адрес. Как говорит Санни, принимающий сервер не знает, как вернуться на внутренний IP-адрес, даже если ваш интернет-провайдер не отфильтровал его.

iptables -t nat -A POSTROUTING -s 10.8.0.0/24 -o eth0 -j MASQUERADE
iptables -a FORWARD -i tun0 -j ACCEPT