Configuración de OSGi para Adobe Experience Manager as a Cloud Service

NOTA

AEM ha introducido la capacidad de utilizar la interfaz de usuario de Cloud Manager para configurar variables de entorno estándar con la versión 2021.12.0. Para obtener más información, consulte la documentación here.

OSGi es un elemento fundamental de la pila tecnológica de Adobe Experience Manager (AEM). Se utiliza para controlar los paquetes compuestos de AEM y sus configuraciones.

OSGi proporciona los primitivos estandarizados que permiten construir aplicaciones a partir de componentes pequeños, reutilizables y colaborativos. Estos componentes se pueden componer en una aplicación e implementar. Esto permite una administración sencilla de los paquetes OSGi, ya que se pueden detener, instalar e iniciar individualmente. Las interdependencias se gestionan automáticamente. Cada componente OSGi está contenido en uno de los distintos paquetes. Para obtener más información, consulte la Especificación de OSGi.

Puede administrar los ajustes de configuración de los componentes de OSGi a través de archivos de configuración que formen parte de un proyecto de código AEM.

Archivos de configuración OSGi

Los cambios de configuración se definen en los paquetes de código del proyecto de AEM (ui.apps) como archivos de configuración (.cfg.json) en carpetas de configuración específicas del modo de ejecución:

/apps/example/config.<runmode>

El formato de los archivos de configuración OSGi se basa en JSON mediante el uso de .cfg.json formato definido por el proyecto Apache Sling.

Las configuraciones de OSGi se dirigen a los componentes de OSGi a través de su Identidad Persistente (PID), que de forma predeterminada es el nombre de clase Java™ del componente OSGi. Por ejemplo, para proporcionar la configuración OSGi para un servicio OSGi implementado por:

com.example.workflow.impl.ApprovalWorkflow.java

un archivo de configuración OSGi se define en:

/apps/example/config/com.example.workflow.impl.ApprovalWorkflow.cfg.json

después de cfg.json Formato de configuración OSGi.

NOTA

Versiones anteriores de AEM archivos de configuración OSGi compatibles que utilizan diferentes formatos de archivo, como .cfg, .config y como XML sling:OsgiConfig definiciones de recursos. Estos formatos se sustituyen por la variable .cfg.json Formato de configuración OSGi.

Resolución del modo de ejecución

SUGERENCIA

AEM 6.x es compatible con modos de ejecución personalizados, pero AEM no lo es. AEM soporte as a Cloud Service y conjunto exacto de modos de ejecución. Cualquier variación en las configuraciones de OSGi entre AEM entornos as a Cloud Service debe manejarse usando Variables de entorno de configuración OSGi.

Las configuraciones de OSGi específicas se pueden dirigir a instancias de AEM específicas mediante modos de ejecución. Para utilizar runmode, cree carpetas de configuración en /apps/example (donde el ejemplo es su nombre de proyecto), en formato:

/apps/example/config.<author|publish>.<dev|stage|prod>/

Se utiliza cualquier configuración OSGi en dichas carpetas si los modos de ejecución definidos en el nombre de la carpeta de configuración coinciden con los modos de ejecución utilizados por AEM.

Por ejemplo, si AEM utiliza los modos de ejecución author y dev, los nodos de configuración en /apps/example/config.author/ y /apps/example/config.author.dev/ , mientras que los nodos de configuración de /apps/example/config.publish/ y /apps/example/config.author.stage/ no se aplican.

Si se aplican varias configuraciones para el mismo PID, se aplica la configuración con el mayor número de modos de ejecución coincidentes.

La granularidad de esta regla se encuentra en el nivel de PID. Esto significa que no puede definir algunas propiedades para el mismo PID en /apps/example/config.author/ y más específicos en /apps/example/config.author.dev/ para el mismo PID. La configuración con el mayor número de modos de ejecución coincidentes será efectiva para todo el PID.

NOTA

A config.preview Carpeta de configuración OSGi cannot se declararán del mismo modo que config.publish se puede declarar como carpeta. En su lugar, el nivel de vista previa hereda su configuración OSGi de los valores del nivel de publicación.

Al desarrollar localmente, un parámetro de inicio de modo de ejecución, -r, se utiliza para especificar la configuración OSGI del modo de ejecución.

$ java -jar aem-sdk-quickstart-xxxx.x.xxx.xxxx-xxxx.jar -r publish,dev

