DCImanager 6

Migration from DCImanager 5 to DCImanager 6

Migration allows you to transfer settings and equipment from the DCImanager 5 control panel to the DCImanager 6 platform. Migration is performed semi-automatically from the console of the server with DCImanager 6. Migration from one or more DCImanager 5 control panels is possible.

If DCImanager 5 has integration with BILLmanager configured, the tariffs and services of dedicated servers will be automatically transferred to the DCImanager 6 processing module.

Migration stages:

  1. Software preparation — DCImanager 5, DCImanager 6, IPmanager 5, BILLmanager.
  2. Migration of address space — IP addresses, pools and networks used.
  3. Migration of DCImanager 5 objects — users, equipment, connection settings, VLANs, warehouses.
  4. Editing BILLmanager settings.
Note

During migration the following will not be moved:

  • test switches and Dummy-type PDUs;
  • switches and PDUs with user processing modules;
  • users with the Operator role.

Software preparation

DCImanager 5

  1. In the settings of all servers, switches, and PDUs specify the racks and units in which these devices are located.
  2. In the settings of all blade servers, specify the chassis units in which these servers are located.
  3. Create a temporary user for the integration. When creating, specify:
    1. Administrator access level.
    2. Number of records — not less than the number of equipment of each type in the warehouse. For example, if there are 5600 disks in the warehouse, the value must be at least 5600.
  4. Generate a one-time authorization key:
    1. Connect to the server with DCImanager 5 via SSH with superuser permissions.
    2. Run the command:

      /usr/local/mgr5/sbin/mgrctl -m dcimgr session.newkey username=<integration_user> key=<secret_key>
      Comments to the command
    3. Save the key value. 

      Note
      You can only log in with this key once. To migrate again, the key must be generated anew.
  5. Create a temporary database user and allow it access to the user table:
    1. Open access to MySQL.
      Commands for CentOS 7:

      firewall-cmd --new-zone=migration-mysql --permanent
      firewall-cmd --reload
      firewall-cmd --zone=migration-mysql --add-source=<IP address> --permanent
      firewall-cmd --zone=migration-mysql --add-port=3306/tcp --permanent
      firewall-cmd --reload
      
      Comments to the commands
    2. Create a temporary user with read-only access:

      1. Go to the database console:

        mysql
      2. Run the commands:

        CREATE USER '<user>'@'localhost' IDENTIFIED BY '<password>';
        CREATE USER '<user>'@'%' IDENTIFIED BY '<password>';
        GRANT SELECT, SHOW VIEW ON dcimgr.users TO '<user>'@'localhost';
        GRANT SELECT, SHOW VIEW ON dcimgr.users TO '<user>'@'%';
        FLUSH PRIVILEGES;
        Comments to the commands

DCImanager 6

  1. Create a platform backup.
  2. Create and configure the location.
  3. Load the necessary OS templates.
  4. Install and configure the necessary modules.
  5. If the Integration with IPmanager 6 module is installed but not configured in the platform, delete it.

IPmanager 5

  1. Make sure that IPmanager 5 uses a MySQL or MariaDB DBMS. If IPmanager 5 is using SQLite DBMS, switch to the use of MySQL DBMS. Read more in Usage of MySQL as a DBMS (database management system) in the IPmanager documentation.

    Note
    Recommended MySQL/MariaDB version is at least 5.5.x. For earlier versions, the successful import of VMs is not guaranteed.
  2. Open access to the MySQL server from the DCImanager 6 side. To do this, allow connections on ports 3306/TCP, 3306/UDP and remote connections to the database:
    1. Connect to the server with IPmanager 5 via SSH with superuser permissions.
    2. Check the current firewall settings:

      firewall-cmd --list-all
    3. Open ports 3306/TCP, 3306/UDP:

      firewall-cmd --permanent --add-port=3306/tcp
      firewall-cmd --permanent --add-port=3306/udp
    4. Restart the firewall service:

      service firewalld restart
    5. Open the MySQL configuration file /etc/my.cnf. Under [mysqld], add the parameter bind-address=<IP address of the server with IPmanager 5> and comment the line with the parameter skip-networking.
    6. Connect to mysql service:

      mysql -u root
      use mysql;
    7. Allow the user to connect to MySQL remotely:

      GRANT ALL PRIVILEGES ON <db_name> . * TO '<db_user>'@'<remote_ip>' IDENTIFIED BY '<db_password>';
      Comments
      FLUSH PRIVILEGES;

