Openvpn, inoltra i pacchetti molto lentamente


10

Ho riavviato il mio server e si è appena verificato un problema strano. Sto correndo su ArchLinux, i client sono Ubuntu, Android e Mac.

Il problema è che l'accesso a Internet tramite i client è lento, circa 2ko / se si interrompe lentamente.

Ma scaricare qualcosa dal server al client direttamente è fatto a tutta velocità. E, ovviamente, Internet dal server è alla sua massima velocità (40mo / s).

Non so cosa sia successo dal riavvio, ma questo problema è qui su tutti i client ed è legato solo al traffico che openvpn inoltra a Internet.

EDIT: provato con tcp, non risolto. EDIT: testate varie impostazioni di frammento / mtu, nessuna modifica.

Ecco tutti i miei conf:

╭─<root@Alduin>-</etc/openvpn>-<1:45:07>-◇
╰─➤ cat Alduin.conf ccd/Thunderaan
local 212.83.129.104
port 1194
proto udp
dev tun
ca keys/ca.crt
cert keys/Alduin.crt
key keys/Alduin.key
dh keys/dh1024.pem
server 10.8.0.0 255.255.255.0
ifconfig-pool-persist ipp.txt
push "dhcp-option DNS 10.8.0.1"
client-to-client
keepalive 5 60
ping-timer-rem
comp-lzo
persist-key
persist-tun
status openvpn-status.log
verb 3
client-config-dir ccd
topology subnet

ccd from here +++++++++++++++


ifconfig-push 10.8.0.2 255.255.255.0
push "redirect-gateway def1"

Conf. Cliente:

client
dev tun
proto udp
remote 212.83.129.104 1194
resolv-retry infinite
nobind
persist-key
persist-tun
ca ca.crt
cert name.crt
key name.key
ns-cert-type server
comp-lzo
verb 3

e alcuni output che potrebbero aiutarti:

╭─<cubox@Alduin>-<~>-<1:49:43>-◇
╰─➤ ip addr
1: lo: <LOOPBACK,UP,LOWER_UP> mtu 65536 qdisc noqueue state UNKNOWN
    link/loopback 00:00:00:00:00:00 brd 00:00:00:00:00:00
    inet 127.0.0.1/8 scope host lo
       valid_lft forever preferred_lft forever
    inet6 ::1/128 scope host
       valid_lft forever preferred_lft forever
2: eno1: <BROADCAST,MULTICAST,UP,LOWER_UP> mtu 1500 qdisc mq state UP qlen 1000
    link/ether b8:ac:6f:94:e2:4e brd ff:ff:ff:ff:ff:ff
    inet 88.190.15.135/24 scope global eno1
       valid_lft forever preferred_lft forever
    inet 212.83.129.104/32 scope global eno1
       valid_lft forever preferred_lft forever
    inet6 2001:bc8:300a:dead::b12d/64 scope global
       valid_lft forever preferred_lft forever
    inet6 2a01:e0b:1000:15:baac:6fff:fe94:e24e/64 scope global dynamic
       valid_lft 2592000sec preferred_lft 604800sec
    inet6 fe80::baac:6fff:fe94:e24e/64 scope link
       valid_lft forever preferred_lft forever
3: eno2: <BROADCAST,MULTICAST> mtu 1500 qdisc noop state DOWN qlen 1000
    link/ether b8:ac:6f:94:e2:4f brd ff:ff:ff:ff:ff:ff
6: tun0: <POINTOPOINT,MULTICAST,NOARP,UP,LOWER_UP> mtu 1500 qdisc pfifo_fast state UNKNOWN qlen 100
    link/none
    inet 10.8.0.1/24 brd 10.8.0.255 scope global tun0
       valid_lft forever preferred_lft forever
