このページの本文へ

Windows Info 第112回

Windows 10 RS4におけるWindows Subsystem for Linuxの改良点をチェックする

2018年01月14日 10時00分更新

文● 塩田紳二 編集● ASCII編集部

  • この記事をはてなブックマークに追加
  • 本文印刷

 今年3月の完成に向けて、プレビュー版のリリースが進められているWindows 10 RS4だが、昨年最後のBuild 17063では、Windows Subsystem for Linux(以下WSLと表記する)について大きな改良があった。

 RS3ことFall Creators Updateで、正式版となったWSLだが、Windows Serverにも搭載されている。また、Bash on WindowsやBash on Ubuntu on Windowsといった名称が使われていたが、Windows Subsystem for Linuxが正式な名称となり、起動のためのWSLコマンドもサポートされるようになった。

Windows 10 RC4でWindows Subsystem for Linuxが強化
バックグラウンドプロセスが利用可能に

 Build 17063では、「バックグラウンドプロセス」「環境変数の共用」といった機能が実現している。今回はとりあえず概要のみを示し、個々の機能は次回以降に詳しく見ていくことにする。

 「バックグラウンドプロセス」は、このビルドで一気に実装されたのではなく、Build 17017から行われてきた内部改良の結果としてBuild 17063で利用可能となった。

 バックグラウンドで、コンソールを割り当てられていないプロセスは、Build 17046ですでに実行可能だったが、WSLを起動したコンソール(ttyデバイス)を閉じてしまうと、WSL自体が終了してしまうため、バックグラウンドプロセスも終了させられていた。

 しかし、Build 17063からは、バックグラウンドプロセスは、WSLを起動したコンソールを閉じても動作し続けるようになった。これにより、バックグラウンドでネットワーク接続を待って機能提供するようなプログラム(Unix系ではデーモンと呼ぶ。Windowsのサービスに相当)も利用可能になった。たとえば、sshでの接続を受け付けるsshdなどを動作させておくことが可能だ。

 ただし、Linuxの「ランレベル」(rcスクリプト)のような仕組みがないため、デーモンの起動は手動でする必要があり、たとえ複数のデーモンの起動を1つのスクリプトにまとめたとしても、どこかで、root権限で処理するためのsudoコマンド用にパスワードをキーボードから入力しなければならない。

 つまり、Windowsが起動したら自動的にデーモンが起動させることはできず、パスワードを入力するような、なんらかの手作業が必要になる。前述のsshdも「sudo /etc/init.d/ssh」とせねば起動することはできない。しかし、一回起動すれば、Windowsをログオフするか再起動するまでsshdは動き続けることができる。

デーモンはroot権限を必要とする処理を行なうため、起動時にはroot権限でコマンドを実行させるsudoが必要で、パスワードをユーザーが入力しなければならない。一般的なLinuxではスタートアッププロセス(rcスクリプト)内は管理者権限で実行されるため、パスワードの入力は必要ない

 Linuxのお手本となったUnix系OSでは、システムの起動時に特定のスクリプトを管理者権限で実行させることで、デーモンのようなバックグラウンドで動作するプログラムを起動していた。

 そのファイル名からrcスクリプトなどと呼ばれている。Unix SystemV(はAT&Tの商標です、と思わず書きたくなる)では、複数の起動状態を使い分けるためにランレベル(run level)が導入された。起動スクリプトにエラーが起こると、場合によっては復旧に時間がかかってしまうこともあり、エラーの影響を抑えたり、あらかじめ検証した複数の構成から選択して起動できるようにして、エラーに備えるといった仕組みが必要になったからだ。

 その後Linuxでは、こうしたUnixでの取り組みをベースに、ランレベルなどを引き継いだものや、個人向けに簡素化したものなど、さまざまな仕組みが作られた。

 しかし、WSLでは、最初に起動するinitプロセスは、実際にはLinuxのバイナリではなく、Windowsのバイナリであり、Windows環境の中でLinuxのプログラムを動作させるのが目的であったため、ランレベルやrcスクリプトは実装されていない。

 では、WSLのバックグラウンドプロセス実行は、なんの役にも立たないのかというとそうでもない。プログラムに対してちゃんとした環境さえ整えてやれば、ウィンドウを閉じたままでも実行環境を維持することができる。

 たとえば、tmuxのような仮想端末マネージャを使って、複数のシェル環境をウィンドウを閉じても維持しておくことができる。