Verificación de los modos de ejecución

AEM modos de ejecución as a Cloud Service están bien definidos según el tipo de entorno y el servicio. Consulte la lista completa de los modos de ejecución as a Cloud Service AEM disponibles.

Los valores de configuración de OSGi especificados por runmode se pueden verificar mediante:

  1. Apertura del AEM como entorno de Cloud Services Developer Console
  2. Selección de los niveles de servicio que se van a inspeccionar mediante el uso de la variable Pod lista desplegable
  3. Al seleccionar la variable Estado ficha
  4. Selección Configuraciones de la variable Volcado de estado lista desplegable
  5. Al seleccionar la variable Obtener estado botón

La vista resultante muestra todas las configuraciones de componentes OSGi para los niveles seleccionados con sus valores de configuración OSGi aplicables. Se puede hacer referencia a estos valores con los valores de configuración OSGi en el código fuente del proyecto de AEM en /apps/example/osgiconfig/config.<runmode(s)>.

Para verificar que se aplican los valores de configuración de OSGi adecuados:

  1. En la salida Configuración de Developer Console
  2. Busque la variable pid representando la configuración OSGi que se va a verificar; este es el nombre del archivo de configuración OSGi en el código fuente del proyecto de AEM.
  3. Inspect la variable properties para pid y compruebe que la clave y los valores coinciden con el archivo de configuración OSGi en el código fuente del proyecto AEM para el modo de ejecución que se está verificando.=

Tipos de valores de configuración de OSGi

Existen tres variedades de valores de configuración OSGi que se pueden utilizar con Adobe Experience Manager as a Cloud Service.

  1. Valores en línea, que son valores que están codificados en la configuración OSGi y almacenados en Git. Por ejemplo:

    {
       "connection.timeout": 1000
    }
    
  2. Valores secretos, que son valores que no deben almacenarse en Git por motivos de seguridad. Por ejemplo:

    {
    "api-key": "$[secret:server-api-key]"
    }
    
  3. Valores específicos de entorno, que son valores que varían entre entornos de desarrollo y, por lo tanto, no se pueden definir con precisión como objetivos del modo de ejecución (ya que hay un solo dev runmode en Adobe Experience Manager as a Cloud Service). Por ejemplo:

    {
     "url": "$[env:server-url]"
    }
    

    Tenga en cuenta que un solo archivo de configuración OSGi puede utilizar cualquier combinación de estos tipos de valores de configuración en conjunto. Por ejemplo:

    {
    "connection.timeout": 1000,
    "api-key": "$[secret:server-api-key]",
    "url": "$[env:server-url]"
    }
    

Cómo elegir el tipo de valor de configuración de OSGi apropiado

El caso común de OSGi utiliza valores de configuración de OSGi en línea. Las configuraciones específicas del entorno se utilizan solo para casos de uso específicos en los que un valor difiere entre entornos de desarrollo.

Las configuraciones específicas del entorno amplían las configuraciones OSGi tradicionales definidas estáticamente que contienen valores en línea, lo que proporciona la capacidad de administrar los valores de configuración OSGi externamente a través de la API de Cloud Manager. Es importante comprender cuándo se debe utilizar el enfoque común y tradicional de definir valores en línea y almacenarlos en Git, en lugar de abstraer los valores en configuraciones específicas del entorno.

Las siguientes directrices tratan sobre cuándo utilizar configuraciones específicas de entorno secreto y no secreto:

Cuándo se deben utilizar los valores de configuración en línea

Los valores de las configuraciones en línea se consideran el enfoque estándar y deben utilizarse cuando sea posible. Las configuraciones en línea proporcionan las ventajas de:

  • Se mantienen, con un gobierno y un historial de versiones en Git
  • Los valores están implícitamente vinculados a las implementaciones de código
  • No requieren ninguna consideración o coordinación de despliegue adicional

Siempre que defina un valor de configuración OSGi, comience con valores en línea y seleccione únicamente configuraciones secretas o específicas del entorno si es necesario para el caso de uso.

Cuándo usar valores de configuración específicos de entornos no secretos

