前回はWingetのPinningとPowerShell用モジュールを解説したが(「Wingetにおける安定版v1.14からプレビュー版v1.16での新機能」)、今回はこのプレビュー版で最大の新機能と言えるWinget Configurationについて解説する。なお、この機能は、マイクロソフトがプレビュー中の開発者向けアプリケーション「Dev Home」から利用できるようになっている。
Winget configurationとDSC
Wingetのconfigureオプション、あるいはWingetのConfiguration機能とは、Windows DSC(Desired State Configuration、PowerShellやDSCとも)を利用して、アプリケーションのインストールだけでなく、同時に環境設定などをするための仕組みである。
「Desired State Configuration」とは、プログラムコードではなく、設定結果を指定する。このとき、ユーザーが希望する状態「Desired State」を記述してシステムを構成するため、この名称がある。DSCではConfigurationと呼ばれる情報に望む状態を記述する。
従来、設定を自動化するには、PowerShellなどのコマンドを記述したプログラム(スクリプト)を記述する必要があった。しかし、プログラムコードによる設定は、特定マシン・特定環境での1回の利用では問題なくとも、さまざまなバージョンや環境、マシンで利用するためには、かなり頑強なエラー対策・処理が必要だった。こうしたスクリプトは簡単なものであっても、エラー処理のために開発コストが大きくなってしまうのが欠点だった。
DSUは、簡単に言えば、エラー処理組み込みの設定機能を実現する。もちろん、エラーがあったときに勝手に修復などはできないが、少なくともエラー処理を記述することからは解放される。
ただし、DSCで可能な設定は、DSCの「resources」が用意されているものに限られる。この「resources」というプログラムモジュールの中で必要なエラー処理などが行なわれる。
DSCには、「冪等性」(べきとうせい)があるとされる。冪等性(idempotence)とは、同じ操作を繰り返し適用しても同じ状態が得られることを意味する数学用語だが、コンピュータ関係でも基本的には同様だ。DSCでは、Configurationを繰り返し適用したとしても、初期状態に関わらず、同じ状態が得られるようになっている。
Winget Configuration機能は、Windows DSCを使うものだが、その記述は、PowerShellではなく、YAMLというデータ記述言語となる。YAML(ヤメル、YAML Ain't Markup Language)は、テキストでデータを記述する「人間が読むことができるデータシリアル化言語」である。
YAMLのVer.1.2以降は、JSONの上位互換になっていて、YAML 1.2を処理できるプログラムはJSONを処理することもできる。ただし、YAMLは、Pythonのようにインデントを使ってデータ構造を表すことが可能で、JSONよりは記述を簡略化できる。逆に、YAMLでは、インデントにタブは利用できず、行頭のスペースを変更しないようにしなければならない。
これまでDSCは、主にPowerShell/Windows PowerShellで利用していたが、Winget Configurationは、それとは異なる表現となる。意味的には、PowerShellのDSCと同じものだが、記述方法が異なる。ただし、Microsoftのブログの記述によれば、PowerShell DSC側で、Winget Configurationの機能を使ってソフトウェアのインストールを行うことは可能だという。
Winget Configurationを使う
Winget Configurationは、現状プレビュー段階であり、利用するには、プレビュー版Wingetと実験的機能の設定が必要になる。なお、Winget Configurationでは、システム設定を変更する可能性もあるため、単なる評価のためであれば、仮想環境やWindowsサンドボックスで実行させたほうが無難である。
まずは、プレビュー版(原稿執筆時点ではv 1.6.1573-preview)をインストールする(https://github.com/microsoft/winget-cli/releases/tag/v1.6.1573-preview)。Windows Sandboxから使う場合には、同時に「Microsoft.VCLibs.x64.14.00.Desktop」が必要になる(https://aka.ms/Microsoft.VCLibs.x64.14.00.Desktop.appx)。
ダウンロードしたら、Windows PowerShellから「Add-AppxPackage Microsoft.VCLibs.x64.14.00.Desktop.appx」としてインストールしおき、その後、同じく「Add-AppxPackage」コマンドでWingetプレビュー版を導入する。
コマンドラインで「winget settings」コマンドを実行し、Winget設定JSONファイルをJSONエディタ(標準状態ではメモ帳)で開く。JSONファイルを以下のリストのように編集し、ファイルを保存したら、「winget features」コマンドを実行して、ConfigurationがEnabledになっていることを確認する。
{
"experimentalFeatures": {
"configuration": true
}
}
winget configurationを動かすには、YAMLファイルを用意する。ここでは、サンプルとして提示されていたVisual Studio 2022(以下、VS2022)をインストールして、設定を行うYAMLファイルを一部書き換えて利用した。オリジナルは、以下のページの「WinGet構成ファイルの例」にある。
●WinGet 構成ファイルを作成する方法
https://learn.microsoft.com/ja-jp/windows/package-manager/configuration/create#example-winget-configuration-file
これは、Windowsの「開発者モード」を有効化し、VS2022コミュニティ版をインストール、設定するもの。
ただし、すでに稼働しているVisual Studio 2022からエクスポートした構成ファイル(.vsconfigファイル)が必要になる。エクスポートはVS2022をインストールしたマシンのVisual Studio Installerからする。
上記のページにあるサンプルでは、この.vsconfigファイルをYAMLファイルの1つ上のフォルダーに置いていたが、これを書き換えて同じフォルダーから読み込むようにしてある。最後から2番目の行がそれにあたる。なお、必要なDSCの「resource」は、PowerShell Galleryなどから自動的に読み込まれるようだ。
Visual Studioは、手動でインストールすると、最後に開発言語や対象システムなどの「ワークロード」の設定画面となる。
通常はここで必要なワークロードを手動で選択する必要がある。.vsconfigは、このワークロード設定をエクスポートしたもので、winget configurationは、これを使って、VS2022の設定を変更する。つまり、現在と同じVS2022開発環境を別のマシン上でも構築することができるわけだ。
Winget Configurationは、DSCを開発環境向けにアレンジしなおしたものといえる。サンプルで示したVS2022のDSC resource(Microsoft.VisualStudio.DSC)は、2ヵ月ほど前に作られたもの。Winget Configurationに合わせたのだろう。
DSCはWindows固有の用語だが、同様のコンセプトを持つConfigurationシステムはLinuxなどにもあり、Windowsだけが持つ特徴的な仕組みというわけでもない。逆にいうと開発環境向けにDSCを利用できるようにすることで、Linuxなどの他のプラットフォームと同等のものをWindowsでも提供するという意味もありそうだ。
この連載の記事
-
第459回
PC
WSL 2.4.4ではtar形式でのディストリビューションが配布でき、企業での利用が容易になってきた -
第458回
PC
Windows上でhostsファイルを活用する -
第457回
PC
IPv6アドレスは先頭を見ればどんな種類かわかる -
第456回
PC
あらためてIPv6基本のキ -
第455回
PC
Windowsで現在どのネットワークアダプタがインターネット接続に使われているかを調べる方法 -
第454回
PC
Windows 11 24H2では「デバイスの暗号化」の条件が変わり、より多くのPCでドライブが暗号化される -
第453回
PC
Windows 11 24H2の配布開始後もすぐにはやってこない Windows UpdateとSafeguard Holds -
第452回
PC
Windows 11 Ver.24H2が登場 Copilot+ PCとそうでないPCで実質Windowsが2つに分かれる -
第451回
PC
新しいWindowsサンドボックスではコマンドラインからの制御が可能に -
第450回
PC
ユニコードで文字数を数える方法 -
第449回
PC
WSLはプレビュー版でGUIでの設定が加わった! リリース2.3.xの新機能を見る - この連載の一覧へ