Windows Insider Preview Build 17063でWSLを起動しtmuxを使って4つのクライアントを動作させている

コンソールウィンドウを閉じるとcmd.exe(Procexp64.exeの下)以下が消えるが、下のtmux、bashのプロセスは残っている

同じくBuild 16299(Fall Creators Update)では、cmd.exe以下のプロセスの構造が少し違うが、下にtmuxやbashのプロセスが並ぶ

コンソールウィンドウを閉じてしまうと、wsl.exeが終了し、下にあったbashやtmuxのプロセスも終了してしまう

 複数のサーバーを管理しているとき、1つのコンソールを切り替えたり、分割ウィンドウからアクセスするなどの操作が可能だ。そんなら相手の数だけコンソールウィンドウを開けばいいじゃないか? と思うかもしれないが、多数の同じようなウィンドウは混同しやすく、一定以上になると間違った操作の原因になりやすい。

 かえって、分割ウィンドウ(tmuxではペインという)を使って位置で対象を区別したり、必要に応じて画面を切り替えて使うほうが頭の中に「全体象」が作りやすく、対象を間違えにくい。ウェブブラウザのマルチウィンドウとタブウィンドウのようなものというと少しわかりやすいだろうか。 なお、tmuxは、ptyがサポートされたRS3から利用可能だったが、プロセスを維持するためには、WSLを起動したコンソールウィンドウを閉じることができなかった。

 もう1つの「環境変数」の共用は、かつて「WSLとWin32の相互運用」(Windows Subsystem for LinuxにおけるWin32相互運用性のメカニズム、本連載の以前の記事を参照のこと)で行なわれた「Path環境変数」の共用をさらに強化したものだ。

 WSLの環境変数の共有では、WSLENVというWin32でもWSLでも見える1つの環境変数に複数の環境変数を区切って格納することで、他方へ環境変数を伝達する。このとき、環境変数の中身に応じたオプションを付け、ファイルパスの変換などを指示することができる。また、WSL側にWin32のパス文字列をDrvfsの形式に変換するwslpathというコマンドが提供されている。

 今回のRS4では、WSL自体が改良されるだけでなく、Windows側にもLinux/Unix)的な機能が導入される。すでにLinux(U)は一定の地位を占め、そのために作られるソフトウェアの中には重要なものも少なくない。しかしWindowsには、独自に開発した部分があり、そのために同じような機能を実現しているLinux/Unix系のAPIを採用しにくい部分があった。

 この部分がオープンソースソフトウェアをWindows上で利用する場合の障害になっていたが、WSLにより、Linuxのバイナリがそのまま実行できるようになった。しかし、WSLの外側にあるWin32は依然として独自の世界のままだ。これでは、WSLとWin32を連携させる場合に問題がある。WSLきWin32相互運用機能は、その解法の1つであり、前述の環境変数の共有もそのためのものだ。

 RS4ではさらに踏み込んで、Windows側にLinux/Unixでよく使われるAPIやコマンドを持ち込み、相互運用を用意にする。たとえば、すでにtarやcurlといったLinux/Unix系のコマンドが搭載された。

 また、APIでも改良がある。Windowsは伝統的にプロセス間通信では「名前付きパイプ(Named Pipe)」という機構を使っている。これに対してLinux/Unix系では、ネットワーク通信に利用するSocketで、プロセス間通信専用のアドレス形式(伝統的な命名に従ってAF_UNIXと呼ばれる。AFはAddress Familyの略)を指定することでプロセス間通信を実現できる(Linux/Unixにも名前付きパイプと呼ばれるAPIはあるが実装としてはWindowsのものと大きく違う)。

 Build 17063から、Windows側のSocketでAF_UNIX形式が利用可能になる。これにより、Linux向けのソフトウェアのプロセス間通信の部分を書き直す必要なく、Windows側で利用できるようになる。ただし、現時点では、あくまでもWin32の中でUnixドメインSocketが利用できるだけだ。

 Windowsに搭載されているSocketは「WinSock」と呼ばれ、マイクロソフトではないところで定義、開発されたものだ。当時のWindows 3.xは、TCP/IPをサポートしていなかった。このため、TCP/IPプロトコルスタックは、サードパーティソフトウェアとして導入されていた。また、アプリケーションの中には、内部に専用のTCP/IPプロトコルスタックを持つものも少なくなかった。これでは、TCP/IPを利用するアプリケーションを開発することが困難だったが、当時のマイクロソフトはインターネットを正しく理解していなかった。

 こうした中、共通のTCP/IPアプリケーションインターフェースとして提案されたのがWinSockだ。これは、BSD系Unixで開発されたSocket(BSD Socket、Barkley Socketともいう)をベースにしたもの。策定にはマイクロソフトの社員も関わったが、最初の提案はサードパーティから行なわれた。その後、マイクロソフトは、Windows95でTCP/IPに対応しWinSockを標準のAPIとして取り込んだ。しかし、WinSockは、そもそもWindowsにTCP/IPプロトコルスタックとの接続インターフェースを作るという目的であったため、プロセス間通信となるAF_UNIXには対応しなかった。

 WindowsがAF_UNIXに対応することで、多くのUnix/Linux向けのソフトウェアのプロセス間通信部分を書き換えることなく利用できるようになる(ソースコードレベルの話だが)。たとえば、Dockerなどの大物ソフトウェアの多くは、そもそもLinux由来であり、UnixドメインSocketを前提に開発されている。現在のDocker for Windowsなどでは、Named Pipeに書き換えられているが、こうした作業は不要になる。また、対応するソフトウェアも少なくないD-BusなどもUnixドメインSocketを利用する。

 最終的にWSL側とWin32側でプロセス間通信ができるようにするならUNIXドメインSocketでなければならない。というのは、WSLは、Linuxのバイナリを動作させることを前提にしていて、WindowsのNamed Pipeに対応するLinuxソフトウェアが開発されることは想定しにくい。