Utilice solo configuraciones específicas del entorno ($[env:ENV_VAR_NAME]) para valores de configuración no secretos cuando los valores varían para el nivel de vista previa o varían entre entornos de desarrollo. Esto incluye instancias de desarrollo locales y cualquier entorno de desarrollo de Adobe Experience Manager as a Cloud Service. Aparte de establecer valores únicos para el nivel de vista previa, evite utilizar configuraciones específicas de entorno no secreto para entornos de fase o producción de Adobe Experience Manager as a Cloud Service.

  • Utilice únicamente configuraciones específicas de entorno no secreto para valores de configuración que difieran entre el nivel de publicación y vista previa, o para valores que difieran entre entornos de desarrollo, incluidas instancias de desarrollo local.
  • Además del escenario en el que el nivel de vista previa necesita variar desde el nivel de publicación, utilice los valores en línea estándar en las configuraciones OSGi para los valores no secretos de fase y producción. En relación con esto, no se recomienda utilizar configuraciones específicas del entorno para facilitar la realización de cambios de configuración en tiempo de ejecución en entornos de fase y producción; estos cambios deben introducirse mediante la administración del código fuente.

Cuándo utilizar valores de configuración específicos de entornos secretos

Adobe Experience Manager as a Cloud Service requiere el uso de configuraciones específicas del entorno ($[secret:SECRET_VAR_NAME]) para cualquier valor de configuración OSGi secreto, como contraseñas, claves de API privadas o cualquier otro valor que no se pueda almacenar en Git por motivos de seguridad.

Utilice configuraciones específicas de entornos secretos para almacenar el valor de secretos en todos los entornos de Adobe Experience Manager as a Cloud Service, incluidos los entornos de fase y producción.

Creación de configuraciones de OSGi

Existen dos maneras de crear configuraciones de OSGi, como se describe a continuación. El método anterior se utiliza generalmente para configurar componentes OSGi personalizados que tienen propiedades y valores OSGi conocidos por parte del desarrollador, y el último para componentes OSGi proporcionados por AEM.

Escritura de configuraciones de OSGi

Los archivos de configuración OSGi con formato JSON se pueden escribir a mano directamente en el proyecto AEM. A menudo, esta es la forma más rápida de crear configuraciones de OSGi para componentes de OSGi conocidos, y especialmente componentes de OSGi personalizados que han sido diseñados y desarrollados por el mismo desarrollador que define las configuraciones. Este método también se puede utilizar para copiar/pegar y actualizar configuraciones para el mismo componente OSGi en varias carpetas de modo de ejecución.

  1. En su IDE, abra el ui.apps proyecto, localizar o crear la carpeta de configuración (/apps/.../config.<runmode>) que se dirige a los modos de ejecución que debe aplicar la nueva configuración de OSGi
  2. En esta carpeta de configuración, cree un <PID>.cfg.json archivo. El PID es la identidad persistente del componente OSGi. Normalmente es el nombre de clase completo de la implementación de componentes OSGi. Por ejemplo:
    /apps/.../config/com.example.workflow.impl.ApprovalWorkflow.cfg.json
    Tenga en cuenta que los nombres de archivo de fábrica de configuración OSGi utilizan la variable <factoryPID>-<name>.cfg.json convención de nomenclatura
  3. Abra el nuevo .cfg.json y defina las combinaciones de clave/valor para los pares de propiedad y valor OSGi, siguiendo el Formato de configuración JSON OSGi.
  4. Guarde los cambios en la nueva .cfg.json file
  5. Añadir y confirmar el nuevo archivo de configuración OSGi en Git

Generación de configuraciones de OSGi mediante el inicio rápido AEM SDK

La consola web AEM del SDK de AEM Quickstart Jar se puede utilizar para configurar componentes OSGi y exportar configuraciones de OSGi como JSON. Esto resulta útil para configurar componentes OSGi proporcionados por AEM, cuyas propiedades OSGi y sus formatos de valor pueden no ser bien entendidos por el desarrollador que define las configuraciones OSGi en el proyecto AEM.

NOTA