BILLmanager

  1. Create the DCImanager 6 processing module.
  2. Create a temporary user to configure the integration. When creating, enable the Full access privileges option.

    Note
    Do not use the root account to set up the integration.
  3. Generate a one-time authorization key:
    1. Connect to the server with BILLmanager via SSH with superuser permissions.
    2. Run the command:

      /usr/local/mgr5/sbin/mgrctl -m billmgr session.newkey user=<integration_user> key=<secret_key>
      Comments to the command
    3. Save the key value.

      Note
      You can only log in with this key once. To migrate again, the key must be generated anew.
  4. Create a backup of BILLmanager.
  5.  If BILLmanager has services with the Server type option, they should be disabled. To do this:
    1. Connect to the server with BILLmanager via SSH with superuser permissions.
    2. Go to the database console:

      mysql
    3. Select the billmgr database:

      USE billmgr;
    4. Determine the id of the DCImanager 5 processing module:

      SELECT id FROM processingmodule WHERE name='<DCI5_processing_module_name>';
      Comments
    5. Determine if the service processing module has the Server type option:

      SELECT id FROM processingparam pp WHERE pp.processingmodule=<DCI5_processing_module_id> AND pp.intname='use_configuration' AND pp.value='on';
      Comments
    6. If the reply to the previous command contains the service id, disable the option:

      UPDATE processingparam pp SET pp.value='off' WHERE pp.processingmodule=<DCI5_processing_module_id> AND pp.intname='use_configuration' AND pp.value='on';
      Comments

Address space transfer

DCImanager 5 and DCImanager 6 use different software to manage the address space:

  • DCImanager 5 uses the IPmanager 5 control panel;
  • DCImanager 6 uses the built-in IPmanager 6 module.

To perform the migration, you need to import an address space from IPmanager 5 into IPmanager 6.

IPmanager 6 supports IPmanager 5 API emulation mode. If you are using other software products that require integration with IPmanager 5 (for example, BILLmanager, VMmanager 5, ISPmanager), you can configure them to work with IPmanager 6.

Example of address space management

If DCImanager 6 has integration with external IPmanager 6, the data must be imported into the platform that acts as the master. Read more in the article Integration with IPmanager 6 module.

If you are using VMmanager 6 as the master, import the data according to the instructions in the VMmanager 6 documentation. If VMmanager 6 uses the Integration with DNSmanager 6 module, you do not need to install the same module in DCImanager 6.

Data import

To import address space data:

  1. Create a user on the server with IPmanager 5 for integration. All types of addresses to be migrated must be available to the user. Read more about address types in Manage the groups of IP addresses.
  2. Connect to the server with DCImanager 6 via SSH with superuser permissions.
  3. Run the command:

    docker exec -it dci_ipmgr_1 /opt/ispsystem/ipmgr/bin/mgr5import --dbhost <db_ip> --dbname <db_name> --dbuser <db_user> --dbpassword <db_pass> --user <ipmgr_user>
    Comments to the command
    Optional command parameters

    Example of command output

    Container names may differ depending on the used version of Docker Compose. A hyphen may be used instead of the underscore character in container names.

The command logs are written to the /var/log/ipmgr5_import.log file in the dci_ipmgr_1 container on the server with DCImanager 6.

Integration of control panels with IPmanager 6

To switch control panels that were integrated with IPmanager 5 to IPmanager 6:

  1. Create an administrator account in DCImanager 6 named ipmgr5@example.com.

    Note
    ipmgr5@example.com is not an example, but the exact name you need to specify when creating an account.
  2. If the control panel to be connected should only have access to a certain pool of IP addresses, create a pool in DCImanager 6 with the public suffix. For example, DCI5_public.
  3. In the control panel to be connected:
    1. Enter IntegrationIPmanager.
    2. Specify the settings for integration:
      1. IPmanager URL — https://domain.com/api/ipmgr5/v3/ipmgr.

        Comments to the URL
      2. Username:

        • to allow the control panel to access only a certain pool of IP addresses, specify pool_XXX;

          Comments
        • to allow the control panel to access the entire address space, specify an arbitrary username.
      3. Password — password of the ipmgr5@example.com user.
    3. Press Ok.

Synchronization of PTR records

If DCImanager 6 has integration with DNSmanager 6, you need to synchronize PTR records with the DNS server after the address space is created. To do this:

  1. Delete the DNSmanager 6 integration module: Settings → Modules → Integration with DNSmanager 6 → Delete module → Delete module.
  2. Reinstall and configure the integration module. Read more in Integration with DNSmanager 6 module.

