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

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

新規登録して質問してみよう
ただいま回答率
85.35%
WSL(Windows Subsystem for Linux)

WSL (Windows Subsystem for Linux) は、Windows10のOS上でLinux向けのバイナリプログラムを実行可能にする機能です。また、WindowsOSのAPIを用いた仕組みを提供しており、Linux側からWindowsOSへのファイルアクセスもできます。

Q&A

解決済

3回答

4051閲覧

VSCodeの拡張機能Remote-WSLのターミナルでは.exeファイルが実行できない...?

namnium1125

総合スコア2045

WSL(Windows Subsystem for Linux)

WSL (Windows Subsystem for Linux) は、Windows10のOS上でLinux向けのバイナリプログラムを実行可能にする機能です。また、WindowsOSのAPIを用いた仕組みを提供しており、Linux側からWindowsOSへのファイルアクセスもできます。

0グッド

0クリップ

投稿2020/10/30 12:57

編集2020/10/30 14:52

Powershellでは当たり前に、通常のWSLのUbuntuターミナルでも、普通でしたら以下のようにしてメモ帳を起動することができます。その他の .exe ファイルも同様です。

wsl

1$ notepad.exe

しかし、VSCodeの拡張機能 Remote-WSL を使用し、そのターミナルから実行した場合、以下のようなエラーになりました。

wsl

1$ notepad.exe 2<3>init: (21306) ERROR: UtilConnectToInteropServer:300: connect failed 2

質問

エラーで検索を掛けても情報を見つけることができなかったので質問させていただきます。

この拡張機能を使っている方皆さん同じ現象が起きるのでしょうか...?(それだけでも答えていただけると諦めがつくので幸いです。)
それとも設定でどうにかなるものなのでしょうか?

全く詳しくないので適当な予想なのですが拡張機能 Remote-SSH と似たようなことをしており .exe ファイルはリモートではできないような特殊な方法で起動されているからVSCodeでは起動できない...みたいな感じなのでしょうか...?(自分のWSLにSSH接続するなどで検証できそうですがしていません...)

普通のターミナルから実行すればよいだけなのでものすごい問題というわけではないですが、ターミナル(というよりはウィンドウ)が増えるのは避けたいので解決策を探しています。

何かわかる方がおりましたら回答よろしくお願いいたします。

バージョン情報

  • Windows 10 Pro バージョン 2004 OSビルド 19041.572
  • WSL: Ubuntu 20.04.1 LTS
  • VSCode: 1.50.1
  • Remote-WSL: 0.50.1
  • [追記] wsl.exe -l -v を実行すると VERSION2 でした。

他に必要な情報があれば追記いたします。

追記(質問背景)

LinuxのバイナリとWindowsのバイナリが異なることは理解しております。GUIアプリケーションをRustで開発しているのですがWSLで動かすLinuxバイナリだと依存関係の問題かうまく動かなかったので、ターミナルはWSLですが生成するアプリケーションはWindows用という言われてみれば奇妙な環境で開発しようと考えていました。(Powershellはアレルギーなので使いたくないのとMinGW等は導入が面倒という側面があります。)

一応背景を追記いたしましたが、質問の本筋とは関係がありません。

引き続き回答よろしくお願いいたします。

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

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

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

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

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

guest

回答3

0

ベストアンサー

ええと、WSLが最初に出てきた頃はWindowsの実行ファイルを実行できなかったのですが、現在のWSLでは実行可能です(binfmt_miscを利用)。拡張子まで指定する必要がありますが、質問文からすると質問者はそれを既に知っていますね。

質問は、「VSCodeのRemote-WSLのターミナルからでは実行できない(エラーになるのか)」ですよね。こちらの環境では、VSCodeのRemote-WSLのターミナルからnotepad.exeで問題なくメモ帳を実行できたので、そちらの環境に何か問題があると思います。

投稿2020/10/30 13:51

編集2020/10/30 14:14
Daregada

総合スコア11990

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

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

namnium1125

2020/10/30 14:45

回答ありがとうございます。もう少し調べてみようと思います。ところでなんとなく思い出したので質問文に追記しようとおもうのですがWSL"2"であることが問題なのかもしれません...WSLのバージョンってどうなっていますか?
Daregada

2020/10/30 14:50

こっちはWSL1, Ubuntu 18.04, Windows 10 1909ですね。
namnium1125

2020/10/30 14:53

ありがとうございます。こちらもWSL1では問題ないことを確認いたしましたので、WSL2であることが原因かもしれません。(1と2では仕組みが違うらしいですし...)
Daregada

2020/10/30 16:54

ちょうどWindows 10 20H2に更新するところだったので、更新後にWSL2に変更し(Ubuntu 18.04はそのまま)、VSCodeのRemote-WSLのターミナルからnotepad.exeを実行したところ、エラーは起きずに起動しました。
namnium1125

2020/10/30 21:51

わざわざありがとうございます。m(_ _)m 私の手元の問題みたいですね...もう少し手元の状況を調べてみます
namnium1125

2020/10/30 23:52

無事に解決できました! Daregada様が回答してくださったおかげで手元で変なことをしていないか確認するまでに至れました。本当にありがとうございました。
guest

0

とりあえず今回の問題については原因がわかりましたので自己解決としてここに書かせていただきます。

自分は「 VSCode → 左下にある Remote-WSL 接続」という流れで起動するのが面倒に感じたため次のショートカットを使用していました。

ショートカットのリンク先:

C:\Windows\System32\wsl.exe code /home/user_name

しかしこのショートカットを利用すると $WSL_INTEROP 変数の値が無効なものになります。この場合に .exe ファイルがうまく起動しないようです。

プロセスの親子関係の問題でしょうかね? pstree -p で調べたのですがはっきりしませんでした。

自作ショートカットを使用せず真面目に普通にVSCodeを開いてリモート接続すると、 $WSL_INTEROP の値は正常なもの(親プロセスIDによるもの)になり無事に .exe ファイルを起動することができました。

参考

[WSL2] [Interop] Keep a single shared /run/WSL/* socket · Issue #5065 · microsoft/WSL

投稿2020/10/30 23:51

namnium1125

総合スコア2045

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

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

0

WSLってのはLinux環境ですが、Linux上では、Windowsの実行ファイルは実行できません

投稿2020/10/30 13:11

y_waiwai

総合スコア88042

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

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

あなたの回答

tips

太字

斜体

打ち消し線

見出し

引用テキストの挿入

コードの挿入

リンクの挿入

リストの挿入

番号リストの挿入

表の挿入

水平線の挿入

プレビュー

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

ただいまの回答率
85.35%

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

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

質問する

関連した質問