╭─<cubox@Alduin>-<~>-<1:49:47>-◇
╰─➤ route
Kernel IP routing table
Destination     Gateway         Genmask         Flags Metric Ref    Use Iface
default         88-190-15-1.rev 0.0.0.0         UG    0      0        0 eno1
10.8.0.0        *               255.255.255.0   U     0      0        0 tun0
88.190.15.0     *               255.255.255.0   U     0      0        0 eno1
╭─<cubox@Alduin>-<~>-<1:49:51>-◇
╰─➤ route -6
Kernel IPv6 routing table
Destination                    Next Hop                   Flag Met Ref Use If
::1/128                        ::                         U    256 0     0 lo
2001:bc8:300a:dead::/64        ::                         U    256 0     0 eno1
2a01:e0b:1000:15::/64          ::                         UAe  256 0     0 eno1
fe80::/64                      ::                         U    256 0     0 eno1
::/0                           fe80::225:45ff:fef6:947f   UGDAe 1024 2     0 eno1
::/0                           ::                         !n   -1  1  1891 lo
::1/128                        ::                         Un   0   2  5227 lo
2001:bc8:300a:dead::/128       ::                         Un   0   1     0 lo
2001:bc8:300a:dead::b12d/128   ::                         Un   0   1   131 lo
2a01:e0b:1000:15::/128         ::                         Un   0   1     0 lo
2a01:e0b:1000:15:baac:6fff:fe94:e24e/128 ::                         Un   0   3 29356 lo
fe80::/128                     ::                         Un   0   1     0 lo
fe80::baac:6fff:fe94:e24e/128  ::                         Un   0   1   311 lo
ff00::/8                       ::                         U    256 0     0 eno1
::/0                           ::                         !n   -1  1  1891 lo



-A POSTROUTING -s 10.8.0.0/24 -o eno1 -j MASQUERADE # The iptables rule

La regola iptables qui è l'unica che è attiva sul server.

╰─➤ tc qd
qdisc mq 0: dev eno1 root
qdisc pfifo_fast 0: dev tun0 root refcnt 2 bands 3 priomap  1 2 2 2 1 2 0 0 1 1 1 1 1 1 1 1

EDIT: Ecco un registro dal client Archlinux che si collega.

