Sieci komputerowe, sieci bezprzewodowe, sprzęt do wideokonferencji - Network Expert

VPN IPSec Site-to-Site

Poniżej w kilku krokach przedstawiamy jak szybko ustanowić tunel VPN pomiędzy dwoma routerami Cisco.

VPN pozwalają na połączenie ze sobą i umożliwienie szyfrowanej łączności pomiędzy dwoma oddzielnymi LANami.

Technologia VPN jest często wykorzystywana przez firmy do umożliwienia dostępu dla swoich zdalnych pracowników. Połączeń VPN jest kilka rodzajów jako pierwszy przedstawimy konfigurację dla opcji Site-to-Site.

VPN IPSec Site-to-Site

Nasza konfiguracja składa się z pięciu routerów. Routery A i E znajdują się wewnątrz sieci LAN odpowiednio 1 i 2. To pomiędzy nimi będziemy chcieli uzyskać łączność VPN. Routery B i D są to routery brzegowe dla obu LANów. Router C ma za zadanie udawać Internet. Routery A i E są skonfigurowane w trasy default wskazujące na routery brzegowe. Routery B i D posiadają trasy default w kierunku routera C. Zastosowana adresacja jest przedstawiona na rysunku.

Jako pierwszy konfigurujemy router B. Poza podstawową konfiguracją trzeba również stworzyć możliwość otwierania tunelu VPN. To na tym routerze będzie on tworzony dla użytkowników sieci LAN 1, którzy będą chcieli się skomunikować z LANem 2. Połączenie VPN składa się z dwóch faz. W fazie pierwszej routery próbujące nawiązać połączenie wymieniają się kluczami. Wykorzystywany jest tu protokół IKE. Następuje uwierzytelnienie każdej strony. W fazie drugiej następuje ustanowienie parametrów szyfrowania tunelu docelowego. Parametry na obu końcach tunelu (w naszym przypadku na routerach B i D) muszą być takie same. Gdy wszystko się zgadza tunel się podnosi i można przesyłać dane.

Konfiguracja routera B:

interfejsy:

interface FastEthernet0/0
ip address 10.192.10.1 255.255.255.0
duplex auto
speed auto

interface FastEthernet0/1
ip address 81.1.1.2 255.255.255.252
duplex auto
speed auto
crypto map vpnlab

droga domyślna w kierunku routera C:

ip route 0.0.0.0 0.0.0.0 81.1.1.1

konfiguracja fazy pierwszej:

crypto isakmp policy 1
authentication pre-share
crypto isakmp key cisco address 81.1.2.1

podajemy adres drugiego routera i klucz, który będzie wymieniany pomiędzy nimi, można ustalić wszystkie parametry wg. uznania hash, typ szyfrowania i uwierzytelniania

crypto ipsec transform-set vpnlab esp-aes esp-sha-hmac

konfiguracja fazy drugiej:

crypto map vpnlab 1 ipsec-isakmp
set peer 81.1.2.1
set transform-set vpnlab
match address 100

access lista niezbędna do nawiązania połączenia pomiędzy dwoma wybranymi LANami:

access-list 100 permit ip 10.192.10.0 0.0.0.255 10.192.20.0 0.0.0.255

jest wykorzystywana przy crypto mapie, ustala się tam również adres końca tunelu – drugiego routera (w naszym przypadku router D)

crypto mapa jest również przypięta do odpowiedniego wychodzącego interfejsu u nas Fa0/1

Konfiguracja routera D jest taka sama jak B, należy pamiętać o zgodności kluczy i adresów:

crypto isakmp policy 1
authentication pre-share
crypto isakmp key cisco address 81.1.1.2

klucz taki sam, adres routera B

crypto ipsec transform-set vpnlab esp-aes esp-sha-hmac

crypto map vpnlab 1 ipsec-isakmp
set peer 81.1.1.2
set transform-set vpnlab
match address 100

access-list 100 permit ip 10.192.20.0 0.0.0.255 10.192.10.0 0.0.0.255

access-lista w drugą stronę, kierująca ruch z LANu 2 do LANu 1

interface FastEthernet0/0
ip address 81.1.2.1 255.255.255.252
duplex auto
speed auto
crypto map vpnlab

interface FastEthernet0/1
ip address 10.192.20.1 255.255.255.0
duplex auto
speed auto

droga domyślna do routera C:
ip route 0.0.0.0 0.0.0.0 81.1.2.2

Sprawdzenie łączności: ping z routera A do E i odwrotnie:

A#ping 10.192.20.1
Type escape sequence to abort.
Sending 5, 100-byte ICMP Echos to 10.192.20.1, timeout is 2 seconds:
!!!!!
Success rate is 100 percent (5/5), round-trip min/avg/max = 1280/1324/1444 ms
A#

E#ping 10.192.10.2
Type escape sequence to abort.
Sending 5, 100-byte ICMP Echos to 10.192.10.2, timeout is 2 seconds:
!!!!!
Success rate is 100 percent (5/5), round-trip min/avg/max = 1300/1368/1452 ms
E#

