39
19

Delete article

Deleted articles cannot be recovered.

Draft of this article would be also deleted.

Are you sure you want to delete this article?

More than 5 years have passed since last update.

SSHダイナミックポートフォワードを使ってローカルマシンから固定IPアドレスでWebアクセスをする

Posted at

あるWebサイトにアクセスする際に固定IPアドレスが必要。(複数人)
でも自宅は固定IPサービスを持っていない。
外部に固定IPを持ったマシンは作れる。(AWSなど)

そんな時にSSHダイナミックポートフォワードを使うことでローカルマシンから外部の固定IPを経由してWebサイトにアクセスし、ブラウザで表示できたのでメモ。

環境

  • ローカルPC(Mac OSX 10.11.4)
  • リモートサーバー(Amazon Linux AMI 2016.03.0)

参考

ダイナミックポートフォワードでlocalhostからのみアクセスできるページを確認してみる

サーバー側の準備

まずはいきなり、本題を実施せず、ダイナミックポートフォワードがうまくできるかやってみます。

httpdの情報が取得できるserver-statusを有効にします。
その後、上記サイトへはlocalhostからのアクセスのみ許可するように設定し、ローカルマシンのブラウザから確認できるかやってみます。

# httpdのインストール
$sudo yum install httpd -y

# 設定ファイルを変更し、server-statusを有効化
$sudo vi /etc/httpd/conf/httpd.conf

/etc/httpd/conf/httpd.conf
<Location /server-status>
    SetHandler server-status
    Order deny,allow
    Deny from all
    Allow from localhost
</Location>
# サービス起動
$sudo service httpd start

# server-statusが取得できることを確認
$curl http://localhost/server-status

これでサーバー側の準備ができました。

ローカルマシンから確認してみる

次にローカルマシンからSSHダイナミックポートフォワードで接続します。
これによってローカル->リモートサーバー間をSSHで接続します。
sshコマンドの-D [port]と指定することでダイナミックポートフォワードの有効化とローカルホストのどのポートをリモートサーバーにフォワードさせるか決めます。

$ssh -v -D 1080 ec2-user@xx.xxx.xxxx.xxx -i ~/.ssh/hoge.pem
・・・
debug1: Local connections to LOCALHOST:1080 forwarded to remote address socks:0
debug1: Local forwarding listening on ::1 port 1080.
debug1: channel 0: new [port listener]
debug1: Local forwarding listening on 127.0.0.1 port 1080.
debug1: channel 1: new [port listener]
debug1: channel 2: new [client-session]
debug1: Requesting no-more-sessions@openssh.com
・・・

成功した場合、上記のようにSOCKSプロトコルにより、1080がフォワードされることが確認できます。

なお、バックグラウンドSSHを実行させたい場合には以下のオプションで実行します。

$ssh  -v -N -f -L ec2-user@xx.xxx.xxxx.xxx -i ~/.ssh/hoge.pem

SSHは接続したままで次はローカルマシンからこのSSHで接続された通信を利用してlocalhostからしかアクセスできないサイトにcurlコマンドでアクセスしてみます。

$curl --socks5 localhost:10080 http://127.0.0.1/server-status

アクセスできました!

ちなみにオプションで以下でもできました。

  • --socks4
  • --socks4a
  • --socks5-hostname

基本的にSOCKSプロトコルであればバージョンはある程度対応できているようですね。

Firefoxからアクセスしてみる

以下を参考にやってみました。

特定のネットワーク内からしか見れないウェブページを外から見る方法

が、環境設定のProxyでSOCKSの設定をやってもうまくいかない。。。
CLIではうまくいっているので設定の問題ではないはず。。

Firefoxからsshのダイナミック転送を使って非公開サーバへアクセスする

こちらを見ると設定であるホストへのアクセスの場合にはSOCKSのプロキシを使ってねという設定をJSでしています。
気になったのはFirefoxの設定だとアクセス時に対象のProxyがHTTPプロキシなのかSOCKSプロキシなのか設定するわけではないので、アクセス時に誤ってHTTPプロキシなどとして動作していたら動かないだろうなという予想がつきました。

参考サイトのようにJSでやっても良かったのですが、少し面倒そうだったので良さげなアドオンがあったのでこれを使ってみます。

Socks Proxy

まずは設定をします。以下の流れで設定画面を表示させます。

Firefoxの設定(画面の右上の横線三つ)->アドオン->拡張機能->Socks Proxy->設定

以下のように設定(localhostの1080をSOCKS5のプロキシとして利用)

Screen Shot 2016-04-18 at 8.24.52 AM.png

これで設定は完了です。
Firefoxの画面に戻り、画面右上のソックスのアイコンを押してSOCKSプロキシを有効化させ、アクセスしてみます。

Screen Shot 2016-04-18 at 8.26.56 AM.png

おお!
localhostからしかアクセスできないページへSSHの接続経由で自身のMacからアクセスできました

FirefoxからSOCKSのProxyを使ってアクセスしたくない場合、ソックスのアイコンを押してdisableにすればOKです

SSHポートフォワードでWebサイトに固定IPでアクセスする

いよいよ本題です。
実験のため、もう1台Webサーバーを起動しておき、80番ポートは解放しておきます。

SOCKSのProxyを経由せず、自分のPCからブラウザでアクセスすると以下のようになります。

xxx.xxx.xxx.xx - - [18/Apr/2016:06:01:06 +0000] "GET / HTTP/1.1" 403 3839 "-" "Mozilla/5.0 (Macintosh; Intel Mac OS X 10_11_4) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/49.0.2623.110 Safari/537.36"
xxx.xxxx.xxx.xx - - [18/Apr/2016:06:01:06 +0000] "GET /icons/apache_pb2.gif HTTP/1.1" 200 1797 "http://

自宅の回線は固定IPではないので、アクセスのタイミングでアクセス元IPアドレスはバラバラになります。

次に先ほどのSSHダイナミックポートフォワード経由でFirefoxからアクセスしてみます。

52.193.129.240 - - [18/Apr/2016:06:02:00 +0000] "GET / HTTP/1.1" 403 3839 "-" "Mozilla/5.0 (Macintosh; Intel Mac OS X 10.11; rv:36.0) Gecko/20100101 Firefox/36.0"
52.193.129.240 - - [18/Apr/2016:06:02:00 +0000] "GET /icons/apache_pb2.gif HTTP/1.1" 200 1797 "http://52.68.107.79/" "Mozilla/5.0 (Macintosh; Intel Mac OS X 10.11; rv:36.0) Gecko/20100101 Firefox/36.0"
52.193.129.240 - - [18/Apr/2016:06:02:00 +0000] "GET /favicon.ico HTTP/1.1" 404 287 "-" "Mozilla/5.0 (Macintosh; Intel Mac OS X 10.11; rv:36.0) Gecko/20100101 Firefox/36.0"

するとSSHでダイナミックポートフォワードしているEC2(グローバルIPが52.193.129.240)からのアクセスとなっています!

おお、やりたい事ができたー。

社内からのProxy経由で固定IPが確定しない時もSSHで固定IPを持ったリモートサーバーへアクセスできればSSHポートフォワードを使ってアクセスの確認ができて便利です。

39
19
0

Register as a new user and use Qiita more conveniently

  1. You get articles that match your needs
  2. You can efficiently read back useful information
  3. You can use dark theme
What you can do with signing up
39
19

Delete article

Deleted articles cannot be recovered.

Draft of this article would be also deleted.

Are you sure you want to delete this article?