カテゴリートップへ

本記事はアフィリエイトプログラムによる収益を得ている場合があります

この連載の記事
1
【整備済み品】富士通 ノートパソコン LIFEBOOK U9310 13.3型FHD(1920x1080) 超軽薄 ノートPC/第10世代 Core i5-10310U@1.7GHz/ 8GB メモリ/高速ストレージ SSD/Webカメラ/WIFI/Type-C/HDMI/win11&MS Office 2019 搭載 ビジネス 在宅勤務向け パソコン (メモリ:8GB/SSD:256GB)
【整備済み品】富士通 ノートパソコン LIFEBOOK U9310 13.3型FHD(1920x1080) 超軽薄 ノートPC/第10世代 Core i5-10310U@1.7GHz/ 8GB メモリ/高速ストレージ SSD/Webカメラ/WIFI/Type-C/HDMI/win11&MS Office 2019 搭載 ビジネス 在宅勤務向け パソコン (メモリ:8GB/SSD:256GB)
¥35,129
2
【整備済み品】富士通 A748 15.6型 第8世代CPU Core i3-8130U /Windows11/MS Office2019搭載/初期設定不要/DVDドライブ/WIFI/Bluetooth/HDMI/USB3.0/テンキー(Core i3-8th, メモリ8GBSSD256GB)
【整備済み品】富士通 A748 15.6型 第8世代CPU Core i3-8130U /Windows11/MS Office2019搭載/初期設定不要/DVDドライブ/WIFI/Bluetooth/HDMI/USB3.0/テンキー(Core i3-8th, メモリ8GBSSD256GB)
¥19,880
3
Apple 2026 MacBook Air M5チップ搭載13インチノートブック:AIとApple Intelligence、13.6インチLiquid Retinaディスプレイ、16GBユニファイドメモリ、512GB SSDストレージ、12MPセンターフレームカメラ、日本語キーボード、Touch ID - スターライト
Apple 2026 MacBook Air M5チップ搭載13インチノートブック:AIとApple Intelligence、13.6インチLiquid Retinaディスプレイ、16GBユニファイドメモリ、512GB SSDストレージ、12MPセンターフレームカメラ、日本語キーボード、Touch ID - スターライト
¥224,800
4
【整備済み品】ノートパソコン 東芝 Bシリーズ core i3 第7世代/ノートPC/MS & Office2019/Windows11/15.6インチ/4GB/SSD128GB/日本語キーボード/Bluetooth/Wi-Fi/HDMI/有線マウス/内蔵テンキー/初期設定不要 初心者向け(core i3 第7世代/メモリ4GB/SSD128GB)
【整備済み品】ノートパソコン 東芝 Bシリーズ core i3 第7世代/ノートPC/MS & Office2019/Windows11/15.6インチ/4GB/SSD128GB/日本語キーボード/Bluetooth/Wi-Fi/HDMI/有線マウス/内蔵テンキー/初期設定不要 初心者向け(core i3 第7世代/メモリ4GB/SSD128GB)
¥13,500
5
Apple 2026 MacBook Neo A18 Proチップ搭載13インチノートブック:AIとApple Intelligenceのために設計、Liquid Retinaディスプレイ、8GBユニファイドメモリ、512GB SSDストレージ、1080p FaceTime HDカメラ、Touch ID - ブラッシュ
Apple 2026 MacBook Neo A18 Proチップ搭載13インチノートブック:AIとApple Intelligenceのために設計、Liquid Retinaディスプレイ、8GBユニファイドメモリ、512GB SSDストレージ、1080p FaceTime HDカメラ、Touch ID - ブラッシュ
¥137,800