Mimo że pomiędzy nimi jest sieć publiczna można wykonywać ping na adres prywatny. Router brzegowy dostając pakiety do sieci 10.192.10.0 lub 10.192.20.o wie, że musi je puścić poprzez tunel VPN.

Poza standardowym pingiem, można również na routerach B i D obserwować czy zestawiły się poszczególne fazy połączenia VPN

Sprawdzenie fazy pierwszej:
B# show crypto isakmp sa
IPv4 Crypto ISAKMP SA
dst src state conn-id slot status
81.1.2.1 81.1.1.2 QM_IDLE 1001 0 ACTIVE

IPv6 Crypto ISAKMP SA

Widać oba końce tunelu, parametr QM_IDLE świadczy o tym, że tunel wstał i nawiązane jest połączenie fazy pierwszej.

Sprawdzenie fazy drugiej:

B#show crypto ipsec sa

interface: FastEthernet0/1
Crypto map tag: vpnlab, local addr 81.1.1.2

protected vrf: (none)
local ident (addr/mask/prot/port): (10.192.10.0/255.255.255.0/0/0)
remote ident (addr/mask/prot/port): (10.192.20.0/255.255.255.0/0/0)
current_peer 81.1.2.1 port 500
PERMIT, flags={origin_is_acl,}
#pkts encaps: 11, #pkts encrypt: 11, #pkts digest: 11
#pkts decaps: 11, #pkts decrypt: 11, #pkts verify: 11

// część powyżej świadczy, że tunel działa poprawnie, pokazuje ile pakietów zostało zaszyfrowanych i odszyfrowanych – należy pamiętać, że bez puszczenia jakiegokolwiek ruchu nic się tu nie pojawi!

#pkts compressed: 0, #pkts decompressed: 0
#pkts not compressed: 0, #pkts compr. failed: 0
#pkts not decompressed: 0, #pkts decompress failed: 0
#send errors 4, #recv errors 0

local crypto endpt.: 81.1.1.2, remote crypto endpt.: 81.1.2.1
path mtu 1500, ip mtu 1500, ip mtu idb FastEthernet0/1
current outbound spi: 0xCA6AA626(3395986982)

inbound esp sas:
spi: 0x4110ADED(1091612141)
transform: esp-aes esp-sha-hmac ,
in use settings ={Tunnel, }
conn id: 1, flow_id: SW:1, crypto map: vpnlab
sa timing: remaining key lifetime (k/sec): (4462441/2349)
IV size: 16 bytes
replay detection support: Y
Status: ACTIVE

inbound ah sas:

inbound pcp sas:

outbound esp sas:
spi: 0xCA6AA626(3395986982)
transform: esp-aes esp-sha-hmac ,
in use settings ={Tunnel, }
conn id: 2, flow_id: SW:2, crypto map: vpnlab
sa timing: remaining key lifetime (k/sec): (4462441/2349)
IV size: 16 bytes
replay detection support: Y
Status: ACTIVE

outbound ah sas:

outbound pcp sas:
B#

i w drugą stronę:

D#show crypto isakmp sa
IPv4 Crypto ISAKMP SA
dst src state conn-id slot status
81.1.2.1 81.1.1.2 QM_IDLE 1001 0 ACTIVE

IPv6 Crypto ISAKMP SA

D#show crypto ipsec sa

interface: FastEthernet0/0
Crypto map tag: vpnlab, local addr 81.1.2.1

protected vrf: (none)
local ident (addr/mask/prot/port): (10.192.20.0/255.255.255.0/0/0)
remote ident (addr/mask/prot/port): (10.192.10.0/255.255.255.0/0/0)
current_peer 81.1.1.2 port 500
PERMIT, flags={origin_is_acl,}
#pkts encaps: 11, #pkts encrypt: 11, #pkts digest: 11
#pkts decaps: 11, #pkts decrypt: 11, #pkts verify: 11
#pkts compressed: 0, #pkts decompressed: 0
#pkts not compressed: 0, #pkts compr. failed: 0
#pkts not decompressed: 0, #pkts decompress failed: 0
#send errors 0, #recv errors 0

local crypto endpt.: 81.1.2.1, remote crypto endpt.: 81.1.1.2
path mtu 1500, ip mtu 1500, ip mtu idb FastEthernet0/0
current outbound spi: 0x4110ADED(1091612141)

inbound esp sas:
spi: 0xCA6AA626(3395986982)
transform: esp-aes esp-sha-hmac ,
in use settings ={Tunnel, }
conn id: 1, flow_id: SW:1, crypto map: vpnlab
sa timing: remaining key lifetime (k/sec): (4409774/2177)
IV size: 16 bytes
replay detection support: Y
Status: ACTIVE

inbound ah sas:

inbound pcp sas:

outbound esp sas:
spi: 0x4110ADED(1091612141)
transform: esp-aes esp-sha-hmac ,
in use settings ={Tunnel, }
conn id: 2, flow_id: SW:2, crypto map: vpnlab
sa timing: remaining key lifetime (k/sec): (4409774/2177)
IV size: 16 bytes
replay detection support: Y
Status: ACTIVE

outbound ah sas:

outbound pcp sas:
D#

2024-06-25T09:49:59+02:00
Przejdź do góry