The synchronization logs are written to the /var/log/dns_proxy_integration.log file in the dci_dns_proxy_1 container on the server with DCImanager 6.

Container names may differ depending on the used version of Docker Compose. A hyphen may be used instead of the underscore character in container names.

Migration of DCImanager 5 objects

How it works

The migration consists of two steps:

  1. Exporting data from DCImanager 5 to a json file.
  2. Importing data from a file into the DCImanager 6 platform.

You can migrate all DCImanager 5 objects together or each type individually. A separate file is created for each type of object during migration. For example, a server.json file is created for servers. This allows, in case of any problems, to correct the data in the file manually and repeat the migration.

Note
Before each run of the migration script, you must recreate the authorization key in DCImanager 5.

If you are migrating each type of object separately, perform the migration in the following order:

  1. Users.
  2. Equipment:
    1. Racks and platforms.
    2. Switches, PDUs, UPS.
    3. Chassis.
    4. Servers.
  3. User VLANs.
  4. Warehouses:
    1. Suppliers and supplies.
    2. Switches, PDUs, UPS, types of equipment, servers.
    3. Components.

    Usernames

    Usernames will be changed during migration:

    • if DCImanager 5 has integration with BILLmanager, the username will be replaced with the server owner's email;
    • If integration with BILLmanager is not configured, @dci5.imported suffix will be added to the username. This change is due to limitations of the DCImanager 6 platform. The format of an email address is mandatory as a user ID. 

    Hard disk models

    Based on the hard disk model from DCImanager 5, a model of drives with the same name in the DCImanager 6 directory will be created. Based on the "Type" field, the "Alias for configuration" and "Size, GB" fields will be generated. If the model name is not specified in DCImanager 5, the value from the "Type" field will be used as the name.

    RAM models

    Based on the RAM model from DCImanager 5, a RAM model with a similar name in the DCImanager 6 directory will be created. Based on the "Type" field, the "RAM size" and "Frequency" fields will be generated. The memory capacity unit will be changed from mebibyte to gigabyte. If the model name is not specified in DCImanager 5, the value from the "Type" field will be used as the name.

    Migration of id

    To migrate equipment id from DCImanager 5, add a custom parameter named old_id to the required equipment types in DCImanager 6. During migration, the equipment id will be written to the created parameter. Read more about creating a parameter in the article Custom equipment parameters.

    Starting the migration

    To start the migration:

    1. Connect to the server with DCImanager 6 via SSH with superuser permissions.
    2. Enter the migrator container:

      docker exec -it migrator bash
    3. Go to the service directory:

      cd /opt/ispsystem/migrate
    4. Create configuration files for migration based on the export_settings.example.yaml and import_settings.example.yaml templates.

      Example of file for export
      action: export
      platform: dci5
      data: 
        - user
        - rack
        - platform
        - switch
        - server
      transport:
        - type: dci5_http
          address: https://10.1.1.1:1500
          key: my_secret_key
        - type: dci5_db
          host: 10.1.1.1
          port: 3306
          user: migrator
          password: migrator_password
          db: dcimgr
      location: 1
      format: json
      debug: false
      log_file: /var/log/migrate.log
      report_file: export_report_{datetime}.txt
      report_view: plain
      
      Example of file for import
      action: import
      platform: dci6
      data:
        - all
      transport:
        - type: dci6_http
        - type: dci6_auth_http
      location: 1
      format: json
      debug: false
      log_file: /var/log/migrate.log
      report_file: import_report_{datetime}.txt
      report_view: plain
      Comments


    5. Run the script to export data:

      python3 migrator.py -p export_settings.yaml
      Comments
    6. If the data was exported successfully, run the script to import the data:

      python3 migrator.py -p import_settings.yaml
      Comments

    Migration logs are written to the /var/log/migrate.log file in the migrator container on the server with DCImanager 6. The migration report is saved to the file specified in the report_file parameter of the migration configuration file.

    Repeat migration

    If migration failed or if DCImanager 5 configuration changed during the migration, you can perform the migration again:

    1. Restore DCImanager 6 from a backup.
    2. Create a one-time key for authorization in DCImanager 5.
    3. Correct the export and import configuration files.
    4. Run the migration script.

    What to do after migration

    1. Examine the report and make sure the migration was successful.
    2. Open the platform interface and check if the following are correct:
      1. Migration of all platform objects.
      2. Allocation of IP addresses to servers.
      3. interaction with switches and PDUs.
      4. Settings of connections to switches and PDUs.

    Changing BILLmanager settings

    If DCImanager 5 has integration with BILLmanager, you can transfer services to the DCImanager 6 processing module. During migration:

    1. For all tariffs that run on the selected DCImanager 5 processing module, the DCImanager 6 processing module will be enabled and the internal configuration for the order will be changed.
    2. An account in DCImanager 6 will be created for each DCImanager 5 user:

      • username — the email specified in BILLmanager;
      • password — the password specified in the dedicated server service.

        Note
        If the user changes the password in DCImanager 5 after ordering the server, the password will be restored to the original password. The user will still be able to enter DCImanager 6 via the BILLmanager interface. In the future, the user will be able to restore the password via email.


    3. The following will be changed in all open and stopped dedicated server services:
      • username — to the user's email from DCImanager 6;
      • server id — to the id from DCImanager 6;
      • service processing module — to DCImanager 6.

    If BILLmanager has a server colocation service, the following will be performed during the migration:

    1.   The DCImanager 6 processing module will be connected to the colocation tariffs.
    2.   The below parameters will be changed in all open and stopped colocation services:
      • username — to the user's email in BILLmanager;
      • server and rack id — to the id in DCImanager 6; 

         Server search in DCImanager 6 will be performed by its name in the BILLmanager service, not by its id.


      • service processing module — to DCImanager 6.
    3. The user who has the same email address as the user in BILLmanager will become the owner of the server in DCImanager 6. If this user does not exist, it will be created automatically with a random password.
    4. The DCImanager 5 processing module will be disabled for the colocation tariffs.

    Starting the migration

    To start the migration:

    1. Connect to the server with DCImanager 6 via SSH with superuser permissions.
    2.  Enter the migrator container:

      docker exec -it migrator bash
    3.  Go to the service directory:

      cd /opt/ispsystem/migrate
    4. Create a configuration file for the migration based on the template bill_migrate.example.yaml.

      Example of configuration file
      from_modules:
       - dci5_processing_module_1
       - dci5_processing_module_2
      to_module: dci6_processing_module
      admin_name: temp_admin
      transport:
       - type: dci6_http
       - type: dci6_auth_http
       - type: bill_http
         address: https://10.1.1.2:1500
         key: my_secret_key
      debug: false
      log_file: /var/log/bill_migrate.log
      report_file: bill_migrate_report_{datetime}.txt
      report_view: plain
      Comments
    5. To check if the migration is possible, run the script in "read-only" mode:

      python3 bill_migrator.py -p bill_migrate.yaml -r
      Comments

      In this mode, the script does not perform real actions, but only checks the possibility of migration.

    6. If the report has no errors, re-generate a one-time key in BILLmanager and run the actual migration:

      python3 bill_migrator.py -p bill_migrate.yaml
      Comments

    Migration logs are written to the /var/log/bill_migrate.log file in the migrator container on the server with DCImanager 6. The migration report is saved to the file specified in the report_file parameter of the migration configuration file.

    Repeat migration

    If the migration failed or if the BILLmanager configuration changed during the migration, you can perform the migration again:

    1. Create a one-time key for authorization in BILLmanager.
    2. Correct the configuration file.
    3. Run the migration script.

    What to do after migration

    1. Examine the report and make sure the migration was successful.
    2. Check if the tariffs are configured correctly. For example, perform a test server order.
    3. Check if DCImanager 6 has OS templates used in the tariffs.
    4. Remove all temporary users with the @dci5.imported suffix from DCImanager 6. Before deleting, make sure that these users do not own the servers.
    5. Remove the DCImanager 5 processing module:
      1. Connect to the server with BILLmanager via SSH with superuser permissions.
      2. Go to the database console:

        mysql
      3. Select the billmgr database:

        USE billmgr;
      4. Determine the id of the DCImanager 5 processing module:

        SELECT id FROM processingmodule WHERE name='<DCI5_processing_module_name>';
        Comments
      5. Remove the binding of IP addresses to IPmanager and the DCImanager 5 processing module:

        UPDATE ip SET ipmgr=NULL, processingmodule=NULL WHERE processingmodule=<DCI5_processing_module_id>;
        Comments
      6. Delete the processing module in the BILLmanager interface.