Đường hầm IPSec giữa Strongswan phía sau NAT và VMWare NSX Edge

Vì một số lý do, cần phải tổ chức kết nối VPN giữa mạng trong VMWare Cloud Director và một máy Ubuntu riêng biệt trên đám mây. Ghi chú không có vẻ là một mô tả đầy đủ, nó chỉ là một hướng dẫn nhỏ.

Đường hầm IPSec giữa Strongswan phía sau NAT và VMWare NSX Edge

Bài viết duy nhất về chủ đề này từ năm 2015 được tìm thấy trên Internet “Site to Site IPSEC VPN giữa NSX Edge và Linux strongSwan'.

Thật không may, nó không thể được sử dụng trực tiếp bởi vì... Tôi muốn mã hóa đáng tin cậy hơn chứ không phải chứng chỉ tự ký và cấu hình được mô tả sẽ không hoạt động sau NAT.

Vì vậy, tôi phải ngồi xuống và nghiên cứu kỹ tài liệu.

Về cơ bản, tôi đã lấy một cấu hình mà tôi đã sử dụng từ lâu, cho phép tôi kết nối từ hầu hết mọi hệ điều hành và chỉ cần thêm một phần vào đó cho phép tôi kết nối với NSX Edge.

Vì việc cài đặt và cấu hình đầy đủ máy chủ Strongswan nằm ngoài phạm vi của ghi chú này nên hãy để tôi tham khảo tài liệu hay về chủ đề này.

Vì vậy, hãy chuyển trực tiếp đến cài đặt.

Sơ đồ kết nối của chúng ta sẽ trông như thế này:

Đường hầm IPSec giữa Strongswan phía sau NAT và VMWare NSX Edge

со стороны VMWare внешний адрес 33.33.33.33 и внутренняя сеть 192.168.1.0/24
со стороны Linux внешний адрес 22.22.22.22 и внутренняя сеть 10.10.10.0/24
также понадобится настроить Let's encrypt сертификат для адреса vpn.linux.ext
PSK с обеих сторон: ChangeMeNow!

Cấu hình từ NSX Edge:

Văn bản

Enabled: yes
Enable perfect forward secrecy (PFS): yes
Name: VPN_strongswan (любое, по вашему выбору)
Local Id: 33.33.33.33
Local Endpoint: 33.33.33.33
Local Subnets: 192.168.1.0/24
Peer Id: vpn.linux.ext
Peer Endpoint: 22.22.22.22
Peer Subnets: 10.10.10.0/24
Encryption Algorithm: AES256
Authentication: PSK
Pre-Shared Key: ChangeMeNow!
Diffie-Hellman Group: 14 (2048 bit — приемлемый компромисс между скоростью и безопасностью. Но если хотите, можете поставить больше)
Digest Algorithm: SHA256
IKE Option: IKEv2
IKE Responder Only: no
Session Type: Policy Based Session

Ảnh chụp màn hình
Đường hầm IPSec giữa Strongswan phía sau NAT và VMWare NSX Edge
Đường hầm IPSec giữa Strongswan phía sau NAT và VMWare NSX Edge

Thiết lập từ Strongswan:

ipsec.conf

# /etc/ipsec.conf
config setup

conn %default
	dpdaction=clear
	dpddelay=35s
	dpdtimeout=300s

	fragmentation=yes
	rekey=no

	ike=aes256gcm16-aes256gcm12-aes128gcm16-aes128gcm12-sha256-sha1-modp2048-modp4096-modp1024,aes256-aes128-sha256-sha1-modp2048-modp4096-modp1024,3des-sha1-modp1024!
	esp=aes128gcm12-aes128gcm16-aes256gcm12-aes256gcm16-modp2048-modp4096-modp1024,aes128-aes256-sha1-sha256-modp2048-modp4096-modp1024,aes128-sha1-modp2048,aes128-sha1-modp1024,3des-sha1-modp1024,aes128-aes256-sha1-sha256,aes128-sha1,3des-sha1!

	left=%any
	leftsubnet=10.10.10.0/24
        leftcert=certificate.pem
	leftfirewall=yes
	leftsendcert=always

	right=%any
	rightsourceip=192.168.1.0/24
	rightdns=77.88.8.8,8.8.4.4

	eap_identity=%identity

# IKEv2
conn IPSec-IKEv2
	keyexchange=ikev2
	auto=add

# BlackBerry, Windows, Android
conn IPSec-IKEv2-EAP
	also="IPSec-IKEv2"
	rightauth=eap-mschapv2

# macOS, iOS
conn IKEv2-MSCHAPv2-Apple
	also="IPSec-IKEv2"
	rightauth=eap-mschapv2
	leftid=vpn.linux.ext

# Android IPsec Hybrid RSA
conn IKEv1-Xauth
	keyexchange=ikev1
	rightauth=xauth
	auto=add

# VMWare IPSec VPN
conn linux-nsx-psk
	authby=secret
	auto=start
	leftid=vpn.linux.ext
	left=10.10.10.10
	leftsubnet=10.10.10.0/24
	rightid=33.33.33.33
	right=33.33.33.33
	rightsubnet=192.168.1.0/24
	ikelifetime=28800
	keyexchange=ikev2
	lifebytes=0
	lifepackets=0
	lifetime=1h

ipsec.secret

# /etc/ipsec.secrets
: RSA privkey.pem

# Create VPN users accounts
# ВНИМАНИЕ! После логина сначала пробел, потом двоеточие.

user1 : EAP "stongPass1"
user2 : EAP "stongPass2"
%any 33.33.33.33 : PSK "ChangeMeNow!"

sau đó, chỉ cần đọc lại cấu hình, bắt đầu kết nối và kiểm tra xem nó đã được thiết lập chưa:

ipsec update
ipsec rereadsecrets
ipsec up linux-nsx-psk
ipsec status

Tôi hy vọng ghi chú nhỏ này hữu ích và giúp ai đó tiết kiệm được vài giờ.

Nguồn: www.habr.com

Thêm một lời nhận xét