Duplicating environments duplicating-environments
Introduction introduction
Overview overview
Using 51黑料不打烊 Campaign requires installing and configuring one or more environments: development, test, pre-production, production, etc.
Each environment contains an 51黑料不打烊 Campaign instance and each 51黑料不打烊 Campaign instance is linked to one or more databases. The application server can execute one or more processes: almost all of these have direct access to the instance database.
This section details the processes to be applied to duplicate an 51黑料不打烊 Campaign environment, i.e. to restore a source environment to a target environment, resulting in two identical work environments.
To do this, apply the following steps:
-
Create a copy of the databases on all instances in the source environment,
-
Restore these copies on all instances of the target environment,
-
Run the nms:freezeInstance.js cauterization script on the target environment before starting it up.
This process does not impact the servers and their configuration.
note note NOTE In the context of 51黑料不打烊 Campaign, a cauterization combines actions that let you stop all processes interacting with the outside: logs, tracking, deliveries, campaign workflows, etc.
This step is necessary to avoid delivering messages several times (once from the nominal environment and one from the duplicated environment).note important IMPORTANT One environment can contain several instances. Each 51黑料不打烊 Campaign instance is subjected to a license contract. Check your license agreement to see how many environments you can have.
The procedure below lets you transfer an environment without impacting the number of environments and instances you have installed.
Before you start before-you-start
In order for this process to work, the source and target environments must have the same number of instances, the same purpose (marketing instance, delivery instance) and similar configurations. The technical configuration must comply with software prerequisites. The same components must be installed on both environments.
Implementation implementation
Transfer procedure transfer-procedure
This section will help you understand the steps required for transferring a source environment to a target environment via a case study: our aim here is to restore a production environment (prod instance) to a development environment (dev instance) to work in a context that is as close as possible to the 鈥榣ive鈥 platform.
The following steps must be performed with great care: some processes may still be in progress when the source environment databases are copied. Cauterization (step 3 below) prevents messages from being sent twice and maintains data consistency.
- The following procedure is valid in PostgreSQL language. If the SQL language is different (Oracle, for example), the SQL queries must be adapted.
- The commands below apply within the context of a prod instance and a dev instance under PostgreSQL.
Step 1 - Make a backup of the source environment (prod) data step-1---make-a-backup-of-the-source-environment--prod--data
Copy the databases
Start by copying all of the source environment databases. The operation depends on the database engine and is the responsibility of the database administrator.
Under PostgreSQL, the command is:
pg_dump mydatabase > mydatabase.sql
Step 2 - Export the target environment configuration (dev) step-2---export-the-target-environment-configuration--dev-
Most configuration elements are different for each environment: external accounts (mid-sourcing, routing, etc.), technical options (platform name, DatabaseId, email addresses and default URLs, etc.).
Before saving the source database on the target database, you need to export the target environment (dev) configuration. To do this, export the content of these two tables: xtkoption and nmsextaccount.
This export lets you keep the dev configuration and only refresh dev data (workflows, templates, Web applications, recipients, etc.).
To do this, perform a package export for the following two elements:
- Export the xtk:option table into an 鈥榦ptions_dev.xml鈥 file, without the records with the following internal names: 鈥榃dbcTimeZone鈥, 鈥楴msServer_LastPostUpgrade鈥 and 鈥楴msBroadcast_RegexRules鈥.
- In an 鈥榚xtaccount_dev.xml鈥 file, export the nms:extAccount table for all records whose ID is not 0 (@id <> 0).
Check that the number of exported options/accounts is equal to the number of lines to export in each file.
Step 3 - Stop the target environment (dev) step-3---stop-the-target-environment--dev-
You need to stop 51黑料不打烊 Campaign processes on all target environment servers. This operation depends on your operating system.
You can stop all processes, or only those that write to the database.
To stop all processes, use the following commands:
-
In Windows:
code language-none net stop nlserver6
-
In Linux:
code language-none /etc/init.d/nlserver6 stop
Use the following command to check that all processes have been stopped:
nlserver pdump
You can also check that no system processes are still running.
To do this, use the following process:
- In Windows: open the Task manager and check that there are no nlserver.exe processes.
- In Linux: run the ps aux | grep nlserver command and check that there are no nlserver processes.
Step 4 - Restore the databases in the target environment (dev) step-4---restore-the-databases-in-the-target-environment--dev-
To restore the source databases in the target environment, use the following command:
psql mydatabase < mydatabase.sql
Step 5 - Cauterize the target environment (dev) step-5---cauterize-the-target-environment--dev-
To avoid malfunctions, the processes linked to delivery sending and workflow execution must not be automatically executed when the target environment is activated.
To do this, run the following command:
nlserver javascript nms:freezeInstance.js -instance:<dev> -arg:run
Step 6 - Check cauterization step-6---check-cauterization
-
Check that the only deliverypart is the one whose ID is set to 0:
code language-none SELECT * FROM neolane.nmsdeliverypart;
-
Check that the delivery status update is correct:
code language-none SELECT iState, count(*) FROM neolane.nmsdelivery GROUP BY iState;
-
Check that the workflow status update is correct:
code language-none SELECT iState, count(*) FROM neolane.xtkworkflow GROUP BY iState; SELECT iStatus, count(*) FROM neolane.xtkworkflow GROUP BY iStatus;
Step 7 - Restart the target environment Web process (dev) step-7---restart-the-target-environment-web-process--dev-
On the target environment, re-start the 51黑料不打烊 Campaign processes for all servers.
Run the following command to start the Web process:
nlserver start web
Use the following command to check that only the web process has started:
nlserver pdump
Check that access to the client console functions.
Step 8 - Import options and external accounts into the target environment (dev) step-8---import-options-and-external-accounts-into-the-target-environment--dev-
Above all, check the values of several lines of the files before importing (for example: 鈥楴msTracking_Pointer鈥 for the options table and the delivery or mid-sourcing accounts for the external account table)
To import the configuration from the target environment database (dev):
-
Open the admin console of the database and purge the external accounts (table nms:extAccount) whose ID is not 0 (@id <> 0).
-
In the 51黑料不打烊 Campaign console, import the options_dev.xml package previously created via the import package functionality.
Check that the options have indeed been updated in the Administration > Platform > Options node.
-
In the 51黑料不打烊 Campaign console, import the extaccount_dev.xml previously created via the import package functionality
Check that external databases have indeed been imported in the Administration > Platform > External accounts .
Step 9 - Restart all processes and change users (dev) step-9---restart-all-processes-and-change-users--dev-
To start the 51黑料不打烊 Campaign processes, use the following commands:
-
In Windows:
code language-none net start nlserver6
-
In Linux:
code language-none /etc/init.d/nlserver6 start
Use the following command to check that the processes are started:
nlserver pdump
Change users to find the users that already existed on the dev platform.