AWSで、以前OpenVPNを構築した時は、easy-rsaがバージョン2だったのですが、今構築しようとすると、easy-rsaがバージョン3となっています。
今回はAmazon Linuxで、標準パッケージのOpenVPNとEPELパッケージのeasy-rsa 3で構築しました。
Amazon Linux 2は標準パッケージにOpenVPNが入ってないので使いません。
目次:
easy-rsaのバージョン2とバージョン3で大きな違い
コマンドがeasy-rsaのみとなりました。
コマンド実行前にvarsを実行する必要がなくなりました。「cn_only」というCommonNameのみ入力すれば鍵が作成されるモードがデフォルトとなり、鍵を作成するための情報をもったvarsファイルを作成する意味がなくなったためです。
もちろん今までと同様のモード「org」に変更することも可能です。
作成の手順としては今までとほぼ同じです。
それでは構築していきます。
インストール
OpenVPN
sudo yum install openvpn
easy-rsa
sudo yum install easy-rsa --enablerepo=epel
/usr/share/easy-rsaに導入されます。
認証局と鍵の作成
認証局の初期化
sudo -s
cd /usr/share/easy-rsa/3
./easyrsa init-pki
init-pki complete; you may now create a CA or requests.
Your newly created PKI dir is: /usr/share/easy-rsa/3/pki
認証局を作成前にのみ実行します。
メッセージからpkiディレクトリが作成されています。
認証局の作成
./easyrsa build-ca
Generating a 2048 bit RSA private key
.........................................................+++
...............................................................+++
writing new private key to '/usr/share/easy-rsa/3/pki/private/ca.key.FL7BTHsUxo'
Enter PEM pass phrase:
Verifying - Enter PEM pass phrase:
-----
You are about to be asked to enter information that will be incorporated
into your certificate request.
What you are about to enter is what is called a Distinguished Name or a DN.
There are quite a few fields but you can leave some blank
For some fields there will be a default value,
If you enter '.', the field will be left blank.
-----
Common Name (eg: your user, host, or server name) [Easy-RSA CA]:
CA creation complete and you may now import and sign cert requests.
Your new CA certificate file for publishing is at:
/usr/share/easy-rsa/3/pki/ca.crt
ここで入力したのは「pass phrase」のみです。
cn_onlyモードとなっているので、Common Nameしか聞かれていません。
わたしはCommon Nameもデフォルトにしました。
DHパラメータの生成
./easyrsa gen-dh
Generating DH parameters, 2048 bit long safe prime, generator 2
This is going to take a long time
....................................................+...........................
................................................................................
................................................................................
.........................................................................+......
〜 略 〜
....................................+................................+..........
................................................................................
.............................................................++*++*
DH parameters of size 2048 created at /usr/share/easy-rsa/3/pki/dh.pem
サーバ証明書と秘密鍵の作成
nopassオプションでパスフレーズを不要にしています。
./easyrsa build-server-full server1 nopass
Generating a 2048 bit RSA private key
...................+++
.........................................................................................................+++
writing new private key to '/usr/share/easy-rsa/3/pki/private/server1.key.O7Mt8gb0z2'
-----
Using configuration from ./openssl-1.0.cnf
Enter pass phrase for /usr/share/easy-rsa/3/pki/private/ca.key:
Check that the request matches the signature
Signature ok
The Subject's Distinguished Name is as follows
commonName :ASN.1 12:'server1'
Certificate is to be certified until Mar 27 02:46:17 2028 GMT (3650 days)
Write out database with 1 new entries
Data Base Updated
ここで入力したのは認証局の作成の時に設定したパスワードのみです。
クライアント証明書と秘密鍵の作成
./easyrsa build-client-full user1
Generating a 2048 bit RSA private key
.................+++
............................+++
writing new private key to '/usr/share/easy-rsa/3/pki/private/user1.key.y5xGTr558R'
Enter PEM pass phrase:
Verifying - Enter PEM pass phrase:
-----
Using configuration from ./openssl-1.0.cnf
Enter pass phrase for /usr/share/easy-rsa/3/pki/private/ca.key:
Check that the request matches the signature
Signature ok
The Subject's Distinguished Name is as follows
commonName :ASN.1 12:'user1'
Certificate is to be certified until Mar 30 05:26:53 2028 GMT (3650 days)
Write out database with 1 new entries
Data Base Updated
わたしは、OpenVPNのWindowsクライアント用にvpnux、Mac用にTunnelbrickを使っています。
※vpnuxは1.4.6.2以上を利用してください。古いvpnuxでは接続できますが通信に失敗します。
両方のクライアントともパスワードが保存できるので、だれでもセットアップしてつなげられないようにパスワードを設定しています。
最初のパスフレーズが、クライアント証明書のパスワード、後のパスフレーズが認証局作成時のパスワードですを入力します。
作成されたファイルは、pkiディレクトリ内の各サブディレクトリに保管されています。
private:秘密鍵
reqs:証明書要求
issued:証明書
OpenVPN設定
OpenVPN設定ファイル作成
/etc/openvpn/server.conf
port 1194
proto udp
dev tun
ca /usr/share/easy-rsa/3/pki/ca.crt
cert /usr/share/easy-rsa/3/pki/issued/server1.crt
key /usr/share/easy-rsa/3/pki/private/server1.key
dh /usr/share/easy-rsa/3/pki/dh.pem
server 10.200.0.0 255.255.255.0
ifconfig-pool-persist ipp.txt
push "route 10.0.5.0 255.255.255.0"
push "route 10.0.11.0 255.255.255.0"
keepalive 10 120
cipher AES-256-CBC
comp-lzo
persist-key
persist-tun
status openvpn-status.log
verb 3
explicit-exit-notify 1
push “route”のところはVPNのサブネットのIPアドレスになります。
IPアドレスにあわせて変更してください。
OpenVPNの起動
/etc/init.d/openvpn start
OpenVPN自動起動設定
chkconfig openvpn on
IP Forwarding設定
/etc/sysctl.conf
net.ipv4.ip_forward = 0の行があるので1に変更してください。
net.ipv4.ip_forward = 1
sysctl -p
Tunnelbrick設定ファイル
接続テストはMacを利用して行いました。
Tunnelbrickはこちらからダウンロードできます。
client
dev tun
proto udp
remote OpenVPNサーバIPアドレス 1194
resolv-retry infinite
nobind
persist-key
persist-tun
ca ca.crt
cert user1.crt
key user1.key
cipher AES-256-CBC
keepalive 10 60
verb 3
mssfix 1280
AWS設定
- OpenVPNをインストールしたサーバにEIPを設定
- OpenVPNをインストールしたサーバにセキュリティグループを追加し設定
- OpenVPN経由でアクセスさせたいPrivateネットワークのサーバに対して、セキュリティグループからのアクセスを許可
- Privateネットワークのルートテーブルに、VPNクライアント側のセグメントから、OpenVPNをインストールしたサーバへのルーティングを設定
- OpenVPNをインストールしたサーバで送信元/送信先の変更チェックを無効に設定
AWSに慣れている方ならここまでで設定が一気に終わると思います。
ここからはAWS設定について詳細に解説します。
OpenVPNをインストールしたサーバにEIPを設定
この作業でグローバルIPアドレスを取得します。
data:image/s3,"s3://crabby-images/54df4/54df49388729acfc3071954ca7283d3c943d009c" alt="f:id:ishimotohiroaki:20180402111049p:plain f:id:ishimotohiroaki:20180402111049p:plain"
EC2 ダッシュボードを表示し、「Elastic IP」をクリックします。
data:image/s3,"s3://crabby-images/b7f19/b7f1956eaa5a8b1502f9c6883f40b5b262c8fdb1" alt="f:id:ishimotohiroaki:20180402111119p:plain f:id:ishimotohiroaki:20180402111119p:plain"
「新しいアドレスの割り当て」をクリックします。
data:image/s3,"s3://crabby-images/ed635/ed635e9c5b082e8657d2e66b15e120929e8e766c" alt="f:id:ishimotohiroaki:20180402111216p:plain f:id:ishimotohiroaki:20180402111216p:plain"
「割り当て」をクリックします。
data:image/s3,"s3://crabby-images/2dd57/2dd578a67ca231fc19f1f211dc80c56516b90c92" alt="f:id:ishimotohiroaki:20180402111251p:plain f:id:ishimotohiroaki:20180402111251p:plain"
Elastic IPが割り当てられました。
「閉じる」をクリックします。
data:image/s3,"s3://crabby-images/e7c68/e7c68013bdd39ba7fb95e63b408a65793658d9a8" alt="f:id:ishimotohiroaki:20180402111423p:plain f:id:ishimotohiroaki:20180402111423p:plain"
Elastic IPの一覧にも表示されました。
Elastic IPをOpenVPNサーバにアタッチします。
data:image/s3,"s3://crabby-images/2b9a5/2b9a5a312a2f7899d02f8cc22032f69aa3613979" alt="f:id:ishimotohiroaki:20180402121423p:plain f:id:ishimotohiroaki:20180402121423p:plain"
Elastic IPを選択し、「アクション」-「アドレスの関連付け」をクリックします。
data:image/s3,"s3://crabby-images/1d99e/1d99efd16ba3eb3a20aeec5a85cd7e88d4b11d20" alt="f:id:ishimotohiroaki:20180402121511p:plain f:id:ishimotohiroaki:20180402121511p:plain"
OpenVPNの「インスタンス」「プライベートIP」を選択し、「関連付け」をクリックします。
OpenVPNをインストールしたサーバにセキュリティグループを追加し設定
server1というセキュリティグループを作成します。
data:image/s3,"s3://crabby-images/6aab4/6aab4abb34a26a7d77c33e5f4531cdbcfdb29d00" alt="f:id:ishimotohiroaki:20180402111956p:plain f:id:ishimotohiroaki:20180402111956p:plain"
EC2 ダッシュボードを表示し、「セキュリティグループ」をクリックします。
「セキュリティグループの作成」をクリックします。
data:image/s3,"s3://crabby-images/3a194/3a194d3ba0e8088abd2e8114f914977c823d8c15" alt="f:id:ishimotohiroaki:20180402112524p:plain f:id:ishimotohiroaki:20180402112524p:plain"
「セキュリティグループ名」「説明」を入力し、「VPC」を選択します。
「ルールの追加」をクリックします。
カスタムUDPを選択、ポートは1194を入力、ソースは0.0.0.0/0を入力します。
「作成」をクリックします。
OpenVPN経由でアクセスさせたいPrivateネットワークのサーバに対して、セキュリティグループからのアクセスを許可
Privateネットワークのサーバに設定されているセキュリティグループに追加します。
引き続きセキュリティグループで作業します。
data:image/s3,"s3://crabby-images/6772b/6772beb46991b17977958704aefc68105cafd62c" alt="f:id:ishimotohiroaki:20180402113100p:plain f:id:ishimotohiroaki:20180402113100p:plain"
OpenVPN経由でアクセスさせたいサーバに設定されているセキュリティグループを選択します。
インバウンドタブで「編集」をクリックします。
data:image/s3,"s3://crabby-images/4d294/4d294674bd84cc7a8a2eec092e72b9060d013f9d" alt="f:id:ishimotohiroaki:20180402113748p:plain f:id:ishimotohiroaki:20180402113748p:plain"
「ルールの追加」をクリックします。
「すべてのトラフィック」をクリックします。「ソースでセキュリティグループ」を選択します。セキュリティグループを選択にするには「sg」と入力することにより一覧が表示されます。セキュリティグループがたくさん存在する場合は、セキュリティグループからコピーしてきましょう。
すべてのトラフィックではなくもっとポートを絞ることも可能です。
「保存」をクリックします。
Privateネットワークのルートテーブルに、VPNクライアント側のセグメントから、OpenVPNをインストールしたサーバへのルーティングを設定
「VPC」-「ルートテーブル」をクリックします。
data:image/s3,"s3://crabby-images/de0bc/de0bc7aafef3aa0c7ae85b53c84aac4aa8d9b503" alt="f:id:ishimotohiroaki:20170808095142p:plain f:id:ishimotohiroaki:20170808095142p:plain"
プライベートネットワークのルートテーブルを選択し、「ルート」タブをクリックし、「編集」をクリックします。
data:image/s3,"s3://crabby-images/a9bd2/a9bd2b931810a544415a9096db074692d0701653" alt="f:id:ishimotohiroaki:20170808095320p:plain f:id:ishimotohiroaki:20170808095320p:plain"
「別のルートを追加」をクリックします。
data:image/s3,"s3://crabby-images/bd16e/bd16e8bd5a7e10af5aed2f2b45ee44d76e4c1270" alt="f:id:ishimotohiroaki:20180402115444p:plain f:id:ishimotohiroaki:20180402115444p:plain"
送信先に今回OpenVPNの設定でクライアントへのIPアドレス付与した「10.200.0.0/24」を入力し、ターゲットにOpenVPNがインストールされたインスタンスを選択し、「保存」をクリックします。
ターゲット入力時に「i」を入力するとインスタンスの一覧が表示されます。
data:image/s3,"s3://crabby-images/ee990/ee99080938ef21708f96841490b71ec5bcc7aa74" alt="f:id:ishimotohiroaki:20180402115716p:plain f:id:ishimotohiroaki:20180402115716p:plain"
この状態になれば設定完了です。
プライベートサブネットへのアクセスは、10.200.0.0/24からになりますので、あわせてセキュリティグループの設定が必要です。
data:image/s3,"s3://crabby-images/6f4bd/6f4bd3233315b6dc711b0fc6d3980092898c70c1" alt="f:id:ishimotohiroaki:20180402120107p:plain f:id:ishimotohiroaki:20180402120107p:plain"
このルールを追加し、「保存」をクリックします。
OpenVPNをインストールしたサーバで送信元/送信先の変更チェックを無効に設定
data:image/s3,"s3://crabby-images/41385/41385b5a223ba99a50acce5ca18c18ad2acd5d81" alt="f:id:ishimotohiroaki:20170808092516p:plain f:id:ishimotohiroaki:20170808092516p:plain"
OpenVPNをインストールしたサーバを選択し、「アクション」-「ネットワーキング」-「送信元/送信先の変更チェック」をクリックします。
data:image/s3,"s3://crabby-images/6982d/6982d6e4e3610b92e1630d9d0c2b03a2bf250110" alt="f:id:ishimotohiroaki:20170808092712p:plain f:id:ishimotohiroaki:20170808092712p:plain"
「はい、無効化する」をクリックします。
同じオペレーションで、すぐに有効化することもできます。