Amazonのアソシエイトとして、ASCII.jpは適格販売により収入を得ています。

ASCII倶楽部

注目ニュース

  • 角川アスキー総合研究所

プレミアム実機レビュー

ピックアップ
1
KIOXIA(キオクシア) 旧東芝メモリ microSD 128GB UHS-I Class10 (最大読出速度100MB/s) Nintendo Switch動作確認済 国内サポート正規品 メーカー保証5年 KLMEA128G
KIOXIA(キオクシア) 旧東芝メモリ microSD 128GB UHS-I Class10 (最大読出速度100MB/s) Nintendo Switch動作確認済 国内サポート正規品 メーカー保証5年 KLMEA128G
¥2,670
2
ソニー ゲーミングイヤホン INZONE Buds:WF-G700N Fnatic監修/ワイヤレス / 低遅延2.4GHzワイヤレス接続 USBType-Cトランシーバー同梱/LE Audio対応/アクティブノイズキャンセリング/立体音響 / 最大約24時間バッテリー / 急速充電/マイク付き / PS5 スマホ PC Switch グラスパープル
ソニー ゲーミングイヤホン INZONE Buds:WF-G700N Fnatic監修/ワイヤレス / 低遅延2.4GHzワイヤレス接続 USBType-Cトランシーバー同梱/LE Audio対応/アクティブノイズキャンセリング/立体音響 / 最大約24時間バッテリー / 急速充電/マイク付き / PS5 スマホ PC Switch グラスパープル
¥20,800
3
Anker PowerLine III Flow USB-C & USB-C ケーブル Anker絡まないケーブル 240W 結束バンド付き USB PD対応 シリコン素材採用 iPhone 17 / 16 / 15 / Galaxy iPad Pro MacBook Pro/Air 各種対応 (1.8m ミッドナイトブラック)
Anker PowerLine III Flow USB-C & USB-C ケーブル Anker絡まないケーブル 240W 結束バンド付き USB PD対応 シリコン素材採用 iPhone 17 / 16 / 15 / Galaxy iPad Pro MacBook Pro/Air 各種対応 (1.8m ミッドナイトブラック)
¥1,890
4
Anker iPhone充電ケーブル PowerLine II ライトニングケーブル MFi認証 超高耐久 iPhone 14 / 14 Pro Max / 14 Plus / 13 / 13 Pro / 12 / 11 / X/XS/XR / 8 Plus 各種対応 (0.9m ホワイト)
Anker iPhone充電ケーブル PowerLine II ライトニングケーブル MFi認証 超高耐久 iPhone 14 / 14 Pro Max / 14 Plus / 13 / 13 Pro / 12 / 11 / X/XS/XR / 8 Plus 各種対応 (0.9m ホワイト)
¥990
5
Anker USB Type C ケーブル PowerLine USB-C & USB-A 3.0 ケーブル iPhone 17 / 16 / 15 /Xperia/Galaxy/LG/iPad Pro/MacBook その他 Android 等 USB-C機器対応 テレワーク リモート 在宅勤務 0.9m ホワイト
Anker USB Type C ケーブル PowerLine USB-C & USB-A 3.0 ケーブル iPhone 17 / 16 / 15 /Xperia/Galaxy/LG/iPad Pro/MacBook その他 Android 等 USB-C機器対応 テレワーク リモート 在宅勤務 0.9m ホワイト
¥740
6
KIOXIA(キオクシア)【日本製】USBフラッシュメモリ 32GB USB2.0 国内サポート正規品 KLU202A032GL
KIOXIA(キオクシア)【日本製】USBフラッシュメモリ 32GB USB2.0 国内サポート正規品 KLU202A032GL
¥1,616
7
バッファロー マウス 無線 ワイヤレス 5ボタン 【戻る/進むボタン搭載】 小型 軽量 節電モデル 最大584日使用可能 BlueLED ブラック BSMBW315BK
バッファロー マウス 無線 ワイヤレス 5ボタン 【戻る/進むボタン搭載】 小型 軽量 節電モデル 最大584日使用可能 BlueLED ブラック BSMBW315BK
¥1,040
8
【ブラザー純正】 ブラザー工業(Brother Industries) インクカートリッジ4色パック(エコパッケージ) LC411-4PK-E 対応型番:DCP-J926N、MFC-J904N、MFC-J739DN、MFC-J939DN 他
【ブラザー純正】 ブラザー工業(Brother Industries) インクカートリッジ4色パック(エコパッケージ) LC411-4PK-E 対応型番:DCP-J926N、MFC-J904N、MFC-J739DN、MFC-J939DN 他
¥4,536
9
エレコム 電源タップ 6個口 3m 雷ガード 個別スイッチ ほこりシャッター付 耐熱 PSE技術基準適合 ブラック T-K6A-2630BK
エレコム 電源タップ 6個口 3m 雷ガード 個別スイッチ ほこりシャッター付 耐熱 PSE技術基準適合 ブラック T-K6A-2630BK
¥1,899
10
KIOXIA(キオクシア)【日本製】SDカード 128GB SDXC UHS-I Class10 読出速度100MB/s 国内正規品 メーカー保証5年 KLNEA128G
KIOXIA(キオクシア)【日本製】SDカード 128GB SDXC UHS-I Class10 読出速度100MB/s 国内正規品 メーカー保証5年 KLNEA128G
¥2,680

Amazonのアソシエイトとして、ASCII.jpは適格販売により収入を得ています。

デジタル用語辞典

ASCII.jpメール デジタルMac/iPodマガジン