La interfaz de usuario de configuración de la consola web de AEM escribe .cfg.json en el repositorio. Por lo tanto, tenga en cuenta esto para evitar un comportamiento inesperado potencial durante el desarrollo local, cuando las configuraciones de OSGi definidas por el proyecto AEM pueden diferir de las configuraciones generadas.

  1. Inicie sesión en la consola web AEM del SDK de AEM Quickstart Jar como usuario administrador
  2. Vaya a OSGi > Configuración
  3. Para configurar, busque el componente OSGi y pulse su título para editar
    Configuración de OSGi
  4. Edite los valores de las propiedades de configuración de OSGi a través de la interfaz de usuario web según sea necesario
  5. Registre la identidad persistente (PID) en un lugar seguro. Esto se utiliza más adelante para generar el JSON de configuración OSGi
  6. Toque Guardar
  7. Vaya a OSGi > Impresora de configuración del instalador OSGi
  8. Pegue en el PID copiado en el paso 5, asegúrese de que el Formato de serialización está establecido en "OSGi Configurator JSON"
  9. Toque Imprimir
  10. La configuración OSGi en formato JSON se mostrará en la sección Propiedades de configuración serializadas
    Impresora de configuración del instalador OSGi
  11. En su IDE, abra el ui.apps proyecto, localizar o crear la carpeta de configuración (/apps/.../config.<runmode>) que se dirige a los modos de ejecución que la nueva configuración de OSGi debe aplicar.
  12. En esta carpeta de configuración, cree un <PID>.cfg.json archivo. El PID es el mismo valor que el del paso 5.
  13. Pegue las propiedades de configuración serializadas del paso 10 en el .cfg.json archivo.
  14. Guarde los cambios en la nueva .cfg.json archivo.
  15. Añada y confirme su nuevo archivo de configuración OSGi en Git.

Formatos de propiedades de configuración de OSGi

Valores en línea

Los valores en línea tienen el formato de pares de nombre-valor estándar, siguiendo la sintaxis estándar JSON. Por ejemplo:

{
   "my_var1": "val",
   "my_var2": [ "abc", "def" ],
   "my_var3": 500
}

Valores de configuración específicos de entorno

La configuración OSGi debe asignar un marcador de posición para la variable que se pretende definir por entorno:

use $[env:ENV_VAR_NAME]

Los clientes solo deben utilizar esta técnica para las propiedades de configuración de OSGi relacionadas con su código personalizado; no debe utilizarse para anular la configuración OSGi definida por el Adobe.

NOTA

Los marcadores de posición no se pueden usar en instrucciones de informe.

Valores de configuración secreta

La configuración OSGi debe asignar un marcador de posición para el secreto que se pretende definir por entorno:

use $[secret:SECRET_VAR_NAME]

Asignación de nombres a variables

Lo siguiente se aplica a los valores de configuración secreta y específica del entorno.

Los nombres de las variables deben seguir las siguientes reglas:

  • Longitud mínima: 2
  • Longitud máxima: 100
  • Debe coincidir con regex: [a-zA-Z_][a-zA-Z_0-9]*

Los valores de las variables no deben superar los 2048 caracteres.

PRECAUCIÓN

Hay reglas relacionadas con el uso de ciertos prefijos para los nombres de las variables:

  1. Nombres de variable con el prefijo INTERNAL_, ADOBE_o CONST_ están reservadas por Adobe. Se ignorará cualquier variable establecida por el cliente que comience con estos prefijos.

  2. Los clientes no deben hacer referencia a las variables con el prefijo INTERNAL_ o ADOBE_ o bien.

  3. Variables de entorno con el prefijo AEM_ el producto los define como API pública que los clientes utilizarán y establecerán.
    Mientras que los clientes pueden utilizar y establecer variables de entorno que empiecen por el prefijo AEM_ no deben definir sus propias variables con este prefijo.

Valores predeterminados

Lo siguiente se aplica a los valores de configuración secreta y específica del entorno.

Si no se establece ningún valor por entorno, durante la ejecución el marcador de posición no se reemplaza y se deja en su lugar porque no se produjo ninguna interpolación. Para evitarlo, se puede proporcionar un valor predeterminado como parte del marcador de posición con la siguiente sintaxis:

$[env:ENV_VAR_NAME;default=<value>]

Con un valor predeterminado proporcionado, el marcador de posición se reemplaza por el valor por entorno si se proporciona o por el valor predeterminado proporcionado.

Desarrollo local

Lo siguiente se aplica a los valores de configuración secreta y específica del entorno.

Las variables se pueden definir en el entorno local para que la AEM local las recopile durante la ejecución. Por ejemplo, en Linux®:

export ENV_VAR_NAME=my_value

Se recomienda escribir una secuencia de comandos bash simple que establezca las variables de entorno utilizadas en las configuraciones y que la ejecute antes de comenzar el AEM. Herramientas como https://direnv.net/ ayuda a simplificar este enfoque. Según el tipo de valores, se pueden registrar en la administración del código fuente si todos los usuarios pueden compartirlos.

