sshdを動かしてみる
実はこれをやろうとしてはまったのだ【爆】
で、途中になっていたので、やっぱりやってみる事にする。
参考
http://osksn2.hep.sci.osaka-u.ac.jp/~naga/miscellaneous/winssha-1.html
http://sakura.ducub.com/cgi/a-column/data/soft/1014123354.html
必要項目のインストール
Cygwinのsetup.exeを起動して、以下の項目をインストールする。
- cygrunsrv[Admin]
- openssh[Net]
環境変数の修正。
c:?/cygwinにインストールしてるものとして話は続く。あと、Windowsの管理者権限なんかがないとマズイかもしれない。
マイコンピュータを右クリックしてプロパティを表示。
詳細タブをクリック。
環境変数ボタンをクリック。
システム環境変数のPathを選択し、編集ボタンをクリック。変数値に'c:?cygwin?bin?'を追加。
システム環境変数の新規ボタンをクリック。変数名に'CYGWIN'、変数値に'binmode ntsec ntea tty'*1を入力。
sshdの起動準備。
cygwinを起動して、
$ ssh-host-config -y
なにやら必要なファイルを自動的に作ったあと、環境変数'CYGWIN'の入力を求めてくるが、デフォルトの'ntsec'のままで良いのでそのままreturn。
'Host configuration finished. Have fun!'と表示されたら終了。
パーミッションの変更。
/etc以下のsshd関連ファイルのパーミッションを変更。cgywin上で、
$ chown system.system /etc/ssh_host*_key
$ chmod 600 /etc/ssh_host*_key
Windowsへのサービス登録を行なう。
マイコンピュータを右クリックして管理ダイアログを表示。
「サービスとアプリケーション→サービス」を選択。
右のリストに'CYGWIN sshd'があるはずなので、それを選択してサービスの開始ボタンをクリック。
この状態でcygwinから、
$ ssh localhost
でログイン出来ればオッケー・・・ なんだけど、ログインした途端に接続を切られてしまう(?_?)
いろいろ調べてみたのだが、行き着いたところは、
http://www.cygwin.com/ml/cygwin-announce/2004-08/msg00031.html
で、この中に、
Thanks to an early bug report on the cygwin mailing list, I found that
you *must* add the -r option when starting the sshd daemon, if you want
to use privilege separation. Either that, or disable privilege separation
in /etc/sshd_config by setting
UsePrivilegeSeparation no
とあった(-_-;) 要は"バグってるから、privilege separation(特権分離機能)使うなら-rオプションつけてsshdを起動してね。それじゃなかったらこの機能は使わないよーに。"ということ。特に使うつもりもないので【笑】
/etc/sshd_configのUsePrivilegeSeparationをno
にして*2sshdを再起動。
$ net stop "CYGWIN sshd"
$ net start "CYGWIN sshd"
再度、
$ ssh localhost
今度は無事ログインに成功(-o-;)