Instalador de ventanas

La versión actual de la página aún no ha sido revisada por colaboradores experimentados y puede diferir significativamente de la versión revisada el 29 de septiembre de 2018; las comprobaciones requieren 18 ediciones .
instalador de ventanas

Tipo de Componente de Microsoft Windows [d] einstalador
Desarrollador microsoft
Sistema operativo ventanas
plataforma de hardware Microsoft Windows
ultima versión 5.0 [1] ( 22 de julio de 2009 )
Formatos de archivo legibles MSI , archivo de información de instalación de Windows [d] y archivo inf_loc de instalación de Windows [d]
Licencia Acuerdo de usuario de Microsoft
Sitio web docs.microsoft.com/… (  inglés)

Windows Installer ( Windows Installer , nombre en clave - Darwin [2] [3] ) es un subsistema de Microsoft Windows que proporciona instalación de programas ( instalador ). Es un componente de Windows desde Windows 2000 ; se puede instalar en versiones anteriores de Windows. Toda la información necesaria para la instalación (a veces junto con los archivos a instalar) está contenida en paquetes de instalación (installation packages) con la extensión .msi [4] .

Historia

Windows Installer se desarrolló entre 1995 y 1998 y originalmente tenía el nombre en código Darwin . Las primeras versiones se llamaban Microsoft Installer , por lo que la extensión de archivo del paquete de instalación estándar es .msi . [5]

La primera versión de Installer se lanzó a principios de 1999 como un instalador de Microsoft Office  2000. A fines de ese año, Installer pasó a formar parte de Windows 2000 . Microsoft alentó a los desarrolladores a cambiar al nuevo instalador de todas las formas posibles, incluyendo en la lista de requisitos para los programas que deseen recibir el llamado logotipo de Windows 2000, el requisito de instalar usando Windows Installer.

Windows Installer resultó ser un importante paso adelante en relación con el instalador anterior de Microsoft - API de configuración (Configuración ACME): introdujo características de GUI , soporte para desinstalación y reversión en cualquier momento durante la instalación (incluida la reversión durante la desinstalación), trabajo correcto con derechos de acceso en Windows y otras funciones, lo que lo convierte en una fuerte alternativa a varios paquetes de instalación en el mercado.

Las actualizaciones futuras presentarán .MSIX, que será una especie de híbrido de . APPX y .MSI, que le permite instalar aplicaciones UWP en el sistema (Actualmente, esto solo es posible directamente a través de Microsoft Store)

Estructura lógica del paquete

Un paquete de instalación describe la instalación de un producto y tiene su propio GUID . Un producto consta de componentes (que también tienen sus propios GUID) agrupados en características .

Componente (componente): la unidad de instalación mínima e indivisible, que es un grupo de archivos, valores de registro, carpetas creadas y otros elementos, unidos por un nombre común (nombre del componente) e instalados juntos o no instalados. Los componentes están ocultos para el usuario final. Cada componente tiene una ruta clave (key path), por ejemplo, el nombre de su archivo principal, que determina la presencia de este componente en la computadora del usuario.

Oportunidad (característica; en la versión rusa de Windows, esta palabra se traduce como "componente", lo que introduce confusión) es un grupo jerárquico de componentes y/u otras características. Cuando se muestra un cuadro de diálogo para seleccionar las partes instaladas del programa durante la instalación, el usuario controla la elección de las características . Seleccionar una opción para instalar implica instalar todos los componentes que se incluyen en ella [6] .

Estructura física del paquete

Un archivo .msi es un documento compuesto OLE ( documento compuesto OLE : los documentos de Microsoft Word , Excel , etc. se almacenan en el mismo formato de contenedor), que contiene una pequeña base de datos relacional  : un conjunto de varias docenas de tablas interconectadas que contienen diversa información sobre el producto y el proceso de instalación. En este caso, todos los datos de cadena en la base de datos se almacenan juntos en un flujo de documentos separado, y en las tablas de la base de datos hay enlaces a ellos; evitando así la duplicidad de líneas, lo que reduce significativamente el tamaño de la base de datos.

Además de la base, la estructura del archivo .msi prevé la colocación de secuencias de comandos de usuario y archivos DLL auxiliares , si los hubiere, necesarios para la instalación, así como los propios archivos instalables, empaquetados en formato .cab . Los archivos también se pueden colocar por separado del paquete, en formato empaquetado o desempaquetado (conservando la estructura de directorios).

Proceso de instalación

El proceso de instalación consta de varias etapas: recopilación de información, ejecución (la instalación real) y posiblemente reversión (en caso de error o cancelación de la instalación por parte del usuario).

Acciones

