質問をすることでしか得られない、回答やアドバイスがある。

15分調べてもわからないことは、質問しよう!

新規登録して質問してみよう
ただいま回答率
85.48%
Windows 10

Windows 10は、マイクロソフト社がリリースしたOSです。Modern UIを標準画面にした8.1から、10では再びデスクトップ主体に戻され、UIも変更されています。PCやスマホ、タブレットなど様々なデバイスに幅広く対応していることが特徴です。

SSH

SSH(Secure Shell)は、セキュアチャネルを通してデータを交換するためのネットワークプロトコルです。リモートサーバーへのコマンド実行やファイル転送を行う時に一般的に使用されます。

Linux

Linuxは、Unixをベースにして開発されたオペレーティングシステムです。日本では「リナックス」と呼ばれています。 主にWebサーバやDNSサーバ、イントラネットなどのサーバ用OSとして利用されています。 上位500のスーパーコンピュータの90%以上はLinuxを使用しています。 携帯端末用のプラットフォームAndroidは、Linuxカーネル上に構築されています。

Q&A

解決済

1回答

14528閲覧

win10標準のopenSSHを使って、リモートのUbuntuにX11 Forwardingしたい

ayaten3

総合スコア5

Windows 10

Windows 10は、マイクロソフト社がリリースしたOSです。Modern UIを標準画面にした8.1から、10では再びデスクトップ主体に戻され、UIも変更されています。PCやスマホ、タブレットなど様々なデバイスに幅広く対応していることが特徴です。

SSH

SSH(Secure Shell)は、セキュアチャネルを通してデータを交換するためのネットワークプロトコルです。リモートサーバーへのコマンド実行やファイル転送を行う時に一般的に使用されます。

Linux

Linuxは、Unixをベースにして開発されたオペレーティングシステムです。日本では「リナックス」と呼ばれています。 主にWebサーバやDNSサーバ、イントラネットなどのサーバ用OSとして利用されています。 上位500のスーパーコンピュータの90%以上はLinuxを使用しています。 携帯端末用のプラットフォームAndroidは、Linuxカーネル上に構築されています。

0グッド

1クリップ

投稿2020/03/11 16:52

編集2020/03/12 14:45

前提・実現したいこと

  • リモートのubuntuのxeyesを、ホストのwin10上のXサーバ(VcXsrv)にX11 Forwardingで表示する
  • sshクライアントとして、win10標準のopenSSHを使用したい

環境

  • ubuntuのsshdは設定済み
X11Forwarding yes X11UseLocalhost no PasswordAuthentication yes
  • win10上でXサーバ(VcXsrv)は起動済み

発生している問題・エラーメッセージ

win10のコマンドプロンプトから-Xオプション付きでsshする

ssh -X user@remote

sshログイン後、xeyesの起動に失敗する

user@remote$ xeyes Error: Can't open display: user@remote$ echo $DISPLAY user@remote$

試したこと

TeraTermのX11 Forwardingを使った場合、TeraTermのターミナル上で

user@remote$ echo $DISPLAY

とすると、DISPLAY変数が自動設定されています。xeyesも起動できて、win10上のXサーバで表示できます

試したこと(20/03/12 追記)

win10のコマンドプロンプトでDISPLAY環境変数をsetした後にssh -Yすると、エラーが発生して繋がりませんでした。 DISPLAY環境変数をsetしていないコマンドプロンプトでは、ssh -Yは成功しました(ssh後のxeyesは失敗します)

そこでset DISPLAYした後にssh -Y -vvvとすると、以下のエラーが発生していました

debug3: spawning "/usr/X11R6/bin/ssh-askpass" CreateProcessW failed error:2 ssh_askpass: posix_spawn: No such file or directory

一方、Powershellでset DISPLAYssh -Yを行うと、sshは成功しました
しかし、ssh後のxeyesは失敗しました


現状として、疑問点は2つです

  • win10のターミナルをsshクライアントとしてX11 Forwardingできるのか?(未解決)
  • コマンドプロンプトとPowershellで挙動が違うのは何故か?

ご教示いただけますと幸いです。

気になる質問をクリップする

クリップした質問は、後からいつでもMYページで確認できます。

またクリップした質問に回答があった際、通知やメールを受け取ることができます。

バッドをするには、ログインかつ

こちらの条件を満たす必要があります。

guest

回答1

0

ベストアンサー

SSHでX11転送を行う場合、ローカル側でDISPLAY環境変数が正しく設定されている必要があります。
Tera TermでX Forwardingをonにするだけで使えているのならば、localhost:0.0 に設定すれば大丈夫です。
また、-XによるX11転送はローカル側でxauthコマンドが使える必要があります。使えない場合は、セキュリティ的には落ちますが-Yによるtrusted X11 Forwardingを使ってください。

cmd

1set DISPLAY=localhost:0.0 2ssh -Y user@remote

最後に、

X11UseLocalhost no

この設定を使うのはセキュリティ的には望ましくありません。
この設定を入れないとどうしても動かない時のみ設定を行う事をお勧めします。


DISPLAYを設定するとログイン出来ない問題

バグなのか仕様なのかよく分からないのですが、DISPLAYが設定されていて\dev\ttyというファイルが無いと、パスワード/パスフレーズの入力時ssh-askpassを起動しようとして失敗し、結果として認証が行えずログイン出来なくなるようです。

対処としては公開鍵認証の設定を行い、ssh-agent に鍵を登録してパスフレーズの入力無しでログイン出来るようにするというのが有りますが、手順の説明が面倒なので今回はダミーの\dev\ttyを作る方法を紹介します。ssh-agentを使う方法について知りたい場合はGoogle等で検索するか、新しい質問として投稿してください。

ダミーの\dev\ttyは中身は何でもいいようなので、以下の手順で適当なファイルを作成してください。

cmd

1mkdir \dev 2echo a > \dev\tty

上記を行った後ならばDISPLAYが設定してあってもssh -Yでパスワード/パスフレーズの入力が行えるはずです。
またD:E:など、C:以外のドライブにいる時にもsshを使いたい場合は、各ドライブで\dev\ttyを作成する必要があるようです。

PowerShellでの挙動が違う問題

コマンドプロンプトとPowerShellでは環境変数の設定方法が違います。その為、PowerShell ではDISPLAYが設定されていない状態となり動作が変わってきます。
PowerShellで環境変数DISPLAYを設定するには以下のようにしてください。

PowerShell

1$env:DISPLAY="localhost:0.0"

投稿2020/03/11 18:05

編集2020/03/12 15:40
doda

総合スコア947

バッドをするには、ログインかつ

こちらの条件を満たす必要があります。

ayaten3

2020/03/12 14:46 編集

回答ありがとうございます。 試してみましたが、上手くいきませんでした。 試した内容を追記しましたので、ご教示いただけますと幸いです。
ayaten3

2020/03/13 09:20

教えていただいたとおり、ttyファイルを作成したら成功しました。 ありがとうございました。
guest

あなたの回答

tips

太字

斜体

打ち消し線

見出し

引用テキストの挿入

コードの挿入

リンクの挿入

リストの挿入

番号リストの挿入

表の挿入

水平線の挿入

プレビュー

15分調べてもわからないことは
teratailで質問しよう!

ただいまの回答率
85.48%

質問をまとめることで
思考を整理して素早く解決

テンプレート機能で
簡単に質問をまとめる

質問する

関連した質問