Los valores de los secretos se leen a partir de archivos. Por lo tanto, para cada marcador de posición que utilice un secreto se debe crear un archivo de texto que contenga el valor secreto.

Por ejemplo, si $[secret:server_password] se utiliza, un archivo de texto llamado server_password debe crearse. Todos estos archivos secretos deben almacenarse en el mismo directorio y en la propiedad framework org.apache.felix.configadmin.plugin.interpolation.secretsdir debe configurarse con ese directorio local.

Configuración de autor frente a publicación

Si una propiedad OSGi requiere valores diferentes para el autor frente a la publicación:

  • Separar config.author y config.publish Se deben utilizar las carpetas OSGi, tal como se describe en la sección Sección Resolución del modo de ejecución.
  • Hay dos opciones para crear los nombres de variables independientes que deben usarse:
    • la primera opción, que se recomienda: en todas las carpetas OSGi (como config.author y config.publish) declarada para definir valores diferentes, utilice el mismo nombre de variable. Por ejemplo

      $[env:ENV_VAR_NAME;default=<value>], donde el valor predeterminado corresponde al valor predeterminado de ese nivel (autor o publicación). Al configurar la variable de entorno mediante API de Cloud Manager o a través de un cliente, diferencie entre los niveles utilizando el parámetro "service" como se describe en Documentación de referencia de API. El parámetro "service" enlazará el valor de la variable al nivel OSGi apropiado. Puede ser "autor", "publicación" o "previsualización".

    • la segunda opción, que es declarar variables distintas con un prefijo como author_<samevariablename> y publish_<samevariablename>

Ejemplos de configuración

En los ejemplos siguientes, supongamos que hay tres entornos de desarrollo, además de los entornos de ensayo y producción.

Ejemplo 1

La intención es para el valor de la propiedad OSGi my_var1 ser el mismo para stage y prod, pero difieren para cada uno de los tres entornos dev.

Carpeta Contenido de myfile.cfg.json
Configuración
{ "my_var1": "val", "my_var2": "abc", "my_var3": 500 }
config.dev
{ "my_var1" : "$[env:my_var1]" "my_var2": "abc", "my_var3": 500 }

Ejemplo 2

La intención es para el valor de la propiedad OSGi my_var1 para diferir para stage, prod y para cada uno de los tres entornos dev. Por lo tanto, se debe llamar a la API de Cloud Manager para establecer el valor de my_var1 para cada elemento dev env.

Carpeta Contenido de myfile.cfg.json
config.stage
{ "my_var1": "val1", "my_var2": "abc", "my_var3": 500 }
config.prod
{ "my_var1": "val2", "my_var2": "abc", "my_var3": 500 }
config.dev
{ "my_var1" : "$[env:my_var1]" "my_var2": "abc", "my_var3": 500 }

Ejemplo 3

La intención es para el valor de la propiedad OSGi my_var1 ser el mismo para stage, production, y solo uno de los entornos de desarrollo, pero para que difiera para los otros dos entornos de desarrollo. En este caso, se debe llamar a la API de Cloud Manager para establecer el valor de my_var1 para cada entorno de desarrollo, incluido el entorno de desarrollo que debe tener el mismo valor que stage y production. No heredará el valor establecido en la carpeta config.

Carpeta Contenido de myfile.cfg.json
Configuración
{ "my_var1": "val1", "my_var2": "abc", "my_var3": 500 }
config.dev
{ "my_var1" : "$[env:my_var1]" "my_var2": "abc", "my_var3": 500 }

Otra manera de lograr esto sería establecer un valor predeterminado para el token de reemplazo en la carpeta config.dev de manera que sea el mismo valor que en la config carpeta.

Carpeta Contenido de myfile.cfg.json
Configuración
{ "my_var1": "val1", "my_var2": "abc", "my_var3": 500 }
config.dev
{ "my_var1": "$[env:my_var1;default=val1]" "my_var2": "abc", "my_var3": 500 }

Formato de API de Cloud Manager para la configuración de propiedades

Consulte esta página acerca de cómo se debe configurar la API.

NOTA

Asegúrese de que la API de Cloud Manager utilizada haya asignado la función "Administrador de implementación - Cloud Service". Otras funciones no pueden ejecutar todos los comandos siguientes.

Configuración de valores mediante API