Cada etapa de la instalación consta de una secuencia de acciones (acciones), registradas en la base de datos. A las acciones se les asignan números que determinan el orden en que se realizan y, a veces, las condiciones bajo las cuales se realizan o no las acciones.

La mayoría de los pasos son pasos estándar para un proceso típico de recopilación e instalación de información. Todas estas acciones están documentadas, además de ellas, el usuario puede definir sus propias acciones (acciones personalizadas).

Las acciones definidas por el usuario pueden escribirse en uno de los lenguajes de secuencias de comandos integrados en el sistema operativo ( JScript o VBScript , así como Eclipse, un lenguaje secundario de C++), o colocarse en una DLL especialmente creada (escrita en lenguajes como C , C++ , etc.). Los archivos con estas acciones se colocan dentro del archivo .msi y se extraen desde allí al comienzo de la ejecución de la instalación. Estas DLL se extraen al directorio Windows\Installer y se les asignan nombres aleatorios, como MSIF65E.tmp.

Recopilación de información

Durante la fase de recopilación de información, Windows Installer recopila instrucciones (ya sea a través de la interacción del usuario o mediante programación) para instalar o eliminar una o más funciones incluidas en el producto. Estas instrucciones luego forman un script interno basado en la base de datos, que detalla el paso de ejecución posterior.

Esta etapa también se denomina modo inmediato (modo inmediato).

Ejecución

Al comienzo de este paso, el instalador ha generado un script interno diseñado para ejecutarse sin la intervención del usuario. Este script lo ejecuta el instalador en modo de servicio NT privilegiado (específicamente, bajo la cuenta LocalSystem ). El modo privilegiado es necesario debido al hecho de que la instalación puede iniciarla un usuario que no tiene los derechos necesarios para cambiar los parámetros y archivos del sistema (aunque se le otorgó el derecho de instalar el programa).

Esta etapa a veces se denomina modo diferido .

Retroceder

Si alguna de las acciones definidas en el script falla, o si el usuario cancela una instalación en curso, todas las acciones realizadas hasta ese momento se revierten y el sistema vuelve a su estado anterior a la instalación. La reversión está asegurada por la presencia de cada acción que realiza un cambio en el sistema, al revés. Al introducir acciones no estándar en un paquete, el programador también debe crear acciones inversas para que la reversión funcione correctamente [7] .

Otras características

Anuncio e instalación bajo demanda

El instalador de Windows puede anunciar el producto en lugar de instalarlo [8] . El producto aparecerá al usuario, pero en realidad no se instalará hasta que se inicie por primera vez (mediante un acceso directo en el menú de inicio ). Un administrador puede anunciar el paquete de instalación mediante la política de grupo de Windows u otro mecanismo de compilación, o ejecutando el ejecutable msiexec con /jm (para anuncios por dispositivo) o /ju (para anuncios por usuario). Algunos paquetes MSI creados con InstallShield pueden interferir con el uso de estas y otras funciones integradas de MSI.

El usuario debe tener derechos de administrador para completar la instalación anunciada.

Instalación bajo demanda

Similar a la publicidad de un producto, la instalación bajo demanda instala una característica tan pronto como el usuario intenta usarla [9] .

Notas

  1. Versiones publicadas de Windows Installer . Red de desarrolladores de Microsoft . microsoft _ Consultado el 22 de febrero de 2015. Archivado desde el original el 13 de diciembre de 2014.
  2. cuando la configuración no es solo xcopy: La historia de Orca . Archivado desde el original el 23 de diciembre de 2008.
  3. Windows Installer, .NET Framework, Bootstrapper y usted: la visión completamente única de Chris Smith . Consultado el 1 de julio de 2018. Archivado desde el original el 5 de febrero de 2019.
  4. Detalles de la extensión de archivo .MSI . Consultado el 1 de julio de 2018. Archivado desde el original el 11 de agosto de 2021.
  5. Rob Mensching. Dentro del formato de archivo MSI. . Consultado el 11 de abril de 2006. Archivado desde el original el 15 de enero de 2009.
  6. Componentes del instalador de Windows | Documentos de Microsoft . Consultado el 1 de julio de 2018. Archivado desde el original el 1 de julio de 2018.
  7. Instalación revertida | Documentos de Microsoft . Consultado el 1 de julio de 2018. Archivado desde el original el 1 de julio de 2018.
  8. Publicidad | Documentos de Microsoft . Consultado el 1 de julio de 2018. Archivado desde el original el 1 de julio de 2018.
  9. Instalación bajo demanda | Documentos de Microsoft . Consultado el 1 de julio de 2018. Archivado desde el original el 1 de julio de 2018.

Enlaces