guides:reference:database:database_replication
                Differences
This shows you the differences between two versions of the page.
| Both sides previous revisionPrevious revisionNext revision | Previous revision | ||
| guides:reference:database:database_replication [2021/02/11 09:09] – [Pre conditions] bdorlandt | guides:reference:database:database_replication [2024/07/03 12:31] (current) – external edit 127.0.0.1 | ||
|---|---|---|---|
| Line 1: | Line 1: | ||
| + | ====== Database Replication ====== | ||
| + | |||
| + | On deployments using two YCE servers or more, two YCE databases can be setup using master-master replication. This setup offers redundancy with instant fail over capabilities. Although the installation always creates a master-master configuration, | ||
| + | |||
| + | ===== Pre conditions ===== | ||
| + | * It is assumed you already have cloned the primary server or set up a new one. | ||
| + | * If you have installed a new system (VM), make sure that the [[maintenance: | ||
| + | * You've followed the [[maintenance: | ||
| + | ===== Configuration ===== | ||
| + | |||
| + | At installation time, the capabilities and database relationships are defined on a per-server basis. The script ''/ | ||
| + | |||
| + | Invoking the script with the '' | ||
| + | ==== sample session ==== | ||
| + | |||
| + | In the sample session below, yce_setup.pl is used to add a second YCE system to an existing server. Both YCE systems support databases and font-end services, using their local databases as primary, an the other server databases as secondary. | ||
| + | |||
| + | A setup where the the database(s) are installed on dedicated YCE servers instead of shared front-end and database roles is fully supported and setup in the same fashion. | ||
| + | |||
| + | > Note 1: It is essential that each database is assigned its own unique id. The default is ' | ||
| + | |||
| + | > Note 2: NetYCE supports " | ||
| + | |||
| + | < | ||
| + | $ yce_setup.pl | ||
| + | Starting ' | ||
| + | Read yce setup: '/ | ||
| + | Read network setup: '/ | ||
| + | YCE servers currently in setup: | ||
| + | #  Hostname | ||
| + | * 0) genie            172.17.10.21 | ||
| + | Select the server# to Remove, or ' | ||
| + | Add new server | ||
| + | Hostname for new server? specter | ||
| + | Domain name for new server? netyce.org | ||
| + | IP-address for new server? 172.17.10.20 | ||
| + | YCE servers currently in setup: | ||
| + | #  Hostname | ||
| + | * 0) genie            172.17.10.21 | ||
| + | 1) specter | ||
| + | Select the server# to Remove, or ' | ||
| + | YCE server roles: | ||
| + | #  Hostname | ||
| + | * 0) genie            yes          http    non-root | ||
| + | 1) specter | ||
| + | Select the server# to change, ' | ||
| + | ' | ||
| + | ' | ||
| + | ' | ||
| + | ' | ||
| + | ' | ||
| + | Database-id for this database (1/2)? [1] 2 | ||
| + | YCE server roles: | ||
| + | #  Hostname | ||
| + | * 0) genie            yes          http    non-root | ||
| + | 1) specter | ||
| + | Select the server# to change, ' | ||
| + | YCE server database mapping: | ||
| + | #  Hostname | ||
| + | * 0) genie 1 genie specter | ||
| + | 1) specter | ||
| + | Select the server# to change, ' | ||
| + | Wiki setup: | ||
| + | ' | ||
| + | |||
| + | # | ||
| + | # YCE Server overview: | ||
| + | # Name | ||
| + | # ---- | ||
| + | # genie        netyce.org | ||
| + | # specter | ||
| + | # | ||
| + | |||
| + | Create the YCE, httpd, and mysql configuration files for the desired systems | ||
| + | each will be created in / | ||
| + | * 0)  ' | ||
| + | 1)  ' | ||
| + | Select server# to create, ' | ||
| + | |||
| + | Updating ' | ||
| + | Updating ' | ||
| + | Updating ' | ||
| + | Restarting ' | ||
| + | Restarting ' | ||
| + | Restarting ' | ||
| + | Restarting ' | ||
| + | |||
| + | Done | ||
| + | </ | ||
| + | |||
| + | ==== xml setup file ==== | ||
| + | |||
| + | The '' | ||
| + | |||
| + | The file created by the sample yce_setup session above resulted in: | ||
| + | |||
| + | <code xml> | ||
| + | < | ||
| + | < | ||
| + | <configs crontab=" | ||
| + | <daemons yce_ibd=" | ||
| + | </ | ||
| + | <yce name=" | ||
| + | < | ||
| + | <host domainname=" | ||
| + | <httpd mode=" | ||
| + | <net ipv4=" | ||
| + | <roles database=" | ||
| + | <wiki domain=" | ||
| + | <yce_db primary_db=" | ||
| + | </ | ||
| + | <yce name=" | ||
| + | < | ||
| + | <host domainname=" | ||
| + | <httpd mode=" | ||
| + | <net ipv4=" | ||
| + | <roles database=" | ||
| + | <yce_db primary_db=" | ||
| + | </ | ||
| + | </ | ||
| + | </ | ||
| + | |||
| + | ===== Install a replicating database (server) ===== | ||
| + | |||
| + | Once both (database) systems are defined and activated (a running MySql or MariaDB server), the YCE database must be installed on these servers in such a way that the master-master replication can be initialized. | ||
| + | |||
| + | This is accomplished using the YCE front-end. The " | ||
| + | |||
| + | The "**Db archives**" | ||
| + | |||
| + | There are a few reasons why the ' | ||
| + | o First time setup of a replicating database \\ | ||
| + | o Non-recoverable Synchronization failure. | ||
| + | |||
| + | After a system crash, networking problem or database corruption one or both YCE databases may report (System status) that the databases are out-of-sync and cannot be automatically resolved or the backlog is too large. In that case, the YCE application manager needs to determine which database should be considered leading. Normally it is quite evident that one database lags the other due to the synchronisation problem. Then proceed to the ' | ||
| + | |||
| + | > Note: See the paragraph on " | ||
| + | |||
| + | With the desired archive located or created, the procedure to install these archives and initiate the synchronization is as follows: | ||
| + | |||
| + | - Ensure no active users are making modifications to the database(s). | ||
| + | - Create a database backup of the primary server | ||
| + | - Download the ' | ||
| + | - Upload the ' | ||
| + | - On both systems, disable and stop the ' | ||
| + | - Restore the ' | ||
| + | - From the " | ||
| + | - Verify if the synchronization status is " | ||
| + | |||
| + | **Notes** | ||
| + | * It is normal to be forced to logout and re-login after a database restore because the current session cookie cannot be verified in the restored database. | ||
| + | * The skulker process is automatically re-enabled after restoring a database. | ||
| + | * Make sure to initially copy local modified files if these are being used, e.g. csv_api.ini, | ||
| + | |||
| + | <color orange> Please consult the [[menu: | ||
| + | The “System status” tool is described in the  [[menu: | ||
| + | ===== Repairing table data ===== | ||
| + | |||
| + | If it is suspected that there are (extensive) differences between two out-of-sync databases that need to be resolved before one database can be defined the ' | ||
| + | |||
| + | It allows for table-by-table, | ||
| + | |||
| + | < | ||
| + | $ ck_dbsync.pl -h | ||
| + | Compare data between synced YCE databases | ||
| + | usage: / | ||
| + | options -x -s | ||
| + | -x -c | ||
| + | -x -k [-r] [-t table_name] | ||
| + | -x -u [-r] [-T] [-t table_name] | ||
| + | -x -L [-r] | ||
| + | -x -F [-r] | ||
| + | -x -R | ||
| + | -x -Q | ||
| + |  | ||
| + |  | ||
| + |  | ||
| + |  | ||
| + |  | ||
| + |  | ||
| + | -t table  table-name only. Use ' | ||
| + |  | ||
| + |  | ||
| + |  | ||
| + |  | ||
| + | of the various options for both databases (-F, -uT, -L, -F). | ||
| + |  | ||
| + | of the various options for both databases (-F, -k, -L, -F). | ||
| + |  | ||
| + | |||
| + | The ' | ||
| + | </ | ||
| + | |||
| + | On larger tables the processing is time consuming (e.g. 20 minutes) and cpu intensive (e.g. 95% cpu for mysqld). So it is best not performed during production hours. | ||
| + | |||
| + | It is highly recommended to create a manual backup archive of the databases (yes, both) before using the ' | ||
| + | |||
| + | When using the update option ('' | ||
| + | |||
| + | In general, when using this tool to update tables, the resulting database should afterwards be re-installed for synchronization using the above procedure. Alternatively the ck_dbsync tool can be used to reset the replication | ||
| + | log files and administration using its '' | ||
| + | |||
| + | This tool also logs all actions in the file ''/ | ||
| + | |||
| + | > Please consult the page [[guides: | ||
| + | |||
| + | ===== Change Replication Schema ===== | ||
| + | |||
| + | The replication schema is based on a setup where the database servers are both a Master and a Slave. SQL UPDATE and INSERT statements executed on one database are forwarded to the other (the master function) where the SQL statement in turn is executed as well (the slave function). If both databases do this properly, the databases stay in sync. | ||
| + | |||
| + | The technical implementation involves ' | ||
| + | |||
| + | To create and process the binlogs, each database server has a configuration what databases and tables to replicate. | ||
| + | This configuration is maintained in the mysql configuration file, '' | ||
| + | |||
| + | The relevant section is shown below: | ||
| + | |||
| + | < | ||
| + | # Replication Master Server | ||
| + | # binary logging is required for replication | ||
| + | log-bin = mysql-bin | ||
| + | binlog-ignore-db = alerts | ||
| + | |||
| + | # use no checksums when replicating against pre-5.6 versions | ||
| + | # binlog-checksum = none | ||
| + | |||
| + | # Replication Slave | ||
| + | replicate-wild-do-table = YCE.% | ||
| + | replicate-wild-do-table = NMS.% | ||
| + | replicate-wild-do-table = NCCM.% | ||
| + | replicate-wild-do-table = CMDB.% | ||
| + | replicate-ignore-db = mysql | ||
| + | replicate-ignore-db = alerts | ||
| + | </ | ||
| + | |||
| + | If (permanent) changes need to be made to the replication it should be done by editing this configuration file. | ||
| + | The entries like '' | ||
| + | |||
| + | It is essential that the replication setup of both servers are identical! Changes made on one server should be copied on the other. | ||
| + | |||
| + | The change becomes effective when the mysql server is restarted. | ||
| + | |||
| + | < | ||
| + | yce@yceseven / | ||
| + | $ go restart mysql | ||
| + | restarting Daemon ' | ||
| + | mysqld: 28544 28738 | ||
| + | kill: / | ||
| + | wait stop ' | ||
| + | spawn: / | ||
| + | wait start ' | ||
| + | done | ||
| + | </ | ||
| + | |||
| + | |||
| + | Since the ''/ | ||
| + | |||
| + | This requires a small alteration of the configuration file ''/ | ||
| + | The example below shows the top section: | ||
| + | |||
| + | <code xml> | ||
| + | < | ||
| + | < | ||
| + | <configs crontab=" | ||
| + | <daemons vsftpd=" | ||
| + | </ | ||
| + | </ | ||
| + | |||
| + | The modification consists of changing '' | ||
| + | |||
| + | <code xml> | ||
| + | < | ||
| + | < | ||
| + | <configs crontab=" | ||
| + | <daemons vsftpd=" | ||
| + | </ | ||
| + | </ | ||
| + | |||
| + | |||
| + | ===== Temp Change Replication Schema ===== | ||
| + | |||
| + | The above directions serve to make permanent changes to the replication schema. It is also possible to briefly change | ||
| + | it. These directions follow below. Keep in mind though, the change is lost when the mysql process is stopped. This regularly happens daily for a maintenance backup between 23:00 and 24:00. | ||
| + | |||
| + | >> The required mysql superuser password will not be shared here. Please contact a technical NetYCE representative to obtain it. | ||
| + | |||
| + | Execute the steps below using the NetYCE functional account, '' | ||
| + | These steps illustrate to remove the NCCM and CMDB databases from the replication schema. | ||
| + | |||
| + | < | ||
| + | yce@yceseven / | ||
| + | $ mysql -u netYCE -p | ||
| + | Enter password: | ||
| + | Welcome to the MariaDB monitor. | ||
| + | Your MariaDB connection id is 12302 | ||
| + | Server version: 10.0.32-MariaDB MariaDB Server | ||
| + | |||
| + | Copyright (c) 2000, 2017, Oracle, MariaDB Corporation Ab and others. | ||
| + | |||
| + | Type ' | ||
| + | |||
| + | MariaDB [(none)]> | ||
| + | </ | ||
| + | |||
| + | |||
| + | < | ||
| + | MariaDB [(none)]> | ||
| + | *************************** 1. row *************************** | ||
| + |  | ||
| + | Master_Host: | ||
| + | Master_User: | ||
| + | Master_Port: | ||
| + | Connect_Retry: | ||
| + | ::: | ||
| + | Replicate_Ignore_DB: | ||
| + |  | ||
| + |  | ||
| + | Replicate_Wild_Do_Table: | ||
| + | Replicate_Wild_Ignore_Table: | ||
| + | ::: | ||
| + | 1 row in set (0.00 sec) | ||
| + | </ | ||
| + | |||
| + | |||
| + | < | ||
| + | MariaDB [(none)]> | ||
| + | Query OK, 0 rows affected, 1 warning (0.00 sec) | ||
| + | </ | ||
| + | |||
| + | |||
| + | |||
| + | < | ||
| + | MariaDB [(none)]> | ||
| + | Query OK, 0 rows affected (0.00 sec) | ||
| + | </ | ||
| + | |||
| + | |||
| + | < | ||
| + | MariaDB [(none)]> | ||
| + | *************************** 1. row *************************** | ||
| + |  | ||
| + | Master_Host: | ||
| + | Master_User: | ||
| + | Master_Port: | ||
| + | Connect_Retry: | ||
| + | ::: | ||
| + | Replicate_Ignore_DB: | ||
| + |  | ||
| + |  | ||
| + | Replicate_Wild_Do_Table: | ||
| + | Replicate_Wild_Ignore_Table: | ||
| + | ::: | ||
| + | 1 row in set (0.00 sec) | ||
| + | </ | ||
| + | |||
| + | |||
| + | |||
| + | < | ||
| + | MariaDB [(none)]> | ||
| + | Query OK, 0 rows affected (0.00 sec) | ||
| + | </ | ||
| + | |||
| + | |||
| + | |||
| + | < | ||
| + | MariaDB [(none)]> | ||
| + | Bye | ||
| + | yce@yceseven / | ||
| + | $ | ||
| + | </ | ||
| + | |||