Llamar a la API implementa las nuevas variables y valores en un entorno de Cloud, de forma similar a una canalización de implementación de código de cliente típica. Los servicios de autor y publicación se reiniciarán y harán referencia a los nuevos valores, normalmente tardando unos minutos.

PATCH /program/{programId}/environment/{environmentId}/variables
]
        {
                "name" : "MY_VAR1",
                "value" : "plaintext value",
                "type" : "string"  <---default
        },
        {
                "name" : "MY_VAR2",
                "value" : "<secret value>",
                "type" : "secretString"
        }
]
NOTA

Las variables predeterminadas no se establecen mediante API, sino en la propiedad OSGi misma.

Consulte esta página para obtener más información.

Obtención de valores mediante API

GET /program/{programId}/environment/{environmentId}/variables

Consulte esta página para obtener más información.

Eliminación de valores mediante API

PATCH /program/{programId}/environment/{environmentId}/variables

Para eliminar una variable, inclúyala con un valor vacío.

Consulte esta página para obtener más información.

Obtención de valores mediante la línea de comandos

$ aio cloudmanager:list-environment-variables ENVIRONMENT_ID
Name     Type         Value
MY_VAR1  string       plaintext value
MY_VAR2  secretString ****

Configuración de valores mediante la línea de comandos

$ aio cloudmanager:set-environment-variables ENVIRONMENT_ID --variable MY_VAR1 "plaintext value" --secret MY_VAR2 "some secret value"

Eliminación de valores mediante la línea de comandos

$ aio cloudmanager:set-environment-variables ENVIRONMENT_ID --delete MY_VAR1 MY_VAR2
NOTA

Consulte esta página para obtener más información sobre cómo configurar valores utilizando el complemento Cloud Manager para la CLI de Adobe I/O.

Número de variables

Se pueden declarar hasta 200 variables por entorno.

Consideraciones de implementación para valores de configuración secretos y específicos de entorno

Debido a que los valores de configuración específicos de entorno y secreto residen fuera de Git y, por lo tanto, no forman parte de los mecanismos formales de implementación de Adobe Experience Manager as a Cloud Service, el cliente debe administrar, administrar e integrar en el proceso de implementación de Adobe Experience Manager as a Cloud Service.

Como se ha mencionado anteriormente, la llamada a la API implementa las nuevas variables y valores en los entornos de Cloud, de forma similar a una canalización de implementación de código de cliente típica. Los servicios de autor y publicación se reiniciarán y harán referencia a los nuevos valores, normalmente tardando unos minutos. Tenga en cuenta que las puertas de calidad y las pruebas que ejecuta Cloud Manager durante una implementación de código normal no se realizan durante este proceso.

Normalmente, los clientes llaman a la API para establecer variables de entorno antes de implementar un código que dependa de ellas en Cloud Manager. En algunas situaciones, es posible que se desee modificar una variable existente después de que el código ya se haya implementado.

NOTA

Es posible que la API no tenga éxito cuando se está utilizando una canalización, ya sea una actualización de AEM o una implementación de cliente, dependiendo de qué parte de la canalización de extremo a extremo se esté ejecutando en ese momento. La respuesta de error indicará que la solicitud no se realizó correctamente, aunque no indicará el motivo específico.

Puede haber escenarios en los que una implementación programada del código de cliente dependa de variables existentes para tener nuevos valores, lo que no sería apropiado con el código actual. Si esto supone un problema, se recomienda realizar modificaciones de variables de forma aditiva. Para ello, cree nuevos nombres de variables en lugar de cambiar el valor de variables antiguas, de modo que el código antiguo nunca haga referencia al nuevo valor. A continuación, cuando la nueva versión del cliente parezca estable, puede optar por eliminar los valores más antiguos.

Del mismo modo, dado que los valores de una variable no tienen versiones, una reversión del código podría hacer que haga referencia a valores más nuevos que causen problemas. La estrategia de variables aditivas mencionada anteriormente también sería útil aquí.

Esta estrategia de variable aditiva también es útil para escenarios de recuperación ante desastres donde si se necesita reimplementar el código de varios días antes de que se necesite, los nombres y valores de las variables a los que hace referencia seguirán intactos. Esto se basa en una estrategia en la que un cliente espera unos días antes de eliminar esas variables antiguas; de lo contrario, el código anterior no tendría las variables adecuadas a las que hacer referencia.

En esta página