VOOZH about

URL: https://www.cdata.com/kb/tech/mysql-sync-postgresql.rst

⇱ Automated Continuous MySQL Replication to PostgreSQL


Automated Continuous MySQL Replication to PostgreSQL

πŸ‘ Cameron Leblanc
Cameron Leblanc
Senior Technology Evangelist
Use CData Sync for automated, continuous, customizable MySQL replication to PostgreSQL.

Always-on applications rely on automatic failover capabilities and real-time data access. CData Sync integrates live MySQL data into your PostgreSQL instance, allowing you to consolidate all of your data into a single location for archiving, reporting, analytics, machine learning, artificial intelligence and more.

Configure PostgreSQL as a Replication Destination

Using CData Sync, you can replicate MySQL data to PostgreSQL. To add a replication destination, navigate to the Connections tab.

  1. Click Add Connection. πŸ‘ Add a new connection.
  2. Select the Destinations tab and locate the PostgreSQL connector. πŸ‘ Configure a Destination connection to PostgreSQL.
  3. Click the Configure Connection icon at the end of that row to open the New Connection page. If the Configure Connection icon is not available, click the Download Connector icon to install the PostgreSQL connector. For more information about installing new connectors, see Connections in the Help documentation.
  4. To connect to PostgreSQL, set the following connection properties:
    • Connection Name: Enter a connection name of your choice for the PostgreSQL connection.
    • Server: Enter the host name or IP of the server that hosts the PostgreSQL database. The default server value is localhost.
    • Auth Scheme: Select the authentication scheme. The default auth scheme is Password.
    • Port: Enter the port number of the server that hosts the PostgreSQL database. The default port value is 5432.
    • User: Enter the user ID provided for authentication with the PostgreSQL database.
    • Password: Enter the password provided for authentication with the PostgreSQL database.
    • Database: Enter the name of the database.
  5. πŸ‘ Enter the connection details.
  6. Once connected, click Create & Test to create, test and save the connection.

You are now connected to PostgreSQL and can use it as both a source and a destination.

NOTE: You can use the Label feature to add a label for a source or a destination.

πŸ‘ Add a label.

In this article, we will demonstrate how to load MySQL data into PostgreSQL and utilize it as a destination.

Configure the MySQL Connection

You can configure a connection to MySQL from the Connections tab. To add a connection to your MySQL account, navigate to the Connections tab.

  1. Click Add Connection.
  2. Select a source (MySQL).
  3. Configure the connection properties.

    The CData Provider supports connecting to on-premises and cloud-hosted versions of MySQL such as Amazon RDS for MySQL, Google Cloud SQL for MySQL, Azure Database for MySQL, or Oracle MySQL HeatWave. The Server and Port properties must be set to a MySQL server. If IntegratedSecurity is set to false, then User and Password must be set to valid user credentials. Optionally, Database can be set to connect to a specific database. If not set, tables from all databases will be returned.

    SSH Connectivity for MySQL

    You can use SSH (Secure Shell) to authenticate with MySQL, whether the instance is hosted on-premises or in supported cloud environments. SSH authentication ensures that access is encrypted (as compared to direct network connections).

    SSH Connections to MySQL in Password Auth Mode

    To connect to MySQL via SSH in Password Auth mode, set the following connection properties:

    • User: MySQL User name
    • Password: MySQL Password
    • Database: MySQL database name
    • Server: MySQL Server name
    • Port: MySQL port number like 3306
    • UserSSH: "true"
    • SSHAuthMode: "Password"
    • SSHPort: SSH Port number
    • SSHServer: SSH Server name
    • SSHUser: SSH User name
    • SSHPassword: SSH Password

    SSH Connections to MySQL in Public Key Auth Mode

    To connect to MySQL via SSH in Password Auth mode, set the following connection properties:

    • User: MySQL User name
    • Password: MySQL Password
    • Database: MySQL database name
    • Server: MySQL Server name
    • Port: MySQL port number like 3306
    • UserSSH: "true"
    • SSHAuthMode: "Public_Key"
    • SSHPort: SSH Port number
    • SSHServer: SSH Server name
    • SSHUser: SSH User name
    • SSHClientCret: the path for the public key certificate file
    πŸ‘ Configuring a Source connection (Salesforce is shown).
  4. Click Connect to MySQL to ensure that the connection is configured properly.
  5. Click Save & Test to save the changes.

Configure Replication Queries

CData Sync enables you to control replication with a point-and-click interface and with SQL queries. For each replication you wish to configure, navigate to the Jobs tab and click Add Job. Select the Source and Destination for your replication.

πŸ‘ Select Source and Destination connections for the replication.

Replicate Entire Tables

To replicate an entire table, navigate to the Task tab in the Job, click Add Tasks, choose the table(s) from the list of MySQL tables you wish to replicate into PostgreSQL, and click Add Tasks again.

πŸ‘ Choose entire tables to replicate (Salesforce is shown).

Customize Your Replication

You can use the Columns and Query tabs of a task to customize your replication. The Columns tab allows you to specify which columns to replicate, rename the columns at the destination, and even perform operations on the source data before replicating. The Query tab allows you to add filters, grouping, and sorting to the replication with the help of SQL queries. πŸ‘ Configure a replication Transform.

Schedule Your Replication

Select the Overview tab in the Job, and click Configure under Schedule. You can schedule a job to run automatically by configuring it to run at specified intervals, ranging from once every 10 minutes to once every month.

πŸ‘ Schedule your job to run automatically.

Once you have configured the replication job, click Save Changes. You can configure any number of jobs to manage the replication of your MySQL data to PostgreSQL.

Run the Replication Job

Once all the required configurations are made for the job, select the MySQL table you wish to replicate and click Run. After the replication completes successfully, a notification appears, showing the time taken to run the job and the number of rows replicated.

πŸ‘ Run the job.

Free Trial & More Information

Now that you have seen how to replicate MySQL data into PostgreSQL, visit our CData Sync page to explore more about CData Sync and download a free 30-day trial. Start consolidating your enterprise data today!

As always, our world-class Support Team is ready to answer any questions you may have.