Oct  2 16:54:17 Groat ovpn-openvpn[9216]: OpenVPN 2.2.1 x86_64-linux-gnu [SSL] [LZO2] [EPOLL] [PKCS11] [eurephia] [MH] [PF_INET6] [IPv6 payload 20110424-2 (2.2RC2)] built on Feb 13 2013
Oct  2 16:54:17 Groat ovpn-openvpn[9216]: NOTE: the current --script-security setting may allow this configuration to call user-defined scripts
Oct  2 16:54:17 Groat ovpn-openvpn[9216]: LZO compression initialized
Oct  2 16:54:17 Groat ovpn-openvpn[9216]: Control Channel MTU parms [ L:1542 D:138 EF:38 EB:0 ET:0 EL:0 ]
Oct  2 16:54:17 Groat ovpn-openvpn[9216]: Socket Buffers: R=[212992->131072] S=[212992->131072]
Oct  2 16:54:17 Groat ovpn-openvpn[9216]: Data Channel MTU parms [ L:1542 D:1450 EF:42 EB:135 ET:0 EL:0 AF:3/1 ]
Oct  2 16:54:17 Groat ovpn-openvpn[9216]: Local Options hash (VER=V4): '41690919'
Oct  2 16:54:17 Groat ovpn-openvpn[9216]: Expected Remote Options hash (VER=V4): '530fdded'
Oct  2 16:54:17 Groat ovpn-openvpn[9217]: UDPv4 link local: [undef]
Oct  2 16:54:17 Groat ovpn-openvpn[9217]: UDPv4 link remote: [AF_INET]212.83.129.104:1194
Oct  2 16:54:17 Groat ovpn-openvpn[9217]: TLS: Initial packet from [AF_INET]212.83.129.104:1194, sid=edfcb034 3452d72c
Oct  2 16:54:17 Groat ovpn-openvpn[9217]: VERIFY OK: depth=1, /C=FR/ST=FR/L=Paris/O=Dragonborn/CN=Dragonborn_CA/emailAddress=cubox@cubox.me
Oct  2 16:54:17 Groat ovpn-openvpn[9217]: VERIFY OK: nsCertType=SERVER
Oct  2 16:54:17 Groat ovpn-openvpn[9217]: VERIFY OK: depth=0, /C=FR/ST=FR/L=Paris/O=Dragonborn/CN=Dragonborn/emailAddress=cubox@cubox.me
Oct  2 16:54:17 Groat ovpn-openvpn[9217]: Data Channel Encrypt: Cipher 'BF-CBC' initialized with 128 bit key
Oct  2 16:54:17 Groat ovpn-openvpn[9217]: Data Channel Encrypt: Using 160 bit message hash 'SHA1' for HMAC authentication
Oct  2 16:54:17 Groat ovpn-openvpn[9217]: Data Channel Decrypt: Cipher 'BF-CBC' initialized with 128 bit key
Oct  2 16:54:17 Groat ovpn-openvpn[9217]: Data Channel Decrypt: Using 160 bit message hash 'SHA1' for HMAC authentication
Oct  2 16:54:17 Groat ovpn-openvpn[9217]: Control Channel: TLSv1, cipher TLSv1/SSLv3 DHE-RSA-AES256-SHA, 1024 bit RSA
Oct  2 16:54:17 Groat ovpn-openvpn[9217]: [Dragonborn] Peer Connection Initiated with [AF_INET]212.83.129.104:1194
Oct  2 16:54:20 Groat ovpn-openvpn[9217]: SENT CONTROL [Dragonborn]: 'PUSH_REQUEST' (status=1)
Oct  2 16:54:20 Groat ovpn-openvpn[9217]: PUSH: Received control message: 'PUSH_REPLY,dhcp-option DNS 10.8.0.1,route 212.83.129.0 255.255.255.0,route-gateway 10.8.0.1,topology subnet,ping 5,ping-restart 60,redirect-gateway def1,ifconfig 10.8.0.3 255.255.255.0'
Oct  2 16:54:20 Groat ovpn-openvpn[9217]: OPTIONS IMPORT: timers and/or timeouts modified
Oct  2 16:54:20 Groat ovpn-openvpn[9217]: OPTIONS IMPORT: --ifconfig/up options modified
Oct  2 16:54:20 Groat ovpn-openvpn[9217]: OPTIONS IMPORT: route options modified
Oct  2 16:54:20 Groat ovpn-openvpn[9217]: OPTIONS IMPORT: route-related options modified
Oct  2 16:54:20 Groat ovpn-openvpn[9217]: OPTIONS IMPORT: --ip-win32 and/or --dhcp-option options modified
Oct  2 16:54:20 Groat ovpn-openvpn[9217]: ROUTE default_gateway=192.168.1.254
Oct  2 16:54:20 Groat ovpn-openvpn[9217]: TUN/TAP device tun0 opened
Oct  2 16:54:20 Groat ovpn-openvpn[9217]: TUN/TAP TX queue length set to 100
Oct  2 16:54:20 Groat ovpn-openvpn[9217]: do_ifconfig, tt->ipv6=0, tt->did_ifconfig_ipv6_setup=0
Oct  2 16:54:20 Groat ovpn-openvpn[9217]: /sbin/ifconfig tun0 10.8.0.3 netmask 255.255.255.0 mtu 1500 broadcast 10.8.0.255
Oct  2 16:54:20 Groat ovpn-openvpn[9217]: /sbin/route add -net 212.83.129.104 netmask 255.255.255.255 gw 192.168.1.254
Oct  2 16:54:20 Groat ovpn-openvpn[9217]: /sbin/route add -net 0.0.0.0 netmask 128.0.0.0 gw 10.8.0.1
Oct  2 16:54:20 Groat ovpn-openvpn[9217]: /sbin/route add -net 128.0.0.0 netmask 128.0.0.0 gw 10.8.0.1
Oct  2 16:54:20 Groat ovpn-openvpn[9217]: /sbin/route add -net 212.83.129.0 netmask 255.255.255.0 gw 10.8.0.1
Oct  2 16:54:20 Groat ovpn-openvpn[9217]: Initialization Sequence Completed

