WSL のファイルのアクセス許可

このページでは、特に NT ファイル システム上の Windows 内のリソースにアクセスした際に、Linux 用 Windows サブシステム全体で Linux のファイルのアクセス許可がどのように解釈されるかについて詳しく説明します。 このドキュメントでは、Linux ファイル システムのアクセス許可の構造umask コマンドについて基本的な知識があることを前提としています。

WSL から Windows ファイルにアクセスした際、ファイルのアクセス許可は Windows のアクセス許可から計算されるか、WSL によってファイルに追加されたメタデータから読み取られます。 このメタデータは、既定では有効になっていません。

Windows ファイルの WSL メタデータ

WSL のマウント オプションとしてメタデータが有効な場合、Windows NT ファイルの拡張属性を追加および解釈することで、Linux ファイル システムのアクセス許可を提供することができます。

WSL では、次の 4 つの NTFS 拡張属性を追加できます。

属性名 説明
$LXUID ユーザー所有者 ID
$LXGID グループ所有者 ID
$LXMOD ファイル モード (ファイル システムのアクセス許可の 8 進数と種類。例: 0777)
$LXDEV デバイス (デバイス ファイルの場合)

さらに、通常のファイルやディレクトリではないファイル (例: シンボリック リンク、FIFO、ブロック デバイス、UNIX ソケット、文字デバイス) には、NTFS 再解析ポイントもあります。 これにより、特定のディレクトリ内のファイルの種類を、その拡張属性を照会しなくても、はるかにすばやく特定できます。

ファイル アクセスのシナリオ

以下は、Linux 用 Windows サブシステムを使用してさまざまな方法でファイルにアクセスするときに、アクセス許可がどのように特定されるかを説明したものです。

Linux から Windows ドライブ ファイル システム (DrvFS) のファイルにアクセスする

これらのシナリオは、WSL から (ほとんどの場合 /mnt/c 経由で) Windows ファイルにアクセスする場合に生じるものです。

既存の Windows ファイルからファイルのアクセス許可を読み取る

結果は、ファイルに既存のメタデータがあるかどうかによって異なります。

DrvFS ファイルにメタデータがない場合 (既定)

ファイルにメタデータが関連付けられていない場合は、Windows ユーザーの有効なアクセス許可が読み取りビット、書き込みビット、または実行ビットに変換され、これらが "ユーザー"、"グループ"、および "その他" に対して同じ値として設定されます。 たとえば、Windows ユーザー アカウントにファイルの読み取りおよび実行アクセス権がある一方で書き込みアクセス権がない場合、これは "ユーザー"、"グループ"、および "その他" に対して r-x と表示されます。 Windows でファイルに "読み取り専用" 属性が設定されている場合、Linux で書き込みアクセス権は付与されません。

ファイルにメタデータがある場合

ファイルにメタデータが存在する場合は、Windows ユーザーの有効なアクセス許可を変換する代わりに、これらのメタデータ値がそのまま使用されます。

chmod を使用して既存の Windows ファイルのファイル アクセス許可を変更する

結果は、ファイルに既存のメタデータがあるかどうかによって異なります。

chmod ファイルにメタデータがない場合 (既定)

chmod の効果は 1 つだけです。ファイルのすべての書き込み属性を削除すると、Windows ファイルに "読み取り専用" 属性が設定されます。これは、Linux の SMB (Server Message Block) クライアントである CIFS (Common Internet File System) と同じ動作であるためです。

chmod ファイルにメタデータがある場合

chmod を使用すると、ファイルの既存のメタデータに応じて、メタデータを変更または追加できます。

たとえメタデータに示されていても、Windows 上で与えられている以上のアクセス権を自分に与えることはできないことに注意してください。 たとえば、chmod 777 を使用してファイルに対する書き込みアクセス許可があることを示すメタデータを設定することはできますが、そのファイルへのアクセスを試みたときにそのファイルに書き込むことはできません。 これは、相互運用性により、Windows ファイルに対するすべての読み取りまたは書き込みコマンドが Windows ユーザーのアクセス許可を介してルーティングされるためです。

DriveFS にファイルを作成する

結果は、メタデータが有効になっているかどうかによって異なります。

メタデータが有効になっていない場合 (既定)

新しく作成されたファイルの Windows アクセス許可は、特定のセキュリティ記述子なしで Windows でファイルを作成した場合と同じく、親のアクセス許可から継承されます。

メタデータが有効になっている場合

ファイルのアクセス許可ビットは Linux umask に従うように設定され、ファイルと共にメタデータが保存されます。

どの Linux ユーザーおよび Linux グループがファイルを所有しているか

結果は、ファイルに既存のメタデータがあるかどうかによって異なります。

ユーザー ファイルにメタデータがない場合 (既定)

既定のシナリオでは、Windows ドライブを自動マウントするときに、任意のファイルのユーザー ID (UID) が WSL ユーザーのユーザー ID に設定され、グループ ID (GID) が WSL ユーザーのプリンシパル グループ ID に設定されるように指定します。

ユーザー ファイルにメタデータがある場合

メタデータに指定されている UID および GID は、ファイルのユーザー所有者およびグループ所有者として適用されます。

\\wsl$ を使用して Windows から Linux ファイルにアクセスする

\\wsl$ 経由で Linux ファイルにアクセスする場合は、WSL ディストリビューションの既定のユーザーが使用されます。 したがって、Linux ファイルにアクセスするすべての Windows アプリに、既定のユーザーと同じアクセス許可が付与されます。

新しいファイルを作成する

Windows から WSL ディストリビューション内に新しいファイルを作成する場合は、既定の umask が適用されます。 既定の umask は 022 です。つまり、"グループ" と "その他" に対する書き込みアクセス許可を除くすべてのアクセス許可が許可されます。

Linux から Linux ルート ファイル システム内のファイルにアクセスする

Linux ルート ファイル システム内で作成、変更、またはアクセスされるすべてのファイルには、新しく作成されたファイルに umask を適用するといった標準の Linux 規則が適用されます。

ファイルのアクセス許可を構成する

wsl.conf 内でマウント オプションを使用して、Windows ドライブ内のファイルのアクセス許可を構成できます。 マウント オプションを使用すると、umaskdmask、および fmask のアクセス許可マスクを設定できます。 umask はすべてのファイルに適用され、dmask はディレクトリにのみ適用されます。fmask はファイルにのみ適用されます。 これらのアクセス許可のマスクは、ファイルに適用されるときに論理 OR 演算が適用されます。たとえば、umask の値が 023 で、fmask の値が 022 の場合、ファイルに対する結果のアクセス許可マスクは 023 になります。

詳細情報: wsl.conf を使用したディストリビューションごとの構成オプション