PortForwarder

22番ホームへ、いらっしゃい。 のつづきです。

ポートフォワーディング(SSHポート転送)を利用すれば、ブロードバンドルータやファイアウォールを安全に飛び越えて、外から家庭内LAN内のいろんなサービス(リモートデスクトップとかプロキシとかメディアサーバー?とか)に接続できたりして、とても便利な機能なのですが、いかんせん、Windowsでそれらを使用するにはハードルが高すぎますね。

TeraTermを毎日使うような、いわゆるサーバー管理屋さん(クライアントにWindowsなんて使ってないと思うけど・・・)ならともかく、僕みたいに、ちょこっと使えればいいんだよ! という人向きではないです。

ともかく、FTPでファイル転送するたびにTeraTermを起ち上げるなんてメンドーだ。

というわけで、Windowsに常駐してくれるタイプの、その名もズバリのプログラムを公開されている方がいました。検索すれば出てくる。Windowsではあまり需要がないのか?数が少ない。いろいろ探してみたけど、「PortForwarder」しか見つけられなかった。

「PortForwarder 2.9.0 release October 20, 2007」
http://toh.fuji-climb.org/pf/JP/

フリーで、ソースも公開されているし、機能もシンプルです。切断ボタンがあれば・・・とも思ったんですが・・・必要十分です。

設定はファイルに記述するタイプで、

Host HOGEHOGE.JP
    HostName xxx.xxx.xxx.xxx
    User yyyyy
    LocalForward 9999 127.0.0.1:21
    LocalForward 50000 127.0.0.1:50000
    LocalForward 50001 127.0.0.1:50001
    LocalForward 50002 127.0.0.1:50002
    LocalForward 50003 127.0.0.1:50003
    LocalForward 50004 127.0.0.1:50004
    LocalForward 50005 127.0.0.1:50005
    Compression yes

 

と、こんな感じの記述です。カンタンです(^^)

公開鍵認証をさせるには秘密鍵をid_dsa というようなファイル名にして、実行ファイルと同じディレクトリに置いとく必要があります。秘密鍵自体をコピーして分散させるのがいやで・・・WindowsVistaから「ホンモノ」の(笑)シンボリックリンクが作れるようになったので、秘密鍵へシンボリックリンクをはることで回避。

