Серьезные проблемы с производительностью при совместном подключении клиента openvpn к виртуальной коробке клиентов локальной сети

Я пытаюсь настроить внутреннюю сеть в Virtualbox, чтобы разделить клиентский туннель openvpn с несколькими виртуальными машинами, действующими в качестве клиентов, которые должны быть полностью изолированы от всего, кроме интерфейса VPN-туннеля, чтобы предотвратить все возможности клиентских виртуальных машин от раскрывая мой реальный IP-адрес.

Моя установка состоит из 1 виртуальной машины, на которой работает сервер Ubuntu, и нескольких клиентских виртуальных машин, которые подключаются к ней для доступа к соединению openvpn, которое имеет виртуальная машина сервера. Виртуальная машина сервера связана с eth0 как NAT для доступа к интернет-соединению. Эта VM также имеет интерфейс eth1, который подключен к внутренней сети Virtualbox, используемой другими клиентами VM для подключения к Интернету. Dnsmasq работает по eth1 для обслуживания ips клиентам, а iptables настроен для пересылки всего трафика от eth1 к tun0, который является адаптером openvpn tun на сервере.

Пока это было частично успешным. Я могу заставить своих клиентов общаться с сервером через внутреннюю сеть и выходить в Интернет через туннель openvpn, настроенный на сервере, но клиенты испытывают серьезные проблемы с подключением и производительностью в Интернете, в то время как сам сервер не имеет проблем с Интернетом. доступ через vpn. Я исследовал эту проблему и обнаружил, что существует проблема с таймингами mtu, поскольку мой хост-компьютер уже подключен к VPN, а виртуальная машина сервера также подключена к другой виртуальной машине, которая добавляет заполнение и может создавать проблемы фрагментации и производительности. Мне нужно решение, которое не требует изменения vpn-соединения хоста, все должно быть сделано в virtualbox и виртуальных машинах. Я попытался добавить параметры tun-mtu 1400 и mssfix в файл конфигурации клиента openvpn на виртуальной машине моего сервера, но затем openvpn отказывается подключаться. В качестве альтернативы я попытался решить эту проблему со стороны моей клиентской виртуальной машины, установив размер mtu ниже 1400, но проблема не была решена, несмотря на перезапуск и сброс сетевого адаптера. Однако сама серверная виртуальная машина не имеет проблем с поддержанием нормальной производительности по сравнению с vpn, и только клиенты по внутренней сети испытывают проблемы с Интернетом. После попытки этих двух решений я протестировал доступ к моей серверной виртуальной машине через замазку с клиента и загрузку файла по HTTP, что показало, что между клиентскими виртуальными машинами и виртуальной машиной сервера не было проблем с производительностью по внутренней сети. В настоящее время я понятия не имею, почему доступ к локальной сети от клиентов не имеет проблем, в то время как доступ к Интернету делает. Клиенты могут пинговать с помощью icmp, загружать файлы (гораздо медленнее, чем обычно) и частично получать доступ к некоторым веб-сайтам, что заставило меня поверить, что существует проблема с mtu. Однако я понятия не имею, что делать дальше, чтобы решить эту проблему, и я попробовал все известные мне решения.

Вот больше информации о моей настройке, я действительно надеюсь, что кто-то может помочь мне настроить это и запустить его должным образом, поскольку я потратил несколько часов в течение 2 дней, пытаясь заставить это работать безуспешно, и это действительно начинает раздражать меня и заставь меня потерять терпение.

Basic Layout Image (поможет понять): макет

Изображения, показывающие проблемы клиента с подключением: проблемы

Ifconfig на виртуальной машине сервера, показывающий все сетевые интерфейсы:

root@server1:/var/www# ifconfig -a
eth0      Link encap:Ethernet  HWaddr 08:00:27:8b:b4:cb
          inet addr:10.0.2.15  Bcast:10.0.2.255  Mask:255.255.255.0
          inet6 addr: fe80::a00:27ff:fe8b:b4cb/64 Scope:Link
          UP BROADCAST RUNNING MULTICAST  MTU:1500  Metric:1
          RX packets:126546 errors:0 dropped:0 overruns:0 frame:0
          TX packets:75182 errors:0 dropped:0 overruns:0 carrier:0
          collisions:0 txqueuelen:1000
          RX bytes:23817797 (23.8 MB)  TX bytes:9685507 (9.6 MB)

eth1      Link encap:Ethernet  HWaddr 08:00:27:37:98:0c
          inet addr:192.168.1.1  Bcast:192.168.1.255  Mask:255.255.255.0
          inet6 addr: fe80::a00:27ff:fe37:980c/64 Scope:Link
          UP BROADCAST RUNNING MULTICAST  MTU:1500  Metric:1
          RX packets:46043 errors:0 dropped:0 overruns:0 frame:0
          TX packets:103573 errors:0 dropped:0 overruns:0 carrier:0
          collisions:0 txqueuelen:1000
          RX bytes:3105270 (3.1 MB)  TX bytes:550239993 (550.2 MB)

lo        Link encap:Local Loopback
          inet addr:127.0.0.1  Mask:255.0.0.0
          inet6 addr: ::1/128 Scope:Host
          UP LOOPBACK RUNNING  MTU:65536  Metric:1
          RX packets:247 errors:0 dropped:0 overruns:0 frame:0
          TX packets:247 errors:0 dropped:0 overruns:0 carrier:0
          collisions:0 txqueuelen:0
          RX bytes:19597 (19.5 KB)  TX bytes:19597 (19.5 KB)

tun0      Link encap:UNSPEC  HWaddr 00-00-00-00-00-00-00-00-00-00-00-00-00-00-00-00
          inet addr:10.xxx.x.x  P-t-P:10.xxx.x.x  Mask:255.255.255.255
          UP POINTOPOINT RUNNING NOARP MULTICAST  MTU:1500  Metric:1
          RX packets:37018 errors:0 dropped:0 overruns:0 frame:0
          TX packets:20921 errors:0 dropped:0 overruns:0 carrier:0
          collisions:0 txqueuelen:100
          RX bytes:51937120 (51.9 MB)  TX bytes:1148212 (1.1 MB)

/ etc / network / interfaces settings:

root@server1:/var/www# cat /etc/network/interfaces
# This file describes the network interfaces available on your system
# and how to activate them. For more information, see interfaces(5).

# The loopback network interface
auto lo
iface lo inet loopback

# The primary network interface
auto eth0
iface eth0 inet dhcp

# Virtualbox internal Network
auto eth1
iface eth1 inet static
address 192.168.1.1
netmask 255.255.255.0

Iptables:

root@server1:/var/www# iptables --list
Chain INPUT (policy ACCEPT)
target     prot opt source               destination

Chain FORWARD (policy ACCEPT)
target     prot opt source               destination
ACCEPT     all  --  192.168.1.0/24       anywhere             ctstate NEW
ACCEPT     all  --  anywhere             anywhere             ctstate RELATED,ESTABLISHED

Chain OUTPUT (policy ACCEPT)
target     prot opt source               destination

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

client
dev tun
proto udp
remote xxx.xxx.xxx.xxx 1194
resolv-retry infinite
nobind
persist-key
persist-tun
ca ca.crt
tls-client
remote-cert-tls server
auth-user-pass
comp-lzo
verb 1
reneg-sec 0
auth-user-pass login.conf

0 ответов

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