今回は Dynamics 365 Business Central のコンテナをHyper-V仮想マシン上に展開する方法を説明します。前回の記事ではHyper-Vの仮想マシンにDocker Desktopをインストールする方法を書きました。前回の記事のニーズが100だとすると今回の記事のニーズは3くらいですかね。まだまだ日本では知名度が低い製品なので仕方ないです。本当にやりたいのはDockerDesktopなしでBCのコンテナ作ることですが、それは次回に。
前提:Docker DesktopをインストールしたHyper-V仮想マシン。Windowsコンテナモードにスイッチ済。
前回の記事で少し書きましたが物理マシンにDockerをインストールすると使っている内に次第に重くなって削除が面倒だからです。仮想マシンなら検証が終わったらコンテナ捨てて仮想マシンのチェックポイントでDockerインストール済の時点まで戻れるからです。
ちなみに仮想マシンでなくても同じ手順でBCコンテナは作れます。
手順
Docker Desktop起動後、Windowsコンテナモードになっていることを確認する。下図のように「Switch to Linux container」と表示されていればOK。(ここで選択しないこと。選択するとLinuxコンテナモードに切り替わってしまう。)
Microsoft 公式の手順に沿って進める。(ただし、前半の手順は失敗する。)
Running a Container-Based Development Environment – Business Central | Microsoft Docs
コマンドプロンプトを管理者モードで起動する。
「はい」を選択。
Docsの「Using Docker commands」セクションに「以下のPowerShellコマンドを打て。ただしバージョンは適宜修正のこと。」と記述されている。
Windowsのバージョンを確認する。この仮想マシンにはWindows10 21H2の19044.1415がインストールされている。なので、「19041.329」の部分を「19044.1415」に打ち換えればよいハズ・・・だが10.0の部分が表示されていないので一抹の不安を覚える。(多分大丈夫だとは思うのだが)
と思ったら意外なところに答えがあった。コマンドプロンプトの一番上に「Windows Version 10.0.19044.1415」と書いてある。
ということで10.0.19044.1415に置き換えてコマンド実行。
失敗する。「10.0.19044.1415を対象とするマニフェストがない」と言われている。
この仮想マシンにインストールしたOSは以下のバージョン。これを手掛かりにして、、
こんな感じでググるとOSのビルド番号がヒットする。
19041.1415、 19042.1415、 19043.1415、 19044.1415、 は1つのまとまりになっている。この場合、Manufestは最も若い番号で作成されているらしい。
ということで10.0.19041.1415で実行する。
マニフェストが見つかり、処理が進み始める。
無事に完了。Docker DesktopでImagesタブを見ると指定したビルド番号のイメージが存在することがわかる。
Docsに戻って続きを見ると、「以下のコマンドを実行せよ、ただしバージョンは適宜修正のこと」とある。
docker run -e accept_eula=Y -m 4G -e artifacturl=https://bcartifacts.azureedge.net/sandbox/16.3.14085.14363/us mcr.microsoft.com/businesscentral:10.0.19041.329
OSビルド番号を修正してコマンド実行。
エラーになる。。いろいろ調べたが原因は分からず。。
ということで、Docsに紹介されている2つ目の方法、BCContainerHelperを試す。その前に不要なコンテナを削除する。Docker Desktopでコンテナタブを確認すると見覚えのないコンテナができている。これを削除する。
削除する。
コンテナがなくなった。
イメージはそのまま残しておく。
Docs文書に戻り、Using the BCContainerHelper PowerShell moduleのセクションを参照すると、 以下のコマンドを実行して BCContainerHelperをインストールする、と記述されている。これをインストールすると簡単にBCコンテナが作れる。
Install-module BCContainerHelper -force
Yesを選択。
インストールが完了した。
インストールしたら以下のコマンドを打って、BCContainerHelperのコマンドを照会する、とDocsに書いてあるが、、
Write-BCContainerHelperWelcomeText
エラーになる。
これは実行ポリシー設定が不足しているため。以下のコマンドを打つ。
get-ExecutionPolicy -list
すると実行ポリシーが照会できる。5行ともUndefinedになっている。
以下のコマンドを打って実行ポリシーを変更する。
set-ExecutionPolicy -ExecutionPlicy Bypass -Scope CurrentUser
改めて以下のコマンドを打って変更されたか確認する。
get-ExecutionPolicy -list
再度、以下のコマンドを打って、BCContainerHelperのコマンドをリストする。
Write-BCContainerHelperWelcomeText
コマンド群が表示された。OK
Docsの説明に従って続ける。以下のコマンドを入力せよ、とのこと。DocsからKぴーしてそのままPowerShellのコマンドラインに貼り付ければOK
$artifactUrl = Get-BcArtifactUrl -type sandbox -country us -select Latest
New-BCContainer -accept_eula -containerName mysandbox -artifactUrl $artifactUrl
クレデンシャルを求められる。この仮想マシンにサインインしているユーザーIDとPasswordを入力する。
コンテナ作成処理が走る。
完了するとデスクトップにショートカットが3つ作られる。
IEのアイコンのショートカットをクリックする。
Edgeが起動し、BCが表示された。成功!
Docker DesktopのImageを確認する。先にダウンロードしたイメージがInUseになっている。
BCのコンテナが作られていることがわかる。
仮想マインを停止し、ここでチェックポイントを取っておくとよい。いつでもここに立ち返れる。(最初に取ったほうがよかったかもw)
チェックポイントが生成された。
一つ目の方法のエラーを取り除けなかったのは残念ですが、BCContainerHelperを使うと非常に簡単にBCコンテナが作成できることが分かったと思います。
次回はDocker DesktopなしでBCコンテナを作成する方法を説明します。