Windows Vista から、ファイルとレジストリの仮想化という機能が実装されている。
アプリケーションの仮想化の際にユーザーごとの設定を意識せずに持てるなどの利点があるようだが、今までの環境に慣れ親しんだ企業ユーザーなどにとっては管理コストの増大になっている。またユーザーに意識させず行われることと既存のプログラムが対応していない事などの要因で、この機能は様々な場面で問題を起こしていることがある。まさに「小さな親切大きなお世話」的機能になっている。
機能の内容
権限を有しないものが該当するフォルダやレジストリに対して書き込みを行うと、自動的にリダイレクトされ別の場所に書き込む機能である。管理者権限を有していてもユーザーアカウント制御(UAC)がONになっていて、さらに昇格していないとこの機能が働く。(アプリケーションマニフェストで指定されている場合は除かれる模様)
書き込もうとした場所 | 仮想化によって実際に書き込まれる場所 |
---|---|
%programfiles% (初期値:C:\Program Files) |
%LOCALAPPDATA%\VirtualStore\Program Files |
%systemroot% (初期値:C:\Windows) |
%LOCALAPPDATA%\VirtualStore\Windows |
%programdata% (初期値:C:\ProgramData) |
%LOCALAPPDATA%\VirtualStore\ProgramData |
HKEY_LOCAL_MACHINE\SOFTWARE | HKCU\Software\Classes\VirtualStore\Machine\Software |
※参考URLによると%systemroot%も仮想化の対象と取れるが、実験したところ仮想化されていない模様。
無効化の方法(下記の2通りの方法のいずれかで)
- コントロールパネルからの無効化
コントロール パネル\システムとセキュリティ\管理ツール\ローカルセキュリティーポリシー
上記をクリックするとMicrosoft Managiment Console(MMC)が起動する。
下記の場所の設定を変更する。
コンピュータの構成/Windowsの設定/セキュリティの設定/ローカルポリシー/セキュリティーオプション
「ユーザーアカウント制御:各ユーザーの場所へのファイルまたはレジストリの書き込みエラーを仮想化する」
を有効から無効に変更
※ローカルセキュリティーポリシーのコマンドはgpedit.msc - レジストリからの無効化
HKEY_LOCAL_MACHINE\SOFTWARE\Microsoft\Windows\CurrentVersion\Policies\System
EnableVirtualization の値を1から0に書き換える
■参考
- Windows Vista または Windows 7 のファイルおよびレジストリの仮想化に関する一般的な問題
http://support.microsoft.com/kb/927387/ja - ユーザー アカウント制御
http://technet.microsoft.com/ja-jp/library/cc772207(WS.10).aspx
以下のコメントは、その投稿者が所有するものでサイト管理者はコメントに関する責任を負いません。