フォーム読み込み中
こんにちは、長岡です。
今回は、特定のドメインやG-IP向けの通信経路だけAlibaba Cloud網を通したいときの手段として検証してみました。
VPC間にCENを通して2つのVPCをつなげたうえで試してみました。 VPN接続後、NATサーバ(ECS)を通ってアクセスするようになります。
下図のとおりです。
GUIコンソールから作成しました。
| 機能 | Hostname | Zone | InstanceType | Spec | P-IP |
|---|---|---|---|---|---|
| NATサーバ | nat01 | 日本東京(ゾーンB) | ecs.t5-lc1m1.small | 1vCPU 1GiB | 10.68.30.153 |
| VPNサーバ | openvpn01 | 日本東京(ゾーンA) | ecs.t5-lc1m1.small | 1vCPU 1GiB | 10.68.10.238 |
CAは腹持ちで建てました。
[root@openvpn]# grep '^[^#]' 'server_r.conf
port 1194
proto udp
dev tun
ca /etc/openvpn/easy-rsa/pki/ca.crt
cert /etc/openvpn/easy-rsa/pki/issued/server_r.crt
key /etc/openvpn/easy-rsa/pki/private/server_r.key # This file should be kept secret
dh /etc/openvpn/easy-rsa/pki/dh.pem
server 10.8.0.0 255.255.255.0
ifconfig-pool-persist ipp.txt
push "route 13.112.0.0 255.252.0.0"
# firewall-cmd --zone=external --change-interface=eth0 --permanent
success
# firewall-cmd --zone=external --add-masquerade --permanent
success
# firewall-cmd --reload
success
# systemctl enable firewalld
# systemctl start firewalld
# systemctl status firewalld
irewalld.service - firewalld - dynamic firewall daemon
Loaded: loaded (/usr/lib/systemd/system/firewalld.service; enabled; vendor preset: enabled)
Active: active (running) since 木 2019-11-28 08:00:13 CST; 10h ago
Docs: man:firewalld(1)
Main PID: 542 (firewalld)
CGroup: /system.slice/firewalld.service
└─542 /usr/bin/python2 -Es /usr/sbin/firewalld --nofork --nopid
11月 28 08:00:13 nginx02 systemd[1]: Starting firewalld - dynamic firewall daemon...
11月 28 08:00:13 nginx02 systemd[1]: Started firewalld - dynamic firewall daemon.
11月 28 18:02:38 nginx02 firewalld[542]: WARNING: ALREADY_ENABLED: masquerade
vpnuxやtunnelblickなどのGUIアプリでVPN接続します。
OpenVPNに設定しいてたクライアントサブネットが割り当てられていることを確認します。
User:~$ ifconfig | grep 10.8
inet 10.8.0.6 --> 10.8.0.5 netmask 0xffffffff
Qiita向けの経路が適切にpublishされているか確認します。
User:~$ netstat -rn | grep 13.112/14
13.112/14 10.8.0.5 UGSc utun8
これでVPN接続時はAlibaba CloudのVPC網を通ってNATサーバからQiitaにアクセスするようになりました! 注意点としてIPアドレスが複数ある場合は、丸めて記載するか単体でそれぞれ記載するなど工夫が必要です。 OpenVPNがドメインで経路をpushできれば良さそうなんですけど、今のところはできなさそう...🤔
しかし、特定IP範囲であれば、クライアントのProxy設定不要でVPN接続さえすればローカルスプリットします。 そして、特定経路だけVPCにルーティングしてくれるので、ユーザーにルーティングを意識させたくないとき有効的に使える構成だと思います。
条件に該当するページがございません