・・・ファイルパスを指定できるようにできたらな・・・とか、切断ボタンがあれば・・・とか、機能そのものじゃなく、GUI的な部分で若干不満がありますが・・・、これもソースが公開されているので、「使いやすいように自分でなんとかしてね」ということなんでしょうね(^^;;;

また暇ができたらGUI部分を改造しようかな、と思います。いや、便利です。コレ。

Windows本体でこういった基本的な機能はサポートしてくれりゃいいのにね・・・。

22番ホームへ、いらっしゃい。

変なタイトルですみません・・・。(ちと間違いがあったので大幅に修正しました。9/2)
「ポートフォワーディング」を検索すると概念的な説明とか詳しい設定方法がいっぱいあるのでそちらを参照するほうが良いです。あくまで自分用の備忘録です。あしからず。

Webサイト構築などでサーバーの設定を自分でいじれるようになると、いろいろ触りたくなるものです。通常ホームページのデータはFTPでアップロードしてたわけですが、セキュリティーだの個人情報だの、騒がれると、このFTP経由でのアップロード手段も問題となります。FTPの何が駄目なのか、「生のデータを垂れ流す」この一点につきると思います。パスワードでさえプレーンテキストで送っちゃうんですから・・・。

というわけで、SFTPだの、SSLを利用したFTPSだのといったものが出てくるわけですが、使い慣れたFTPクライアントを変えたくない・・・というのは誰しも思うのではないでしょうか。

そこで、これらセキュリティーの問題を克服しつつ、使い慣れたFTPクライアントを使い続けたい・・・この二つの要望を叶えてくれるのが、TCP 22番ポートを利用した、ポートフォワーディングというわけです。

つい最近知りました(笑)

もともとは、DreamWeaverCS4で、秘密鍵を利用したsFTPができないことが、不満で、いろいろ検索して調べた結果、このポートフォワーディングという仕組みを知ったというわけです。なお、DreamWeaverCS4はSFTPのパスワード認証ログインのみ対応しているようです。CS5は持ってないので分かりません。

で・・・ポートフォワーディングを利用する準備です。TeraTerm(ver4.65)を使用します。

  1. サーバー側のsshd の設定を確認。
    /etc/ssh/sshd_config ファイルで、AllowTcpForwarding yes に。
  2. FTPサーバー(vsftpd) の設定ファイル(/etc/vsftpd/vsftpd.conf)に次を追記。
    pasv_promiscuous=YES
    (注)YES に設定した場合、 PASV セキュリティーチェックを無効にし、 制御用の接続と異なる IP アドレスからのデータ接続を許可する。 何をしているかを理解している場合にのみ有効にすること。 唯一の道理にかなった利用法は、安全なトンネルの中で使うか、 そうでなければ、おそらくは FXP(訳注: リモートホスト間転送) を容易にするためのものである。

    pasv_min_port=50000
    pasv_max_port=50002
    も追加します。PASVモードでデータ受信のためにランダムなポートで接続しますので、これらポートもポートフォワーディングしないといけません。ポート番号の最小値・最大値を指定してそれらのポートすべてについてポートフォワーディングする必要があります。 ※これら上記の値(50000とか)は適当につけてます。

  3. TeraTermの「設定」メニューの【ssh転送】を設定。 
      SSHポート転送2 
    「ローカルのポート」は、FTPクライアントと同じマシン(つまりlocalhost)の適当なポート。21番じゃなくてもいい。なんでも好きなの。 「リモート側ホスト」には、sshdが動作しているサーバーから見たFTPホスト。たいていsshdとvsftpdは同じマシンで動作していることが多いし、実際僕の場合もそうなので、今回はサーバーから見たFTPホストということで127.0.0.1を入力。
    また、これと同様に上記で
    pasv_min_port=50000
    pasv_max_port=50002
    と設定しているので、50000~50002までのポートも同様に転送設定を行います。
    SSHポート転送3 

    最終的には、下記のような感じになります。
    SSHポート転送 

    これらの設定で、クライアント側のマシンで21番と,50000~50002番ポートがLISTEN状態になっているはずです。コマンドプロンプトを立ち上げ、netstat –a –p TCP と入力することで確認できます。

  4. 準備完了で、次はFTPクライアントの設定変更です。
  5. FTPクライアントの設定。
    普通はFTPサーバーの接続先は、Webサーバーのアドレスを指定していると思いますが、これをlocalhost、つまり自分のマシンのループバックアドレス(127.0.0.1)を指定します。使用するポートは、上記で指定した「ローカルポート」を使うように設定します。上記の例ですと21番を指定しているので、FTPクライアントのポート番号を変更する必要はないですが。
    あと、PASVモードを有効にする必要です。
  6. これで設定終了。
    つまり、FTPクライアントは、自分のマシンの21番ポートにアクセスすると、ポートフォワーディングによって、その接続(コネクション)がリモートホスト側に転送されるってわけで。自分のマシンからリモートホストまでは当然、ssh接続なのですべてのデータが暗号化されている・・・ってわけで、これで安心・・・というわけです。。。
  7. ちなみに・・・
    FTPサーバーの設定で、ローカルアドレス(127.0.0.1)からのみ接続可のように設定しておけば、ポートフォワーディングしていない、普通の?FTP接続は拒否できると思います。たとえば、僕は /etc/xinetd.d/vsftpd に、only_from = 127.0.0.1 とかしています・・・。

FTP接続するたびに、TeraTermを立ち上げなければなりませんが、まぁ、最小化していれば問題ないしね。。。

 

で、このポートフォワーディングを利用することで、なにかとアクセス制限が多くなるファイアーウォールを超えて自由に通信が可能になります。家のブロードバンドルータの22番ポートさえ開けておけば、適切にアドレス変換などの設定を行うことで、インターネット上の経路を流れるデータを暗号化しつつ、どんなポートでも転送してくれるので非常に便利です。

あ、sshdデーモンの設定を変えれば別に22番ポートじゃなくてもいいかなと。 実際、秘密にするときは、22番ポートなんて使わないでしょうし。。。

いやぁ、Linuxのサーバー一個家に入れとくだけで、たいていのことなら全部解決してしまいますねぇ~。便利ですねぇ。

透過ミラー!

「トランスルーセントミラー・テクノロジー」

またエライもん出してきましたね・・・まったく初耳のワードで、よく分からんが・・・
ミラーはAFセンサーのためだけに存在している?みたいですね。EVFになんだから、そりゃそーだ。

速いから出会える瞬間がある 世界初透過ミラー搭載「スピード一眼」α誕生。 α55 α33 その速さを体験しよう! *2010年8月24日広報発表時点、レンズ交換式デジタルカメラにおいて

連写が10コマ/秒。。。この方式だったら、電子シャッターにすれば、この数字はもっと上がりそうな感じなんだけど・・・、そんな単純な話じゃないのかな。

仕様をザラッとみても、この透過ミラーとEVF以外は・・・とくに目新しいものはなく、まぁ、カメラ自体は平凡な感じが・・・しないではない・・・けど、やっぱりファインダーがEVFなのはちょっと違和感アリアリです。一眼レフスタイルのデザインじゃなくて、もっとデジイチから崩したデザインでも良かったんじゃないのかな~、と思ったりしますが・・・。

一応ミラーがあるので、ミラーレスじゃないけど・・・「一眼レフカメラ」とも言えないような・・・・と思って仕様をよく見ると・・・「レンズ交換式デジタル一眼カメラ」って書いてますね(^^;

 

僕は同時に発表された、「Distagon(ディスタゴン)T* 24mm F2 ZA SSM」 が非常に気になってます・・・。

 Distagon T 24mm F2 ZA SSM

定価約16万か・・・。なかなか所有欲をそそられるレンズではあります!なんか売って資金を捻出しようかな・・・。

Gmail on iPhone4

iPhone4でGmailを使ってます。 最近他の2つほどあるプロバイダのメールアドレスに届くメールをGmailのアドレスに転送するようにしてます。

Gmailはメールが届くと、クライアントにプッシュ通知してくれるのが便利で、携帯電話のメールみたいに届いてすぐに通知してくれるので非常にイイです。

・・・って、実は、それを数日前に初めて知りました(笑)

GmailのアカウントをiPhoneに設定するとき、当然のように”Gmail”のところに設定してたわけですが・・・Gmailでプッシュ通知を可能するには、まさかの(笑)Microsoft Exchangeを選ぶなんて、思いも寄らず・・・。

ただ・・・これ、バッテリーの減りがえれぇ早くなったような・・・。プッシュ通知自体の仕組み(というかプロトコル?)を知らないので詳しくは分かんないけど・・・定期的にポーリングしてんのかな?

便利なんだから、まぁ細かいことはいいや。

これ知る前は、Gmailからi.softbank.jpアカウントへ全部転送してました。これだと同じメールが二つ届くので・・・なんかイイ方法はないかなぁ~、と思ってたんですよね。

これもつい最近知ったんですが、Gmailからi.softbank.jpへ転送して、iPhone4に設定してあるi.softbank.jpのアカウントを停止して通知のみ受け取る方法もあるんだそうで・・・。i.softbank.jpアカウントを停止すると通知はされなくなる・・・と僕は勝手に思い込んでいまして・・・(^^;;;

最近、”Downloads”というアプリを購入しました。これめっちゃエエです! youtubeとかの動画をカンタンにダウンロードしてオフラインで楽しめます(^^

地デジ録画できてケータイかiPhone4へ動画を持ち出せる、レコーダーを物色中なんですが・・・どれも高いですね~。う~ん・・・。Diga欲しい・・・。

VirtualHostの設定

今のブログ(WordPress)のテーマが飽きてきたので、変えてみました。ちょっと見づらいけど・・・。

Apache2.2でバーチャルホストの設定を行っていて、あまりにも無知なおいらに愕然としたので、備忘録として残しておこう・・・というエントリです。

なお、このエントリいう、バーチャルホストは、ネームベースのバーチャルホストです。さらに、LAN内のテスト目的に設置するWebサーバーの事です。あしからず。

通常、バーチャルホストの設定は、以下のような感じかと思います。

 
NameVirtualHost *:80 
<virtualhost *:80>
  ServerName first.localdomain
  DocumentRoot /var/www/vhosts/first
</virtualhost>

<virtualhost *:80>
  ServerName second.localdomain
  DocumentRoot /var/www/vhosts/second
</virtualhost>

のような感じかなと。

そうすることで、http://first.localdomain/ とか、http://second.localdomain/ とかでアクセスできるようになりますよね。

ここで、httpsでもアクセスできるようしたい場合・・・HTTPSリクエストを処理できるように設定をした上で、さきほどの設定にNameVirtualHost *:443 を追加して、<VirtualHost *:80> を、<VirtualHost *:80 *:443>と書けば済む話だったんですね・・・。

 
NameVirtualHost *:80
NameVirtualHost *:443

&lt;virtualhost *:80 *:443&gt;
  ServerName first.localdomain
  DocumentRoot /var/www/vhosts/first
&lt;/virtualhost&gt;

&lt;virtualhost *:80 *:443&gt;
  ServerName second.localdomain
  DocumentRoot /var/www/vhosts/second
&lt;/virtualhost&gt;

ドキュメントをよく読めばすぐ解決するものを・・・しかも、:80を省略したら、httpdの起動時にエラーになるし・・・。気付くの遅くてApacheの設定にまる一日かかっちゃったよ。。。(ーー;;;

やっぱり、ドキュメントはちゃんと読まないとダメですね・・・。
で・・・バーチャルホストの設定をいろいろやってたら・・・

自分だけが知っている秘密のホスト名をつけたバーチャルホストを定義すれば、公開しているWebサーバーと同じサーバー上に秘密の?Webサーバーを同時に立てられるな・・・と気がつきました。気付くの遅すぎ(笑)

隠したければ、BASIC認証なりDigest認証なりでパスワードでロックすれば済む話ですが、存在自体をなるべく隠したいといった場合は使えるかもしれませんね。。。もちろん、クライアント側には、hostsファイルなどでIPアドレスと名前を登録しなければいけませんが・・・。仲間内だけでWebサーバーを公開したいといった場合は便利かも・・・。