sshdを動かしてみる

  • 投稿日:
  • by
  • カテゴリ:
  • tweetする



 実はこれをやろうとしてはまったのだ【爆】


 で、途中になっていたので、やっぱりやってみる事にする。


 参考


  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-;)




*1:これでいいのかどうか、ちょっと怪しい【爆】


*2:ssh-host-configの時、'Should privilege separation be used? (yes/no)'で'no'としておけば、この苦労は不要らしい。