台風19号が三連休最後の日に通り過ぎた後、ずいぶん涼しくなってきました。そろそろ冬の準備をしないといけませんね。今が一番快適に過ごせる季節なので、存分に楽しみたいところでもあります。
台風19号が三連休最後の日に通り過ぎた後、ずいぶん涼しくなってきました。そろそろ冬の準備をしないといけませんね。今が一番快適に過ごせる季節なので、存分に楽しみたいところでもあります。
インストーラの話題をしたところなので、WiX ToolsetでWindows Installer(.msi)を作るためのMyテンプレートなどを一つ。
ディレクトリ構成は次のような感じで。
WiX Toolsetをダウンロードしてパスを通し、上のディレクトリ構成でbuild.batを実行するとoutput/DISK1の中にインストーラが出力されます。
ビルドするためのバッチファイルです。 出力ディレクトリの作成、wxsのコンパイル、wixobjのリンクを行います。
mkdir output mkdir output\DISK1 candle hoge.wxs -o output/hoge.wixobj candle MyExitDialog.wxs -o output/MyExitDialog.wixobj candle MyInstallDirDlg.wxs -o output/MyInstallDirDlg.wixobj candle MyUI_InstallDir.wxs -o output/MyUI_InstallDir.wixobj light output/hoge.wixobj ^ output/MyExitDialog.wixobj ^ output/MyInstallDirDlg.wixobj ^ output/MyUI_InstallDir.wixobj ^ -ext WixUIExtension ^ -ext WixUtilExtension ^ -o output/DISK1/hoge.msi ^ -pdbout output/hoge.wixpdb ^ -cultures:ja-jp
メインとなるソースファイルです。
{YOUR-GUID}のところは全て個別のGUIDを生成して置き換えてください。
ファイル先頭ではプリプロセッサ変数を定義しています。この変数の値によって、生成されるmsiが色々変わるようになってます。
<!– Files –>と書いてある部分はheatで生成しても良いと思います。
<?xml version="1.0" encoding="utf-8"?> <?define ProductName = "製品名" ?> <?define Manufacturer = "製造者" ?> <?define SrcDir = "$(sys.CURRENTDIR)src\" ?> <?define MainExeFileName = "hoge.exe" ?> <?define ReadmeFileName = "readme.txt" ?> <?define UseCustomUI = "yes" ?> <?define AppRegKey = "Software\$(var.Manufacturer)\$(var.ProductName)" ?> <?define Compressed = "no" ?> <Wix xmlns="http://schemas.microsoft.com/wix/2006/wi"> <Product Id="{YOUR-GUID}" UpgradeCode="{YOUR-GUID}" Name="$(var.ProductName)" Manufacturer="$(var.Manufacturer)" Version="1.0.0.0" Language="1041" Codepage="932"> <Package InstallerVersion="200" Compressed="$(var.Compressed)" /> <?if $(var.Compressed)="yes" ?> <MediaTemplate EmbedCab="yes" /> <?else ?> <Media Id="1" DiskPrompt="DISK1" /> <Property Id="DiskPrompt" Value="インストールディスク [1]" /> <?endif ?> <Icon Id="MainIcon" SourceFile="$(var.SrcDir)$(var.MainExeFileName)" /> <Property Id="ARPPRODUCTICON" Value="MainIcon" /> <!-- Directory Structure --> <Directory Id="TARGETDIR" Name="SourceDir"> <!-- INSTALLDIR --> <Directory Id="ProgramFilesFolder" Name="ProgramFiles"> <Directory Id="ProgramFilesManufacturer" Name="$(var.Manufacturer)"> <Directory Id="INSTALLDIR" Name="$(var.ProductName)"> </Directory> </Directory> </Directory> <!-- Start Menu --> <Directory Id="ProgramMenuFolder" Name="Programs"> <Directory Id="AppStartMenuDir" Name="$(var.Manufacturer) $(var.ProductName)"> </Directory> </Directory> <!-- Desktop --> <Directory Id="DesktopFolder" Name="Desktop"> </Directory> </Directory> <!-- Feature --> <Feature Id="EssentialFeature" Level="1"> <ComponentGroupRef Id="EssentialFiles" /> <ComponentRef Id="EssentialRegistries" /> <ComponentRef Id="EssentialShortcuts" /> <ComponentRef Id="EssentialDesktopShortcut" /> </Feature> <!-- Files --> <ComponentGroup Id="EssentialFiles" Directory="INSTALLDIR"> <Component Id="file0001" Guid="{YOUR-GUID}"> <File Id="file0001" KeyPath="yes" Source="$(var.SrcDir)$(var.MainExeFileName)" /> </Component> <Component Id="file0002" Guid="{YOUR-GUID}"> <File Id="file0002" KeyPath="yes" Source="$(var.SrcDir)hoge.dat" /> </Component> <Component Id="file0003" Guid="{YOUR-GUID}"> <File Id="file0003" KeyPath="yes" Source="$(var.SrcDir)$(var.ReadmeFileName)" /> </Component> </ComponentGroup> <!-- Shortcuts --> <DirectoryRef Id="AppStartMenuDir"> <Component Id="EssentialShortcuts" Guid="{YOUR-GUID}"> <RegistryValue Root="HKCU" Key="$(var.AppRegKey)" Name="InstalledStartMenuShortcut" Type="integer" Value="1" KeyPath="yes" /> <RemoveFolder Id="AppStartMenuDir" On="uninstall" /> <Shortcut Id="startMenuShortcut0001" Name="$(var.ProductName)" Target="[INSTALLDIR]$(var.MainExeFileName)" WorkingDirectory="INSTALLDIR" /> </Component> </DirectoryRef> <Property Id="INSTALLDESKTOPSHORTCUT" Value="1" /> <DirectoryRef Id="DesktopFolder"> <Component Id="EssentialDesktopShortcut" Guid="{YOUR-GUID}"> <Condition>INSTALLDESKTOPSHORTCUT</Condition> <RegistryValue Root="HKCU" Key="$(var.AppRegKey)" Name="InstalledDesktopShortcut" Type="integer" Value="1" KeyPath="yes" /> <Shortcut Id="desktopShortcut0001" Name="$(var.ProductName)" Target="[INSTALLDIR]$(var.MainExeFileName)" WorkingDirectory="INSTALLDIR" /> </Component> </DirectoryRef> <!-- Registries --> <DirectoryRef Id="INSTALLDIR"> <Component Id="EssentialRegistries" Guid="{YOUR-GUID}"> <RegistryKey Root="HKCU" Key="$(var.AppRegKey)" ForceCreateOnInstall="yes" ForceDeleteOnUninstall="yes"> <RegistryValue Type="string" Name="InstalledPath" Value="[INSTALLDIR]" KeyPath="yes" /> </RegistryKey> </Component> </DirectoryRef> <!-- User Interface --> <!-- UI: Install Directory --> <Property Id="WIXUI_INSTALLDIR" Value="INSTALLDIR" /> <!-- UI: Bitmap --> <WixVariable Id="WixUIBannerBmp" Value="banner.bmp" /><!-- 493x58 --> <WixVariable Id="WixUIDialogBmp" Value="dialog.bmp" /><!-- 493x312 --> <?if $(var.UseCustomUI) = "yes" ?> <UIRef Id="MyUI_InstallDir" /> <!-- UI: Run application after installed (for MyUI_InstallDir) --> <?if $(var.MainExeFileName) And $(var.MainExeFileName)!="" ?> <Property Id="MYUI_EXITDIALOGOPTIONALCHECKBOXTEXT" Value="プログラムを実行する" /> <Property Id="MYUI_EXITDIALOGOPTIONALCHECKBOX" Value="1" /> <CustomAction Id="LaunchApplication" Directory="INSTALLDIR" ExeCommand="[INSTALLDIR]$(var.MainExeFileName)" Return="asyncNoWait" /> <UI> <Publish Dialog="MyExitDialog" Control="Finish" Event="DoAction" Value="LaunchApplication">MYUI_EXITDIALOGOPTIONALCHECKBOX = 1 and NOT Installed</Publish> </UI> <?endif ?> <?if $(var.ReadmeFileName) And $(var.ReadmeFileName)!="" ?> <Property Id="MYUI_EXITDIALOGOPTIONALCHECKBOXTEXT2" Value="Readmeを開く" /> <Property Id="MYUI_EXITDIALOGOPTIONALCHECKBOX2" Value="1" /> <Property Id="WixShellExecTarget" Value="[INSTALLDIR]$(var.ReadmeFileName)" /> <CustomAction Id="LaunchReadme" BinaryKey="WixCA" DllEntry="WixShellExec" Impersonate="yes" /> <UI> <Publish Dialog="MyExitDialog" Control="Finish" Event="DoAction" Value="LaunchReadme">MYUI_EXITDIALOGOPTIONALCHECKBOX2 = 1 and NOT Installed</Publish> </UI> <?endif ?> <!-- UI: Skip license (for MyUI_InstallDir) --> <UI> <Publish Dialog="WelcomeDlg" Control="Next" Event="NewDialog" Value="MyInstallDirDlg">1</Publish> <Publish Dialog="MyInstallDirDlg" Control="Back" Event="NewDialog" Value="WelcomeDlg">1</Publish> </UI> <?else ?> <UIRef Id="WixUI_InstallDir" /> <!-- UI: Run application after installed (for WixUI_InstallDir) --> <Property Id="WIXUI_EXITDIALOGOPTIONALCHECKBOXTEXT" Value="プログラムを実行する" /> <Property Id="WIXUI_EXITDIALOGOPTIONALCHECKBOX" Value="1" /> <CustomAction Id="LaunchApplication" Directory="INSTALLDIR" ExeCommand="[INSTALLDIR]$(var.MainExeFileName)" Return="asyncNoWait" /> <UI> <Publish Dialog="ExitDialog" Control="Finish" Event="DoAction" Value="LaunchApplication">WIXUI_EXITDIALOGOPTIONALCHECKBOX = 1 and NOT Installed</Publish> </UI> <!-- UI: Skip license (for WixUI_InstallDir) --> <UI> <Publish Dialog="WelcomeDlg" Control="Next" Event="NewDialog" Value="InstallDirDlg">1</Publish> <Publish Dialog="InstallDirDlg" Control="Back" Event="NewDialog" Value="WelcomeDlg">1</Publish> </UI> <?endif ?> </Product> </Wix>
インストール先を指定するダイアログを定義するファイルです。
WiXのソースに含まれているファイル(src/ext/UIExtension/InstallDirDlg.wxs)をコピーして一部を改編しました。改編点は次の通りです。
<?xml version="1.0" encoding="UTF-8"?> <Wix xmlns="http://schemas.microsoft.com/wix/2006/wi"> <Fragment> <UI> <Dialog Id="MyInstallDirDlg" Width="370" Height="270" Title="!(loc.InstallDirDlg_Title)"> <Control Id="Next" Type="PushButton" X="236" Y="243" Width="56" Height="17" Default="yes" Text="!(loc.WixUINext)" /> <Control Id="Back" Type="PushButton" X="180" Y="243" Width="56" Height="17" Text="!(loc.WixUIBack)" /> <Control Id="Cancel" Type="PushButton" X="304" Y="243" Width="56" Height="17" Cancel="yes" Text="!(loc.WixUICancel)"> <Publish Event="SpawnDialog" Value="CancelDlg">1</Publish> </Control> <Control Id="Description" Type="Text" X="25" Y="23" Width="280" Height="15" Transparent="yes" NoPrefix="yes" Text="!(loc.InstallDirDlgDescription)" /> <Control Id="Title" Type="Text" X="15" Y="6" Width="200" Height="15" Transparent="yes" NoPrefix="yes" Text="!(loc.InstallDirDlgTitle)" /> <Control Id="BannerBitmap" Type="Bitmap" X="0" Y="0" Width="370" Height="44" TabSkip="no" Text="!(loc.InstallDirDlgBannerBitmap)" /> <Control Id="BannerLine" Type="Line" X="0" Y="44" Width="370" Height="0" /> <Control Id="BottomLine" Type="Line" X="0" Y="234" Width="370" Height="0" /> <Control Id="FolderLabel" Type="Text" X="20" Y="60" Width="290" Height="30" NoPrefix="yes" Text="!(loc.InstallDirDlgFolderLabel)" /> <Control Id="Folder" Type="PathEdit" X="20" Y="100" Width="320" Height="18" Property="WIXUI_INSTALLDIR" Indirect="yes" /> <Control Id="ChangeFolder" Type="PushButton" X="20" Y="120" Width="56" Height="17" Text="!(loc.InstallDirDlgChange)" /> <!-- Begin MyUI --> <Control Id="DesktopShortcutCheckBox" Type="CheckBox" X="20" Y="160" Width="290" Height="17" Property="INSTALLDESKTOPSHORTCUT" CheckBoxValue="1" Text="デスクトップにショートカットを作成する。" /> <!-- End MyUI --> </Dialog> </UI> </Fragment> </Wix>
インストールが終了したときに表示するダイアログを定義するファイルです。
WiXのソースに含まれているファイル(src/ext/UIExtension/ExitDialog.wxs)をコピーして一部を改編しました。改編点は次の通りです。
<?xml version="1.0" encoding="UTF-8"?> <Wix xmlns="http://schemas.microsoft.com/wix/2006/wi"> <Fragment> <UI> <Dialog Id="MyExitDialog" Width="370" Height="270" Title="!(loc.ExitDialog_Title)"> <Control Id="Finish" Type="PushButton" X="236" Y="243" Width="56" Height="17" Default="yes" Cancel="yes" Text="!(loc.WixUIFinish)" /> <Control Id="Cancel" Type="PushButton" X="304" Y="243" Width="56" Height="17" Disabled="yes" Text="!(loc.WixUICancel)" /> <Control Id="Bitmap" Type="Bitmap" X="0" Y="0" Width="370" Height="234" TabSkip="no" Text="!(loc.ExitDialogBitmap)" /> <Control Id="Back" Type="PushButton" X="180" Y="243" Width="56" Height="17" Disabled="yes" Text="!(loc.WixUIBack)" /> <Control Id="BottomLine" Type="Line" X="0" Y="234" Width="370" Height="0" /> <Control Id="Description" Type="Text" X="135" Y="70" Width="220" Height="40" Transparent="yes" NoPrefix="yes" Text="!(loc.ExitDialogDescription)" /> <Control Id="Title" Type="Text" X="135" Y="20" Width="220" Height="60" Transparent="yes" NoPrefix="yes" Text="!(loc.ExitDialogTitle)" /> <!-- Begin MyUI --> <Control Id="OptionalText" Type="Text" X="135" Y="110" Width="220" Height="80" Transparent="yes" NoPrefix="yes" Hidden="yes" Text="[MYUI_EXITDIALOGOPTIONALTEXT]"> <Condition Action="show">MYUI_EXITDIALOGOPTIONALTEXT AND NOT Installed</Condition> </Control> <Control Id="OptionalCheckBox" Type="CheckBox" X="150" Y="150" Width="10" Height="9" Hidden="yes" Property="MYUI_EXITDIALOGOPTIONALCHECKBOX" CheckBoxValue="1"> <Condition Action="show">MYUI_EXITDIALOGOPTIONALCHECKBOXTEXT AND NOT Installed</Condition> </Control> <Control Id="OptionalCheckBoxText" Type="Text" X="165" Y="150" Width="200" Height="13" Transparent="yes" Hidden="yes" Text="[MYUI_EXITDIALOGOPTIONALCHECKBOXTEXT]"> <Condition Action="show">MYUI_EXITDIALOGOPTIONALCHECKBOXTEXT AND NOT Installed</Condition> </Control> <Control Id="OptionalCheckBox2" Type="CheckBox" X="150" Y="180" Width="10" Height="9" Hidden="yes" Property="MYUI_EXITDIALOGOPTIONALCHECKBOX2" CheckBoxValue="1"> <Condition Action="show">MYUI_EXITDIALOGOPTIONALCHECKBOXTEXT2 AND NOT Installed</Condition> </Control> <Control Id="OptionalCheckText2" Type="Text" X="165" Y="180" Width="200" Height="13" Transparent="yes" Hidden="yes" Text="[MYUI_EXITDIALOGOPTIONALCHECKBOXTEXT2]"> <Condition Action="show">MYUI_EXITDIALOGOPTIONALCHECKBOXTEXT2 AND NOT Installed</Condition> </Control> <!-- End MyUI --> </Dialog> <InstallUISequence> <Show Dialog="MyExitDialog" OnExit="success" Overridable="yes" /> </InstallUISequence> <AdminUISequence> <Show Dialog="MyExitDialog" OnExit="success" Overridable="yes" /> </AdminUISequence> </UI> </Fragment> </Wix>
UIの流れを定義するファイルです。
WiXのソースに含まれているファイル(src/ext/UIExtension/WixUI_InstallDir.wxs)をコピーして一部を改編しました。上で改編したダイアログを使うように、一部のダイアログIdにMyを付加しました。
<?xml version="1.0" encoding="UTF-8"?> <Wix xmlns="http://schemas.microsoft.com/wix/2006/wi"> <Fragment> <UI Id="MyUI_InstallDir"> <TextStyle Id="WixUI_Font_Normal" FaceName="Tahoma" Size="8" /> <TextStyle Id="WixUI_Font_Bigger" FaceName="Tahoma" Size="12" /> <TextStyle Id="WixUI_Font_Title" FaceName="Tahoma" Size="9" Bold="yes" /> <Property Id="DefaultUIFont" Value="WixUI_Font_Normal" /> <Property Id="WixUI_Mode" Value="InstallDir" /> <DialogRef Id="BrowseDlg" /> <DialogRef Id="DiskCostDlg" /> <DialogRef Id="ErrorDlg" /> <DialogRef Id="FatalError" /> <DialogRef Id="FilesInUse" /> <DialogRef Id="MsiRMFilesInUse" /> <DialogRef Id="PrepareDlg" /> <DialogRef Id="ProgressDlg" /> <DialogRef Id="ResumeDlg" /> <DialogRef Id="UserExit" /> <Publish Dialog="BrowseDlg" Control="OK" Event="DoAction" Value="WixUIValidatePath" Order="3">1</Publish> <Publish Dialog="BrowseDlg" Control="OK" Event="SpawnDialog" Value="InvalidDirDlg" Order="4"><![CDATA[WIXUI_INSTALLDIR_VALID<>"1"]]></Publish> <Publish Dialog="MyExitDialog" Control="Finish" Event="EndDialog" Value="Return" Order="999">1</Publish> <Publish Dialog="WelcomeDlg" Control="Next" Event="NewDialog" Value="LicenseAgreementDlg">NOT Installed</Publish> <Publish Dialog="WelcomeDlg" Control="Next" Event="NewDialog" Value="VerifyReadyDlg">Installed AND PATCH</Publish> <Publish Dialog="LicenseAgreementDlg" Control="Back" Event="NewDialog" Value="WelcomeDlg">1</Publish> <Publish Dialog="LicenseAgreementDlg" Control="Next" Event="NewDialog" Value="MyInstallDirDlg">LicenseAccepted = "1"</Publish> <Publish Dialog="MyInstallDirDlg" Control="Back" Event="NewDialog" Value="LicenseAgreementDlg">1</Publish> <Publish Dialog="MyInstallDirDlg" Control="Next" Event="SetTargetPath" Value="[WIXUI_INSTALLDIR]" Order="1">1</Publish> <Publish Dialog="MyInstallDirDlg" Control="Next" Event="DoAction" Value="WixUIValidatePath" Order="2">NOT WIXUI_DONTVALIDATEPATH</Publish> <Publish Dialog="MyInstallDirDlg" Control="Next" Event="SpawnDialog" Value="InvalidDirDlg" Order="3"><![CDATA[NOT WIXUI_DONTVALIDATEPATH AND WIXUI_INSTALLDIR_VALID<>"1"]]></Publish> <Publish Dialog="MyInstallDirDlg" Control="Next" Event="NewDialog" Value="VerifyReadyDlg" Order="4">WIXUI_DONTVALIDATEPATH OR WIXUI_INSTALLDIR_VALID="1"</Publish> <Publish Dialog="MyInstallDirDlg" Control="ChangeFolder" Property="_BrowseProperty" Value="[WIXUI_INSTALLDIR]" Order="1">1</Publish> <Publish Dialog="MyInstallDirDlg" Control="ChangeFolder" Event="SpawnDialog" Value="BrowseDlg" Order="2">1</Publish> <Publish Dialog="VerifyReadyDlg" Control="Back" Event="NewDialog" Value="MyInstallDirDlg" Order="1">NOT Installed</Publish> <Publish Dialog="VerifyReadyDlg" Control="Back" Event="NewDialog" Value="MaintenanceTypeDlg" Order="2">Installed AND NOT PATCH</Publish> <Publish Dialog="VerifyReadyDlg" Control="Back" Event="NewDialog" Value="WelcomeDlg" Order="2">Installed AND PATCH</Publish> <Publish Dialog="MaintenanceWelcomeDlg" Control="Next" Event="NewDialog" Value="MaintenanceTypeDlg">1</Publish> <Publish Dialog="MaintenanceTypeDlg" Control="RepairButton" Event="NewDialog" Value="VerifyReadyDlg">1</Publish> <Publish Dialog="MaintenanceTypeDlg" Control="RemoveButton" Event="NewDialog" Value="VerifyReadyDlg">1</Publish> <Publish Dialog="MaintenanceTypeDlg" Control="Back" Event="NewDialog" Value="MaintenanceWelcomeDlg">1</Publish> <Property Id="ARPNOMODIFY" Value="1" /> </UI> <UIRef Id="WixUI_Common" /> </Fragment> </Wix>
ソース一式は github/simple_wix_template に置いてあります。
InstallShieldで作ったインストーラが信じられないくらい遅いので調べたところ、どうもセキュリティ更新プログラム KB2918614 に問題があるようなのです。
作ったインストーラはDVD-ROMから4GBくらいインストールするのですが、インストールを開始してすぐ、準備段階でプログレスバーが止まったまま10分程度まったく動かなくなります。それを過ぎるとファイルのコピーが始まり、最終的には正常にインストールが完了するのですが、以前はこんなこと起きなかったのにどうなっているんだろうと思い色々調べてみました。
タスクマネージャでmsiexec.exe(.msiを実際に実行するプロセス)のI/O読み取りバイト数を見てみると、止まっている間でもガンガン何かを読み込んでいることが分かります。4GBくらい読み込んだところでプログレスバーが動き始めコピーをしていると表示があり、また4GBくらい読み込むとインストールが終了します。インストールするファイル(もちろん無圧縮、アーカイブ無し)を計2回も読み込んでいるようなのです。そりゃ遅いはずです。それもそのうち最初の1回はプログレスバーが全く動きません。DVD-ROMから4GB読み込むのに10分くらいかかりますから、その間止まっているように見えるわけです。
試しにHDDにインストーラをコピーしてから実行したり、新しくWiX Toolsetでmsiを作ってみたりしましたが、やはりWindows Installerを使う限り二回読み込むことには変わりないようです。
同じインストーラの作り方で以前はこのようなことは起きませんでした。なので以前作ったインストーラを調べてみたのですが、今実行するととてつもなく遅い! 同じ問題が起きています。これはOS側、Windows Installer側に何かあったのでは無いか、と思いました。
Webで色々調べているとKB2918614という単語を見かけました。
【至急】KB2918614適用後、アプリケーションの画像データのインストールに非常に時間がかかるようになった - マイクロソフト コミュニティ
一般コンシューマ向けパッケージソフト製品開発を行っている企業で、開発者をしております。
8/13のWindows UpdateでKB2918614適用後、以下のようなコンポーネントのインストールに非常に時間がかかるようになってしまいました。
環境によっては数時間同じ画面で停止しているという状況になりますので、エンドユーザーから見るとインストールが停止したような形になります。
おそらくは問い合わせが多数寄せられると思いますので、まずはユーザーへの対応策を検討する必要があります。
..略…
膨大なロットを市場に出荷しており、発売直後に第1の売り上げのピークを記録するというソフトウェア製品の性格上、
対応次第ではかなりの損害が出てしまいかねない状況ですので、大至急ご確認をお願いいたします。
なかなか生々しいですね……。
KB2918614はMS14-049の脆弱性を解決するためのセキュリティ更新プログラムのようです。出たのは今年の8月。
筆まめやウィルスバスターなど、いくつかの製品のサポート情報では対策としてKB2918614のアンインストールを挙げています。
その他Twitterを検索してみると8月にKB2918614が出て以降、様々なアプリケーションがインストール不能に陥っているようですね。
試しにKB2918614をアンインストールして再度インストーラの動きを確認してみました。するとすぐにコピーが始まりますし、msiexec.exeは1回分(4GB)しか読み込みません。再度KB2918614を入れると遅くなります。KB2918614の有無で動作が変わるのは間違いないようです。
msiexec /L*v log.txt /i hoge.msi
としてログを取ってみましたが、KB2918614が入っているときは止まって見える間に SECREPAIR: CryptAcquireContext succeeded
のようにSECREPAIRという単語を含むログが出力されます。KB2918614が入っていないときは出力されません。セキュリティ上の確認処理か何かをしているのでしょうか。
結局対策としては、
ということですね。
セキュリティ更新プログラムなのでアンインストールするとセキュリティ上の問題MS14-049が残ってしまうので注意が必要だと思います。
KB2918614で挙げられている既知の問題について、マイクロソフトは現在調査中としています。「遅い」というのは既知の問題として挙げられていませんが、近いうちに修正されることを祈るしか無いでしょう。修正されなければWindows Installerは死んだも同然でしょうね。プログレスバーが数十分も止まったままになるインストーラなんて使い物になりません。msiではない古き良きスクリプト駆動型インストーラに戻るしかありません。