EDIT: Ecco un tcpdump del server che scarica direttamente un file: http://sprunge.us/aaJX Ecco il client che scarica questo risorsa: http://sprunge.us/WUCC ed ecco un client normale da un altro openvpn ( funzionante) server: http://www4.slashusr.com/57552.tcpdump

EDIT: Come richiesto nei commenti, ecco le acquisizioni di tcpdump non elaborate. L'acquisizione tun0 dal server non è riuscita, non so perché. Server che mostra fuori qui , client che mostra tun0 qui , client che mostra fuori qui e server che scarica direttamente il file qui .

EDIT: il server esegue un i3, che non viene utilizzato in qualsiasi momento (nemmeno durante l'utilizzo di openvpn). Lo stesso per il client, i7 totalmente inattivo.

EDIT: il problema è ancora qui. Per favore aiuto :(


Presumo che tu abbia guardato alcune catture con WireShark / TCPCDump? Quasi sicuramente la risposta può essere trovata in una cattura, se catturi nel posto giusto.
Zoredache,

Ho un tcpdump dall'interfaccia eno1 su un download dal client e uno dal server (dello stesso file). E uno anche da un client openvpn funzionante. Modificherò la domanda.
Cubox

È possibile aggiungere informazioni sulla cpu dal client e dal server durante il trasferimento del traffico?
Jed Daniels,

Nel tuo tcpdump, non vedo traffico lento (potrebbe essere troppo breve). Ogni client ottiene lo stesso indirizzo IP 10.8.0.2? Puoi ometterlo e piuttosto spingere un percorso verso la tua rete 212.83.129.0?
ott--

Ogni client ha il proprio ccd con il proprio indirizzo IP. Non capisco cosa intendi con un percorso verso la rete.
Cubox,

Risposte:


1

Non sono sicuro che sia la stessa causa, ma penso che valga la pena adattarsi a tun-mtu e mssfix come menzionato in openvpn-on-android-tcp-ritrasmissioni-dopo-openvpn-server-reboot

EDIT: ho scoperto che anche questo potrebbe essere utile [RISOLTO] Prestazioni openVPN inaccettabili Modifica di un parametro del kernel: net.inet.ip.fastforwarding = 1 (aggiungi in /etc/sysctl.conf sul tuo server linux)


Grazie per la risposta. La modifica dell'opzione tun-mtu e mssfix non ha aiutato. L'impostazione di fastworwarding non esiste in Linux. Solo kernel BSD.
Cubox,

0

Il server VPN è anche il server gateway? prova a rimuovere il push-gateway, i tuoi clienti devono avere solo un percorso aggiuntivo.


Dove vedi un'opzione push-gateway?
Cubox,

Alle opzioni CCD c'è il gateway di reindirizzamento. È necessario verificare se esiste un percorso statico sui client verso il loro vero GW.
MealstroM

C'è. I clienti sono in grado di parlare con qualsiasi cosa su Internet, lo fanno solo lentamente.
Cubox

0

La tua regola di iptables postrouting sembra strana, prova questo

-A POSTROUTING -s 10.8.0.0/24 -o eno1 -j MASQUERADE

invece di SNAT ed elimina uno degli IP su eno1, se non ti servono entrambi. Due indirizzi IP pubblici su quella che sembra un'interfaccia Ethernet sembrano solo strani. Perché quella configurazione?

Suppongo che il tuo server openvpn esegua il looping e rilasci di pacchetti avanti e indietro, portando a questo problema.


Ora ho la regola del travestimento, non ha risolto il problema. Ne ho due sul mio server, uno dei quali è il failover e l'altro il principale. Per avere un server con quattro ips sull'interfaccia eth0 (su un altro server Archlinux) per oltre un anno, posso dirti che i multipli ips non sono il problema qui ...
Cubox

0

Gestisci il tuo server DNS internamente? Ho avuto problemi con la mia rete quando stavo eseguendo una configurazione powerdns per dns interni ma non avevo una zona inversa configurata correttamente. Wireshark ha fornito le risposte in quel caso.

Utilizzando il nostro sito, riconosci di aver letto e compreso le nostre Informativa sui cookie e Informativa sulla privacy.
Licensed under cc by-sa 3.0 with attribution required.