家の PC にリモートデスクトップでアクセスしたくなったので環境構築したお話。
Chrome の Remote Desktop 機能使えば簡単にできるのかと思ったけれども Android から接続した場合に Ctrl キーなどを入力する方法がなかったのでしかたなく VPN サーバーをセットアップすることにしました。サーバーとなるのは以前の記事にもした「kano を DietPi でサーバーにした」ラズパイです。
DietPi に PiVPN をインストールする
PiVPN (Simplest OpenVPN setup and configuration, designed for Raspberry Pi.) というものを見つけたのでこれを使います。
とは言っても、DietPi 使いこなしてないので作法を知らないのですけど…
DietPi はログインすると次のような表示となります。
なんとなく dietpi-software というやつを使えば良さそうです。実行してみましょう。
data:image/s3,"s3://crabby-images/36609/3660941d2ec782b29d497663bbb5c0d63726b846" alt=""
Search で検索します。
data:image/s3,"s3://crabby-images/387f2/387f2b1cce8a17930e3aaf11863a25afbbde083f" alt=""
検索ワードは vpn で。
data:image/s3,"s3://crabby-images/f4472/f447285f39eaae9e6e94ac75980c3e247d547361" alt=""
PiVPN があったので選択して Ok で戻ります。
data:image/s3,"s3://crabby-images/d2e4b/d2e4bcbd465708aff8f5941c5c3518763965d08f" alt=""
Install でさっき選択した PiVPN をインストールします。
data:image/s3,"s3://crabby-images/5a955/5a95592fc6c08b4b79aed57dea0a14e3cf91c607" alt=""
インストール中にサービスが止まったりするよと注意書き
data:image/s3,"s3://crabby-images/e9380/e93805cd02ef97e4d32d28946f93843838358dad" alt=""
OpenVPN もインストールするよ。
data:image/s3,"s3://crabby-images/c5193/c5193475bca1a01bc9e42abaa2c81bae45ebd072" alt=""
サーバーだからIPアドレスを固定する必要があるよ。
data:image/s3,"s3://crabby-images/1592e/1592eefaff32ae4d3fdfc7a5b38e081927834953" alt=""
今のアドレスで固定しちゃってよいですか?と、DHCP サーバーで予約アドレスにしてあるので Ok
data:image/s3,"s3://crabby-images/fb78f/fb78fdd0a3a4c8b45e32e131f462e6e3db20fb2f" alt=""
DHCP の IP プールだから DHCP サーバー側をうまいことやっといてね。
data:image/s3,"s3://crabby-images/c19bb/c19bb3c2bf1403950643a5cf1c8d72229fb24882" alt=""
OpenVPN 用のユーザー選んでね。
data:image/s3,"s3://crabby-images/913ab/913ab9c80176a9e1ac007d639859259ded2ffd88" alt=""
ここでは pivpn を選択することにしました。
data:image/s3,"s3://crabby-images/cfd06/cfd063b1679680ba0e819d2f7a4255e6d46bdf51" alt=""
インターネットにポートを公開するサービスだから unattended-upgrades 機能を有効にすることを推奨しますよと、でも reboot は自分でやってね。
data:image/s3,"s3://crabby-images/38efd/38efdf0d55c06be94013d6cf1642dfe25750e444" alt=""
unattended upgrades を有効にしますか?はい。
data:image/s3,"s3://crabby-images/1b8ca/1b8cae29e861289c1f3bfb384230d47a44bf2f50" alt=""
OpenVPN で使うポートを UDP にするか TCP にするかを選択する。UDP にします。
data:image/s3,"s3://crabby-images/5d3d7/5d3d752b7b9802bafe8d472c8aa87b18c75eb128" alt=""
ポート番号はデフォルトの 1194 のままにする。
data:image/s3,"s3://crabby-images/0b230/0b230fc7ee50718b83c7ee0fc906a3a05d3a8011" alt=""
data:image/s3,"s3://crabby-images/45e91/45e91d33e3f005702d153e78f175dbc13b93bcf5" alt=""
OpenVPN 2.4 からよりセキュアな認証と鍵交換をサポートしているので有効にしますか? モバイルアプリの OepnVPN Connect はサポートしてます。はい有効にします。
data:image/s3,"s3://crabby-images/2fc11/2fc11a27ad2f79f5737ff19c07d25b57620981e1" alt=""
暗号の鍵長選択。うちのラズパイは貧弱なので 256 ビットを選択。
data:image/s3,"s3://crabby-images/75e86/75e8606b58721d8e9751a607b4b14038da3b4a5c" alt=""
クライアントが接続する先のIPアドレス or DNS 名指定。我が家は固定IPアドレスではないので DNS を選択する。
data:image/s3,"s3://crabby-images/bd3bd/bd3bd5ac9440eeb785b854c09337963e9985fbd1" alt=""
DNS 名指定。我が家の WiFi ルーターは TP-Link Deco M5 なので簡単に DDNS 設定できました。
data:image/s3,"s3://crabby-images/5282b/5282b8c310ac4c78a2d32dff88aac1677bf53af8" alt=""
確認。
data:image/s3,"s3://crabby-images/0bfc6/0bfc6bcf209fa1235f3d7e1edd6d3fea4b1bf14d" alt=""
VPN クライアントに配る DNS サーバーの IP アドレスリストを指定します。有名所の Public DNS サーバーは選択肢から選べます。スクロールして見えなくなっていますが Google の 8.8.8.8 のやつも1番目にありました。VPN での接続先にあるサーバーを指定したりする場合は Custom を選択します。
data:image/s3,"s3://crabby-images/de4d7/de4d722fb2dee9af0103943ceaef074fb46c9c10" alt=""
Quad9 (9.9.9.9) を指定してみました。
data:image/s3,"s3://crabby-images/76f80/76f80f57afb1a6775e6957ab8d2375583c6cb63f" alt=""
確認。
data:image/s3,"s3://crabby-images/ac98c/ac98cbb9b5de99e940c6388d74468b29866e5bf7" alt=""
インストール完了。pivpn add
でクライアント用プロファイル作ってね。ログは /etc/pivpn
ディレクトリにあるよ。
data:image/s3,"s3://crabby-images/f2ed3/f2ed34cc6075ceaa29f29a30e312a38f3f178672" alt=""
インストール後は reboot をオススメします。reboot しますか?はい。
data:image/s3,"s3://crabby-images/2047b/2047ba54a19a301ea8770dfddf840f4664f0893c" alt=""
reboot します。
data:image/s3,"s3://crabby-images/0ad00/0ad00f60f6501e99ca84f54386d0f451d128c561" alt=""
Ok で reboot するよ。
インストール完了しました。次はクライアント用プロファル作成です。
VPN クライアント用プロファイル作成
インストール中にも表示されていたように pivpn add
コマンドで作成できます。
# pivpn -h
::: Control all PiVPN specific functions!
:::
::: Usage: pivpn <command> [option]
:::
::: Commands:
::: -a, add [nopass] Create a client ovpn profile, optional nopass
::: -c, clients List any connected clients to the server
::: -d, debug Start a debugging session if having trouble
::: -l, list List all valid and revoked certificates
::: -r, revoke Revoke a client ovpn profile
::: -h, help Show this help dialog
::: -u, uninstall Uninstall PiVPN from your system!
キーペアの秘密鍵をパスフレーズで保護しない場合は pivpn add nopass
と実行します。 実行したら Enter a Name for the Client:
と、クライアント名の入力を求められるので入力したら /home/pivpn/ovpns
ディレクトリに クライアント名.ovpn
ファイルが作成されます。このファイルをメールなどでスマホ (スマホじゃなくても良いけど) に送って OpenVPN Connect アプリを起動して読み込めば完了です。
あ、ポート転送忘れてた。
ルーターでのポート転送
我が家は Softbank のルーターの下にさらに WiFi ルーターの TP-Link Deco M5 が NAT しているのでそれぞれで 1194/udp を転送しました。
[Softbank Router] --> [Deco M5] --> [OpenVPN on DietPi]
これで Microsoft Remote Desktop アプリを使えば Ctrl キーとかも使えます。やったネ!(Beta版もある)