Время на прочтение6 мин
Количество просмотров33K
Продолжая тему работы с Windows Installer, сегодня предлагаю поговорить о готовых инсталляторах, предоставляемых производителями ПО – для их обозначения широко применяется термин «vendor MSI».
Как вы помните из прошлой статьи, Windows Installer является промышленным стандартом установочных файлов и используется в большинстве систем развертывания приложений. Vendor MSI очень удобны для системных администраторов, занимающихся развертыванием ПО в корпоративных сетях. Казалось бы, достаточно взять из документации установочные параметры, использовать их в командной строке или трансформе – и дело сделано. Всё ли так просто?
Предлагаю заглянуть внутрь нескольких vendor MSI и разобраться с их устройством.
Из всякого правила есть исключения. Несмотря на то, что инсталляционный пакет прошел тестирование производителя, будьте готовы столкнуться с непредвиденным поведением в процессе установки, возникающим именно в ваших неповторимых условиях.
Естественно, при подготовке приложения к развертыванию в корпоративной среде нужно руководствоваться в первую очередь рекомендациями производителя ПО. Однако иногда система развертывания понимает только формат MSI, а вендор предоставляет только exe-инсталлятор — в этом случае есть смысл попытаться заполучить именно vendor MSI.
Где взять vendor MSI?
Предположим, нужно развернуть некоторое приложение в нашей сети. Обычно у нас есть установочный пакет, полученный от производителя ПО – скопированный с установочного диска, скачанный с официального сайта и т.д.
Если у нас нет установочного пакета – идем на
рутрекер
сайт производителя и ищем пакет там. На сайте нет пакета в формате MSI, только онлайн-установщик или setup.exe? Попробуем поискать получше. Часто msi-файл для корпоративных пользователей вместе с инструкциями по развертыванию находится не на главной странице, а в разделе сайта с громким названием вроде «For business» (например, Google Chrome или Skype), или на ftp производителя. Если есть выбор из online и offline установщика – выбираем offline вариант.
Простое правило – установочный пакет (в любом формате) можно скачивать только с официального сайта (или ftp) производителя. НИКОГДА не качайте установщик с «файловых архивов» и «каталогов программ», дабы не столкнуться с неприятным сюрпризом.
Естественно, полные версии платных приложений вроде Adobe Creative Suite вы не найдете в открытом доступе. Если у вас есть лицензия на корпоративную версию, но нет установочных файлов — смело обращайтесь в службу поддержки производителя.
Итак, установочный пакет у нас есть. Если он представляет собой файл с расширением .msi – мы имеем дело с vendor MSI (спасибо, Кэп!). Если установщик содержит набор файлов, среди которых есть файл(ы) с расширением .msi – это тоже кандидат на звание vendor MSI. Если установщик – файл с расширением .exe, его не сразу стоит списывать со счетов – есть шансы что это «обертка» и внутри обнаружится снова-таки vendor MSI.
Это можно проверить так:
• Попытаться открыть exe-файл с помощью программы-архиватора (7-zip, WinRAR).
• Запустить установку приложения из имеющегося exe-файла и заглянуть во временные папки (%temp%). Обычно во время установки создается папка со случайным названием, в ней находятся установочные файлы, включая msi-файл. Копируем установочные файлы в надежное место – после окончания процесса установки временная папка удаляется.
• Заглянуть в журналы событий по окончанию установки и проверить наличие свежих записей о событиях с источником MsiInstaller.
• ваш вариант?
Начнем с простого эксперимента на установщике iTunes – откроем файл iTunesSetup.exe с помощью 7-zip и видим, что он включает сразу пять msi-файлов (решить сколько из них «лишние» предлагаю вам самостоятельно).
Убедившись, что мы имеем дело с vendor MSI, продолжаем исследование.
Для удобства предлагаю выделить основные категории vendor MSI. Классификация совершенно условна и основана лишь на личном опыте.
По типу ресурсов:
• «Чистый MSI»
• «Комбинированный MSI»
По типу настройки:
• MSI с простой настройкой через трансформ или параметры
• MSI с мастером настройки
• MSI с файлом ответов
Теперь о каждом немного подробнее и с примерами.
«Чистый MSI»
Общее свойство установщиков такого типа – использование нативных механизмов Windows Installer для установки файлов и ключей реестра. Соответствующие этим ресурсам записи присутствуют в таблицах MSI (File, Registry, Shortcut и т.д.). Для внесения изменений в установку достаточно отредактировать записи этих таблиц в трансформе — вы имеете практически полный котроль над процессом инсталляции.
Простые примеры «чистых MSI» – Skype, InstEd.
Для диагностирования проблем с такими установщиками используются стандартные возможности – чтение записей журнала событий (журнал Application, события с источником MsiInstaller) или полное логирование установки (запуск msiexec с параметром /l*v <install.log>).
«Комбинированный MSI»
В эту категорию я отнес установщики в формате Windows Installer, устанавливающие ресурсы нестандартным для Windows Installer способом. В этом случае Windows Installer используется для вспомогательных задач, а основную часть работы выполняет бинарный Custom Action (.dll или .exe).
Пример первый – Google Chrome for Business.
Хорошо видно, что таблица File в установщике вообще отсутствует, а основную часть установки выполняет бинарный Custom Action под названием DoInstall, внутри него и находятся файлы, которые будут установлены в систему.
Еще один интересный пример – Java Runtime Environment. Извлекаем msi-файл с сопутствующим cab-файлом из оффлайн-установщика, распространяемого в формате exe-файла.
Таблица File этого vendor MSI содержит всего четыре записи, основные файлы приложения находятся внутри zip-архива (который в свою очередь находится внутри cab-файла) с последующей их распаковкой в процессе установки:
За основную часть процесса инсталляции отвечает файл regutils.dll, названия Custom Actions довольно красноречивы:
Этот тип инсталляторов несколько тяжелее поддается диагностированию ошибок – логи Windows Installer дадут нам полезную информацию только до момента запуска внутреннего exe-файла, а сам exe-файл не всегда генерирует внятные сообщения при возникновении ошибок. Также такие vendor MSI тяжелее поддаются настройке. Вернее сказать, наши возможности настройки процесса установки чаще всего ограничены только настройками, предусмотренными производителем ПО. Например, производитель ПО не всегда предусматривает возможность отключения установки ярлыков или внесения изменений в файлы настройки приложения при его установке.
Инсталляторы такого типа иногда преподносят неприятные сюрпризы в процессе установки (приходилось разбираться с JRE и Adobe Flash Player, сваливавшимися на выполнении Custom Action), и на диагностику и исправление ошибок может понадобиться некоторое время.
Теперь перейдем к возможностям настройки пакетов, предлагаемым нам производителями ПО.
MSI с простой настройкой через трансформ или параметры
Это самый распространенный способ – большинство vendor MSI имеют возможность такой настройки. Обычно производитель уже предусмотрел самые востребованные настройки вроде отключения автообновлений приложения и настроек подключения к серверу, и описал это в документации. Настройки могут быть описаны в виде параметров командной строки установщика, параметров MSI (MSI properties) или даже описания реестровых записей, которые вы можете добавить в трансформ для пакета.
Стоит упомянуть, что иногда в более новой версии vendor MSI параметры могут вести себя не так, как в предыдущей (или совсем перестать работать, как когда-то произошло с переставшими работать параметрами отключения автообновлений JRE), но это бывает крайне редко.
MSI с мастером настройки
Некоторые вендоры не ограничиваются публикацией перечня параметров командной строки для установки и настройки пакета. Они предоставляют утилиту для тонкой настройки инсталлятора, выполняющую несколько полезных функций:
• Интуитивно-понятный интерфейс избавляет системного администратора от необходимости открывать msi-файл в редакторе и вручную изменять большое количество записей в таблицах
• Утилита обычно предусматривает некоторую «защиту от дурака» и производит проверку правильности значений изменяемых параметров.
В результате выполнения мастера настроек для msi-файла формируется трансформ, который будет использоваться при развертывании пакета. Естественно, вы можете просмотреть содержимое сохраненного трансформа, применив его к открытому в редакторе msi-файлу.
Хорошим примером такого подхода может служить Adobe Customization Wizard, используемый для настройки параметров установки Adobe Reader и Adobe Acrobat:
Другой пример известного мастера настроек – Office Customization Tool (OCT). Эта утилита позволяет сконфигурировать большое количество параметров, относящихся к установке и пользовательским настройкам MS Office. В результате выполнения мастера создается MSP-файл (патч в терминологии Windows Installer), который используется при дальнейшем развертывании MS Office в корпоративной среде.
MSI с файлом ответов
Этот тип инсталляционных пакетов скорее нужно было назвать «Setup.exe с файлом ответов». Идея состоит в том, что некий установочный файл (назовем его Setup.exe) читает некий предварительно сформированный системным администратором конфигурационный файл (config.xml) и формирует набор параметров для запуска расположенного рядом установочного msi-файла (или нескольких msi-файлов).
Этот подход не предусматривает нашей работы непосредственно с msi-файлом, поэтому не будем на нем останавливаться слишком подробно. Упомяну примеры таких установщиков – файлы настроек Adobe Creative Suite (версии CS2-CS3), а также использование файла ответов config.xml для установки MS Office.
Обычно для диагностики в случае проблем установки можно использовать создаваемый программой-установщиком лог-файл с описанием этапов выполнения; дополнительная информация от Windows Installer также попадает в журналы событий.
Как видите, за общим названием vendor MSI скрываются иногда совершенно непохожие инсталляторы. Надеюсь, эта обзорная статья помогла вам получить представление об их многообразии и о возможных проблемах установки и способах их диагностики.
Download Article
An easy-to-follow guide on installing MSI files on Windows 10 or 11
Download Article
- Installing an MSI File
- Using the Command Prompt
- Video
- Tips
- Warnings
|
|
|
|
Do you need to install MSI files on Windows 10 or 11? MSI files are Microsoft Windows Installer files. These files work natively in Windows to install applications and software. To install an MSI file on Windows 11, Windows 10, and earlier versions, just double-click the file and follow the on-screen instructions. You can also use the Command Prompt (CMD) or Powershell to install an MSI file. This wikiHow teaches you how to install programs using MSI files in Windows 10 or 11.
Things You Should Know
- You will need to be signed in as an administrator to install MSI files.
- To install a program from an MSI file, just double-click the file ending with .MSI.
- You can also use the command «msiexec /i [location of MSI file]» to install an MSI file using the Command Prompt or Powershell.
-
You need to be logged in as an administrator in order to install a program using an MSI file. Either log into Windows using an administrative account or talk to a system administrator and see if they can make your account an administrative account.
-
File Explorer has an icon that resembles a folder with a blue clip. You can either click the File Explorer icon or use the keyboard shortcut to open File Explorer.
Advertisement
-
Use File Explorer to navigate to the location of the MSI file you want to install. If it’s a file you downloaded from the Internet, it will most likely be in your Downloads folder.
-
This will start the installation wizard, and start installing the program.
- If you’re prompted, click Run in the confirmation pop-up.
-
The installation wizard will guide you through the setup and install the program contained in this MSI file.
- The installation steps may vary for different programs. You may be prompted to select an installation location on your computer, or select and unselect program components to install.
-
6
Click Close or Finish. You’ll see a final message in the installation wizard when your installation is complete.
Advertisement
-
-
Replace «[path to MSI file] with the path to the location of the MSI file. The «msiexec /i» command is used to install an MSI file using the
- For example, if the MSI file is located in your Downloads folder, you would type something like msiexec /i C:\Users\username\Downloads\program.msi.
-
This will start installing the program using the MSI file you entered in the command prompt. This will either launch an installation wizard or it will install the program in the same location as the MSI file.
- Alternatively, you can open MSI files in PowerShell, but you need to install the MSI PowerShell installer first. To do so, type [[kbd|msi-installer}} and press Enter. Then you can install MSI file using the same command you would use in the Command Prompt.
- To uninstall an MSI file using this command, type msiexec /x [path to MSI file] and press Enter.[1]
Advertisement
Ask a Question
200 characters left
Include your email address to get a message when this question is answered.
Submit
Advertisement
Video
-
You can’t install an MSI file on a Mac. However, you can open the MSI file using an archive program like Winzip or 7-Zip. This is similar to how you would open a zip file. This will allow you to see what’s inside the file.
Thanks for submitting a tip for review!
Advertisement
-
Though MSI files are generally considered safe, there is always a possibility that they may contain viruses or malware. Always be cautious when installing programs using MSI files.
Advertisement
References
About This Article
Article SummaryX
1. Navigate to the MSI file.
2. Double-click the file to run it.
3. Follow the installation wizard’s prompts.
4. Click Close or Finish.
Did this summary help you?
Thanks to all authors for creating a page that has been read 104,322 times.
Is this article up to date?
Файл с расширением msi – это важный элемент в сфере программного обеспечения, который часто используется для установки и управления различными приложениями на компьютерах под управлением операционных систем Windows. Этот формат является одной из ключевых составляющих, обеспечивающих возможность безболезненной установки, обновления и удаления программ, что делает его незаменимым инструментом для разработчиков и пользователей.
С развитием технологий и ростом популярности операционной системы Windows, необходимость в эффективных методах распространения и установки программного обеспечения становилась все более актуальной. Файл формата msi представил собой качественное решение данной задачи, предоставив удобный и надежный способ для разработчиков распространять свои продукты.
Бренд Windows, благодаря интеграции с этим форматом, смог предложить пользователям интуитивно понятный метод работы с программами. В мsi файлах использованы мощные механизмы, позволяющие безопасно и эффективно управлять установленными приложениями, что очень важно для обеспечения стабильности и производительности системы в целом.
История появления и развития этого формата файла тесно связана с совершенствованием операционных систем компании Microsoft и их стремлением обеспечить максимально комфортное пользовательское взаимодействие.
Файлы msi: что это?
MSI-файлы играют ключевую роль в установке приложений в операционной системе Windows. Они помогают пользователям установить, обновить и удалить программы, сохраняя данные об установке в специальном формате. Давайте разберёмся с их структурами и особенностями.
Изначально этот формат был разработан корпорацией Microsoft для упрощения процесса установки программного обеспечения. За годы использования этот формат стал популярным не только среди разработчиков ПО, но и среди пользователей, благодаря своей надежности и удобству. История бренда Microsoft тесно переплетается с этим типом файлов, так как он был одним из ключевых аспектов развития их экосистемы.
Для открытия и работы с такими файлами используются специальные инструменты, предоставляемые как самой Microsoft, так и сторонними разработчиками. Основным компонентом является Windows Installer, который управляет процессом установки и удаления программ, обеспечивая целостность и чистоту операционной системы.
Особенность | Описание |
---|---|
Создание и использование | Используются для установки, обновления и удаления программного обеспечения. |
Структура | Содержат информацию об установке, файлы программы и данные конфигурации. |
Инструменты | Открываются с помощью Windows Installer и сторонних утилит. |
Актуальность | Являются стандартом для многих современных приложений. |
Таким образом, файлы msi представляют собой мощный инструмент для управления программными продуктами в среде Windows. За каждым таким файлом стоит история и технологии, развивающиеся вместе с операционной системой этого бренда.
Установка с помощью MSI
MSI – это популярный формат установщика, поддерживающий многочисленные функции, которые делают процесс инсталляции наиболее эффективным и удобным. Этот формат стал брендом в своем роде благодаря своей надежности и простоте использования.
Процесс установки включает несколько этапов, каждый из которых направлен на обеспечение безошибочной и безопасной установки программного обеспечения на ваш компьютер. Рассмотрим основные шаги:
- Скачивание файла: Изначально нужно открыть официальный сайт разработчика или другого проверенного источника и загрузить файл MSI.
- Запуск инсталлятора: После того как файл был успешно скачан, двойным кликом открываем его. Это действие запускает последовательность установки.
- Следование указаниям: На экране появляются инструкции и условия лицензионного соглашения, которые необходимо внимательно изучить и подтвердить.
- Выбор параметров установки: Некоторые инсталляторы позволяют выбрать директорию установки и установить дополнительные компоненты или функции.
- Процесс установки: Теперь инсталлятор автоматически копирует файлы, настраивает необходимые параметры и регистрирует компонент в системе.
- Завершение: По окончании процесса установки будет предложено перезагрузить систему или сразу запустить установленное приложение.
История формирования и развития MSI как формата установщика привела к созданию технологии, которая экономит время и усилия пользователей, гарантируя при этом высокую степень надежности и безопасности процесса установки. Благодаря этим особенностям, MSI заслужил свою популярность и сегодня широко используется для установки различного программного обеспечения.
Таким образом, используя MSI, пользователи могут быть уверены в безупречном процессе установки, который открывает возможности безопасной и удобной эксплуатации программного обеспечения.
Инструменты для работы с msi
Для эффективного взаимодействия с msi-файлами существует множество полезных инструментов. Разные программы позволяют выполнять разнообразные операции с этими файлами, будь то их создание, редактирование или анализ. В данном разделе мы рассмотрим наиболее популярные решения и подробно расскажем о возможностях каждого из них.
Одним из ведущих инструментов является Orca. Эта утилита от корпорации Microsoft идеально подходит для редактирования msi-файлов. С ее помощью можно изменять таблицы и записи, что делает процесс модификации более гибким. Orca позволяет детально изучить структуру пакета и внести необходимые изменения.
Другой важный инструмент — InstEd. Это редактор msi, который часто используют разработчики для создания и тестирования установочных файлов. InstEd предлагает удобный интерфейс, который облегчает работу с базовыми и расширенными параметрами пакета. Это ПО помогает отслеживать историю изменений, что полезно для управления версиями установочных файлов.
Специалисты, работающие с msi на профессиональном уровне, ценят возможности программы Advanced Installer. Этот мощный инструмент позволяет не только открывать и редактировать файлы, но и интегрироваться с продуктами различных брендов. Advanced Installer поддерживает автоматизацию процессов и создание сложных сценариев установки.
Для анализа и диагностики msi-файлов часто применяется SuperOrca. Эта утилита предоставляет доступ к таблицам базы данных и позволяет исследовать данные внутри пакета. Благодаря таким особенностям, SuperOrca помогает выявить и устранить ошибки, что значительно повышает надежность установочных файлов.
Не стоит забывать и о WiX Toolset. Этот набор инструментов позволяет создавать msi-файлы из исходного кода, что дает возможность разработчикам полностью контролировать процесс сборки установочных пакетов. WiX Toolset поддерживает интеграцию с другими системами разработки и является незаменимым помощником при создании сложных установочных сценариев.
Каждый из перечисленных инструментов имеет свои уникальные возможности, которые делают работу с msi-файлами более удобной и продуктивной. Выбор конкретного решения зависит от своих задач и уровня подготовки специалиста.
Отличия msi и exe
При установке программного обеспечения на компьютер пользователи часто встречают файлы с расширениями MSI и EXE. Несмотря на кажущееся сходство, эти форматы имеют значительные различия. Рассмотрим, чем же они различаются и в каких случаях предпочтительнее использовать тот или иной тип файла.
Файлы с расширением .msi представляют собой установочные пакеты, разработанные специально для операционной системы Windows. Такие файлы создаются с использованием Windows Installer, инструмента компании Microsoft. MSI-файл обычно содержит всю необходимую информацию для установки, обновления и удаления программного обеспечения. Это делает их удобным вариантом для комплексного управления программными установками в корпоративной среде.
С другой стороны, файлы с расширением .exe представляют собой исполняемые файлы. Они могут содержать не только установочные пакеты, но и любые другие программы или скрипты. EXE-файлы обладают способностью запускаться и открывать различные программы и приложения непосредственно. Происхождение EXE формата можно проследить до начала вековой истории Windows, что делает его одним из самых старых и наиболее широко используемых форматов в операционной системе Microsoft.
Бренды программного обеспечения также могут предпочитать один формат другому. Например, некоторые крупные компании, такие как Adobe или Autodesk, выбирают MSI формат для своих установочных пакетов, чтобы обеспечить простоту интеграции и автоматизации развертывания в корпоративных сетях. В то время как множество других разработчиков отдают предпочтение EXE файлам благодаря их универсальности и совместимости.
Подводя итоги, MSI файлы нацелены на обеспечение профессиональной установки и управления программным обеспечением, тогда как EXE файлы служат универсальным решением для различных задач. Понимание этих различий помогает пользователям выбирать наиболее подходящий формат в зависимости от их конкретных нужд и условий эксплуатации.
Создание собственных msi
Для создания инсталляционного файла можно воспользоваться несколькими подходами:
- Применение специализированных инструментов для разработки msi-пакетов.
- Использование интегрированных возможностей сред разработки, таких как Visual Studio.
- Создание msi вручную с помощью WiX Toolset либо аналогичных инструментов.
Основные шаги для создания msi-пакета включают:
- Подготовка исходных данных: Создание каталогов и подготовка файлов программы, структурирование их в логически организованные директории.
- Настройка проекта: Открытие и настройка проекта в выбранной среде разработки или инструменте, добавление всех необходимых файлов, установление параметров установки.
- Конфигурирование компонентов: Определение компонентов и их зависимостей, указание возможных условий установки.
- Формирование пользовательских интерфейсов: Настройка интерфейсов для установки (например, приветственные экраны, соглашения о лицензии), добавление фирменных элементов бренда, таких как лого и цвета.
- Тестирование сборки: Проведение тестов на разных системах для проверки корректности установки и функционирования приложения.
- Создание итогового мsi-файла: Генерация финального инсталляционного пакета и его распространение пользователям.
Благодаря структурированному подходу и применению функциональных инструментов, вы сможете самостоятельно создавать качественные msi-пакеты, которые поднимут ваш бренд на новый уровень. Помните, что тестирование является ключевым этапом для обеспечения надёжности и стабильности установки вашего программного обеспечения.
Преимущества формата msi
Формат установки программ от бренда Microsoft давно завоевал популярность благодаря своим уникальным достоинствам. Этот формат удобен и функционален, предлагает множество возможностей для пользователя и разработчика, делая взаимодействие с компьютерными приложениями максимально эффективным и комфортным.
Упрощение установки и удаления – Один из ключевых плюсов данного формата заключается в простоте инсталляции и деинсталляции программ. Пользователи могут без труда открывать и устанавливать приложения без необходимости в дополнительных манипуляциях. Автоматический процесс настройки и конфигурирования программного обеспечения значительно экономит время и усилия.
Стабильность и надежность – Формат обеспечивает высокую устойчивость к ошибкам при установке. В случае возникновения проблем пользователи могут легко восстановить исходное состояние системы. Таким образом, минимизируется риск сбоев и повреждений файлов, повышается общая стабильность работы программ, что особенно важно для корпоративного использования.
Безопасность и контроль – Одним из важных преимуществ является усиленная защита. Файлы подписываются цифровыми сертификатами, что гарантирует их подлинность и защищает от вмешательства злоумышленников. Кроме того, IT-специалисты могут тщательно контролировать все устанавливаемые программные продукты, предотвращая нежелательные изменения в системной инфраструктуре.
Широкие возможности автоматизации – Для администраторов и разработчиков формат открывает возможности автоматизации задач, что значительно облегчает процесс установки на множество устройств одновременно. Сценарии и командные файлы могут значительно ускорить работу, упрощая массовое развертывание и обновление программного обеспечения.
Единая структура – Формат отличается структурированной организацией файлов и настроек. Это облегчает поиск конкретных элементов и управление ими. Также стандартный подход к хранению данных улучшает совместимость с другими системами, позволяя решить множество задач без дополнительных разработок.
Устройство и развертывание пакетных файлов
Какому администратору Windows не знакомы символы msi? Служба Windows Installer (программа msiexec.exe) и ее пакетный файл .msi — фактически стандартная технология для установки приложений Windows. Преимущества пакета установки приложений Windows Installer общеизвестны. Во-первых, при сбоях в процессе установки пакет .msi отменяет выполненный фрагмент установки и восстанавливает исходное состояние компьютера, тем самым предотвращая повреждения приложений и системы. Во-вторых, .msi-упакованное приложение обладает способностью к самовосстановлению, если пользователь удаляет один из его файлов. И наконец, Windows Installer обеспечивает установку программ на пользовательских компьютерах. Основные принципы работы Windows Installer широко известны, но более глубокое понимание внутренних механизмов Windows Installer и пакетов .msi позволит строить специализированные пакеты установки приложений и упростит диагностику сбоев в процессе развертывания. Ниже приводится обзор технологии Windows Installer, а затем речь пойдет о структуре пакетов .msi и их взаимодействии со службой Windows Installer.
Технология Windows Installer
Технология Windows Installer была разработана около четырех лет назад, а позднее стала базовым компонентом операционной системы Windows 2000 Server. Windows Installer 2.0 входит в состав Windows Server 2003 и Windows XP и поддерживает сборки Microsoft .NET (блок установки в .NET). Пользователи могут получить Windows Installer либо вместе с операционной системой Windows в качестве службы Windows Installer, либо в составе комплекта разработки программ (software development kit, SDK). Служба Windows Installer представляет собой механизм, который устанавливает пакеты Windows Installer (.msi-файлы). SDK содержит спецификации и API, определяющие формат и функцию .msi-файлов. Windows Installer SDK представляет собой составную часть Platform SDK. Его можно загрузить по адресу http://www.microsoft.com/msdownload/platformsdk/ sdkupdate/sdkinfo.htm. Разработчики и поставщики инструментов упаковки программ, такие как InstallShield Software, OnDemand Software и Wise Solutions (в настоящее время подразделение компании Altiris), применяют SDK для подготовки пакетов установки приложений. Программисты часто используют инструменты упаковки приложений, которые преобразуют старые процедуры установки в формат Windows Installer, чтобы скрыть от пользователей сложность технологии Windows Installer.
Продукты, функции и компоненты
.msi-файл представляет собой сложную базу инструкций по установке приложений, которая содержит десятки таблиц, сотни столбцов и иногда вложенные файлы. В базе данных хранится информация о требованиях операционной системы к установке приложения, этапах установки и даже диалоговых окнах, выводимых на экран.
.msi-файл имеет трехуровневую структуру. Высший уровень — продукт, собственно приложение. Продукту присваивается уникальный код — глобально уникальный идентификатор (globally unique identifier, GUID). На следующем уровне располагаются функциональные блоки внутри продукта. Функциональные блоки имеют имена и могут быть добавлены по желанию пользователя. На экране 1 показан пример функциональных блоков в приложении — в данном случае Microsoft Office Access и Microsoft Office Excel в пакете установки Microsoft Office. Функциональный блок — это единый блок для установки внутри пакета Windows Installer. Устанавливаются (или удаляются) функциональные блоки пакета, а не отдельные файлы.
Экран 1. Функциональные блоки приложения, упакованного для Windows Installer |
На экране 1 видно, что Excel состоит из множества функциональных подблоков, таких как Help и Spreadsheet Templates. Во время установки пользователь может указать подблоки, которые следует установить на компьютере локально или запускать с сервера, добавить при первом обращении к ним (обозначается единицей в пиктограмме подблока) или вообще не требуется устанавливать. Метод «объявления» (advertisement) подблоков описан по врезке «Возможности объявлений».
Функциональные блоки состоят из компонентов, которые представляют третий уровень иерархии .msi-файла. Компонент — это базовая единица пакета Windows Installer и строительный блок приложения. Компонент может быть файлом или группой файлов, параметром реестра, ярлыком или ресурсом (например, пиктограммой). С компонентом связан ключевой путь (key path). Ключевой путь определяет файл или параметр, без которого невозможна полная установка компонента. Ключевой путь — основа механизма самовосстановления пакетов на базе Windows Installer. При ремонте .msi-упакованного приложения служба Windows Installer проверяет полноту всех ключевых путей компонентов. Если ключевой путь какого-нибудь компонента отсутствует, служба Windows Installer определяет, какому функциональному блоку принадлежит компонент, и повторно устанавливает функциональный блок. Таким образом, время, необходимое для ремонта развернутого приложения, отчасти зависит от числа компонентов в пакете и числа компонентов в функциональном блоке, содержащем испорченный компонент.
База данных Windows Installer
Как отмечалось ранее, .msi-файл представляет собой набор инструкций по установке, организованных в таблицы. Windows Installer SDK определяет каждую таблицу и столбец. С помощью редактора баз данных Orca из Windows Installer SDK можно просматривать и редактировать содержимое .msi-файла. .msi-файл установки для Orca находится в подкаталоге in установочного каталога Platform SDK (например, c:program filesplatform sdkin). После установки Orca можно открыть любой .msi-файл. В левой панели интерфейса Orca представлен список таблиц файла. Выделив таблицу, в правой панели можно увидеть ее строки и столбцы.
Экран 2. Таблицы базы данных приложения, упакованного для Windows Installer |
На экране 2 показана таблица LaunchCondition пакета Windows Installer для Group Policy Management Console (GPMC). В правой панели таблицы представлены минимальные требования к операционной системе и платформе для установки GPMC. В столбце Condition содержатся условия, которые должны быть выполнены в процессе установки. В столбце Description описаны минимальные требования для набора условий. Приступая к установке приложения, Windows Installer проверяет, удовлетворены ли условия запуска, прежде чем продолжить установку.
Таблицы последовательностей (sequence table) представляют собой ядро базы данных; в них перечислены действия, которые служба Windows Installer должна выполнить в процессе установки, и порядок их выполнения. Например, в таблице последовательностей указывается, что механизм Installer должен сначала проверить условия запуска в таблице LaunchCondition, затем скопировать исходные файлы в каталог назначения и подготовить набор элементов реестра. Таблицы последовательностей бывают трех типов: Admin, Advertisement и Install. Тип таблицы последовательностей, используемый Windows Installer, зависит от типа выполняемой процедуры установки. Описания типов таблиц последовательностей даны в таблице 1.
С каждой таблицей последовательностей связаны две вспомогательные таблицы. Одна из них — InstallUISequence — определяет диалоговые окна пользовательского интерфейса, которые должны отображаться при интерактивной (управляемой пользователем) установке. Другая таблица — так называемая таблица «исполнительной последовательности» (execute sequence; InstallExecuteSequence) — определяет шаги, необходимые для установки.
Последовательность состоит из набора заранее определенных стандартных функций, которые перечислены в столбце Action таблицы InstallExecuteSequence. Стандартные функции выполняют разнообразные задачи, в том числе копирование файлов, поиск новых версий программы и определение размера дискового пространства, доступного при установке. В документации SDK и Orca приведены подробные сведения о назначении конкретного пакета Windows Installer. С помощью Orca можно подготовить специальные операции для задач, которые нельзя решить с использованием стандартных функций пакета Windows Installer. Специальная операция может быть DLL, составленной пользователем, и даже сценарием VBScript для таких действий, как поиск в Active Directory (AD) определенных значений перед продолжением установки.
Таблица Property — еще одна важная часть базы данных .msi. Свойства представляют собой постоянные величины, задавая которые можно управлять ходом установки. В сущности, свойства есть переменные среды для .msi-файла. В пакетах Windows Installer часто используется свойство ALLUSERS, которое указывает процедуре установки, каким образом хранится информация о конфигурации приложения — для пользователя или для компьютера. Имена свойств чувствительны к регистру и их можно указывать в командной строке во время установки или используя трансформацию.
Трансформации, исправления и модули слияния
.msi-файл, полученный от поставщика, часто не располагает всем необходимым для развертывания пакета в конкретной среде. Например, потребитель может пожелать развернуть пакет автоматически с помощью инструмента развертывания программного обеспечения или установить только определенные функциональные блоки. В такой ситуации могут пригодиться трансформации. Трансформация — это специальный тип файла базы данных .msi, обычно имеющего расширение .mst. Трансформации применяются к процедуре развертывания приложения во время установки. В сущности, они изменяют выбираемые по умолчанию значения в пакете .msi, управляя процессом установки. Измененные значения в .msi-файле не сохраняются; они просто определяют, как будет протекать конкретная установка.
Файлы исправлений (patch file или .msp-файлы) отличаются от трансформаций. Как правило, поставщик выпускает файл исправлений, когда нужно модернизировать продукт, не прибегая к его глубокой переработке. Примером исправлений могут служить обновления для системы безопасности. После установки исправления в экземпляре .msi-файла, хранящемся в кэше рабочей станции, производятся постоянные изменения. Чтобы новые пользователи в будущем получали обновленные файлы, следует применить файлы исправлений к исходному пакету приложения.
Еще один вариант .msi-файла — модуль слияния (merge module, или .msm-файл), набор компонентов, многократно используемых при установке приложений. Например, в различных программах независимых поставщиков применяются компоненты Microsoft Data Access Components (MDAC). Вместо того чтобы воспроизводить установку общих компонентов в каждом новом .msi-пакете, авторы пакетов приложений могут задействовать модули слияния, предоставляемые поставщиками общих компонентов. Модули слияния — упрощенные файлы базы данных .msi, содержащие только общие функциональные блоки и компоненты для процедур установки приложений. Часто собственно компонентные файлы встраиваются в .msm-файл, что позволяет использовать модули слияния с разными пакетами. Затем .msm-файлы вставляются в основной пакет Windows Installer для данного приложения на этапе создания пакета.
При подготовке нового пакета установки файлы приложения можно вставить в .msi-файл. Как правило, файлы вставляются в виде встроенных файлов .cab, которые представляют собой сжатые наборы файлов, похожие на .zip-файлы. В .msi-файл удобно вставлять .cab-файлы не очень большого размера. Например, в Office имеются отдельные .msi- и .cab-файлы, так как размеры .cab-файлов Office достигают нескольких сотен мегабайт. Однако, упаковав все необходимые файлы малого приложения в .msi-файл, можно получить компактный файл, который удобно распространять среди пользователей. Извлечь встроенный .cab-файл из .msi-файла можно с помощью инструмента msidb.exe пакета Windows Installer SDK.
Служба Windows Installer
Пакеты Windows Installer и служба Windows Installer взаимозависимы: они не могут существовать друг без друга. Служба Installer по умолчанию устанавливается на всех компьютерах с версиями операционной системы, выпущенными после Windows 2000: редистрибутивную версию (автономную версию службы Installer и сопутствующие DLL) можно развернуть на компьютерах Windows NT Server 4.0 и Windows 9x. Служба Installer работает в контексте привилегированной пользовательской учетной записи LocalSystem. Чтобы запустить службу Windows Installer, нужно дважды щелкнуть на .msi-файле (например, в Windows Explorer); при запуске службы формируется новый процесс Installer (msiexec.exe) в контексте полномочий пользователя. После того как Windows Installer завершит установку приложения, служба Installer закрывается до следующего обращения к ней.
Служба Windows Installer обеспечивает набор функций, удобных для развертывания программ, особенно при использовании совместно с функцией Software Installation в Group Policy. Главная среди этих функций — повышение полномочий (privilege escalation). Когда обычный пользователь пытается установить приложение на своем компьютере, дважды щелкнув на .msi-файле, его полномочий для выполнения установки не всегда достаточно. Однако при развертывании приложения с помощью функции Software Installation групповой политики служба Windows Installer выполняет установку в своем контексте безопасности LocalSystem.
В частности, служба Installer создает новый процесс msiexec.exe в контексте безопасности пользователя для выполнения той части установки, которая проводится в пользовательском профиле. Служба Installer использует собственный повышенный контекст безопасности (учетную запись LocalSystem) для выполнения специфической для данного компьютера части процедуры установки, для проведения которой у пользователя полномочий нет. Приложения, развернутые таким способом, называются управляемыми (managed applications). Повышение полномочий, используемое Windows Installer для управляемых приложений, как правило, возможно только при применении групповой политики, хотя метод доступен и вне процедур на базе Group Policy Object (GPO), через политику Administrative Template.
В рамках взаимозависимых отношений между Group Policy и службой Windows Installer реализованы объявления (advertisement). Как отмечалось ранее, при связывании программы с пользователем в Group Policy, в сущности, производится установка с объявлением. Таким образом, механизм Windows Installer обрабатывает сценарий объявления приложения (файл .aas), а не непосредственно .msi-файл. Файл .aas создается, когда для развертывания приложения используется Group Policy. Чтобы создать .aas-файл, редактор Group Policy Editor (GPE) вызывает функцию, экспортируемую из msi.dll (основная DLL, используемая msiexec.exe), которая генерирует уникальный сценарий объявлений внутри GPO. Таким образом, когда механизм Windows Installer обрабатывает сценарий объявлений, ему известно местонахождение соответствующего .msi-файла и части приложения, которые нужно объявить. Другими словами, процедура установки программ на базе GPO тесно связана со службой Windows Installer и наоборот.
Хранение файлов Installer на рабочей станции
Рассмотрим, что происходит на рабочей станции, когда служба Windows Installer устанавливает пакет .msi. Во-первых, чтобы обеспечить отмену действий в случае сбоя, Installer делает резервные копии всех замененных файлов, сохраняя их во временной папке на жестком диске пользователя, обычно C:config.msi. Заглянув в эту папку в ходе установки, можно увидеть в ней временные файлы с необычными именами, созданные службой Installer. После завершения установки служба Installer удаляет временные файлы.
Закончив установку, Windows Installer сохраняет экземпляр ассоциированного .msi-файла и любые трансформации, использовавшиеся Windows Installer при установке приложения, в папке \%windir%installer, назначая файлам уникальные условные имена (например, 19fe9b79.msi). Файлы в \%windir%installer в действительности представляют собой кэшированные копии всех .msi-файлов, обработанных службой Windows Installer на компьютере. Благодаря наличию кэшированных копий пользователь может изменить или удалить приложение, не обращаясь к оригинальному пакету установки, который может находиться на разделяемом диске сервера, недоступном мобильному пользователю. Windows отслеживает все развернутые приложения на базе .msi; имеющиеся функциональные блоки, компоненты и исправления, а также имя кэшированного .msi-файла в реестре.
Чтобы выяснить, какой .msi-файл с непонятным именем соответствует данному приложению на рабочей станции, следует перейти в раздел реестра HKEY_LOCAL_MACHINESOFTWAREMicrosoftWindows CurrentVersionInstallerUserData. Разделы упорядочены по SID имени пользователя; первой показана учетная запись LocalSystem, S-1-5-18, далее обычно перечисляются все приложения, установленные на компьютере. Список доступных пользователю программ приведен под соответствующим SID пользователя.
Запуск Installer Files из командной строки и в сценариях
Существует два дополнительных способа запуска пакетных установок Windows Installer — из командной строки и сценария. С помощью msiexec.exe можно выполнять различные процедуры установки из командной строки. Полный список функций командной строки для msiexec.exe приведен в статье Microsoft «Command-Line Switches for the Microsoft Windows Installer Tool» по адресу http://support.microsoft.com/?kbid=227091. Например, из командной строки можно установить один функциональный блок в прикладном пакете, такой как инструменты консоли DNS в пакете Windows 2003 Administration Tools (adminpak.msi). С помощью Orca следует отыскать нужное имя функционального блока — в данном случае FeDNSConsole — и запустить msiexec.exe из командной строки, чтобы произвести установку:
msiexec /I adminpak.msi ADDLOCAL=FeDNSConsole
Свойство ADDLOCAL используется данной командой, чтобы указать службе Windows Installer функциональные блоки пакета, которые необходимо установить. Метод командной строки используется вместо выбора функциональных блоков пользователями или установки отдельных блоков администратором с помощью файла трансформации.
В Windows Installer SDK имеются примеры, поясняющие использование сценариев Windows Script Host (WSH) для взаимодействия со службой Windows Installer и пакетами .msi. Объект WindowsInstaller.Installer располагает методами и свойствами, которые можно применять в сценариях для выполнения таких операций, как подготовка списка всех .msi-пакетов, имеющихся в системе, добавление .cab-файла в базу данных .msi, применение трансформации в ходе установки и сравнение двух .msi-файлов базы данных. Более подробную информацию о сценарных объектах Windows Installer можно получить, изучив сценарии примеров Installer SDK в папке http://msdn.microsoft.com/library/default.asp?url=/library/en-us/msi/setup/using_the_automation_interface.asp.
Как было показано выше, задачи Windows Installer не ограничиваются простым щелчком на .msi-файле. Мощная технология Windows Installer позволяет гибко и быстро устанавливать программы, но для эффективного использования службы необходимо понимать принципы ее работы.
Даррен Мар-Элиа — редактор журнала Windows & NET Magazine. С ним можно связаться по адресу: dmarelia@winnetmag.net
Возможности объявлений
Объявление приложений — компонент Windows Installer, который широко используется при развертывании приложений с помощью Group Policy. Объявленное приложение на самом деле не устанавливается на настольном компьютере пользователя, обозначается лишь «присутствие» приложения. Это может быть ярлык на рабочем столе или в меню Start, ассоциирование файлов в реестре и даже COM-компонент, зарегистрированный в HKEY_CLASSES_ROOT. Объявление оповещает пользователя о том, что приложение установлено и готово к использованию. Однако сами файлы приложения разворачиваются лишь после первого обращения пользователя к приложению. Преимущество объявлений заключается в том, что приложения доступны, но устанавливаются лишь после того, как в них возникает необходимость. Благодаря объявлениям, администратору, обслуживающему 20 тыс. настольных компьютеров, приходится обновлять приложения только на компьютерах, пользователи которых действительно работают с этими программами. Недостаток объявлений — вынужденное ожидание в течение нескольких минут, пока система устанавливает приложение для первого запуска.
Типы таблиц последовательностей
Тип таблицы последовательностей | Описание |
Admin | Используется для административных установок приложений (с сервера) |
Advertisement | Используется для установки с объявлениями |
Install | Используется для интерактивных или автоматических установок на локальном компьютере — наиболее распространенный тип |
Файлы MSI известны в качестве файлов, используемых установщиками программ в ОС Windows. Они содержат информацию об определенных установках, которые помогают установщику выполнять свою работу. Эта информация включает файлы, которые необходимо установить, а также различные пути установки. Использовать файлы MSI могут не только обновления ОС Windows, но и сторонние установщики программного обеспечения, которые не принадлежат Microsoft.
Файлы MSI — это не «чистые» установочные файлы, а всего лишь пакетные файлы. Таким образом, они могут быть извлечены с использованием приложения 7-zip или других методов декомпрессии (и/или программного обеспечения). Файлы MSI подвержены заражению. Вместо того, чтобы доверять случайным файлам MSI, рекомендуется проводить тщательную их проверку антивирусом.
Вот небольшой, но неполный список программ, которые могут открывать документы MSI:
- 7-Zip
- Microsoft Windows Installer