New feature
If you are looking to migrate your database to Neon, you may want to try our new Migration Assistant, which can help. Read the guide to learn more.
Neon's logical replication feature allows you to replicate data from Amazon RDS PostgreSQL to Neon.
Prerequisites
- 
A source database in Amazon RDS for PostgreSQL containing the data you want to replicate. If you're just testing this out and need some data to play with, you can use the following statements to create a table with sample data: CREATE TABLE IF NOT EXISTS playing_with_neon(id SERIAL PRIMARY KEY, name TEXT NOT NULL, value REAL); INSERT INTO playing_with_neon(name, value) SELECT LEFT(md5(i::TEXT), 10), random() FROM generate_series(1, 10) s(i);
- 
A destination Neon project. For information about creating a Neon project, see Create a project. 
- 
Read the important notices about logical replication in Neon before you begin. 
- 
Review our logical replication tips, based on real-world customer data migration experiences. 
- Prepare your source database- This section describes how to prepare your source Amazon RDS Postgres instance (the publisher) for replicating data to Neon. - Enable logical replication in the source Amazon RDS PostgreSQL instance- Enabling logical replication in Postgres requires changing the - wal_levelconfiguration parameter from- replicato- logical. Before you begin, you can check your current setting with the following command:- SHOW wal_level; wal_level ----------- replica (1 row)- note- For information about connecting to RDS from - psql, see Connect to a PostgreSQL DB instance.- If your current setting is - replica, follow these steps to enable logical replication. If you are using the default parameter group, you will need to create a new parameter group to set the value. You can do so by selecting Parameter groups > Create parameter group from the sidebar and filling in the required fields.- To enable logical replication: - 
Navigate to the Configuration tab of your RDS instance. 
- 
Under the Configuration heading, click on the DB instance parameter group link. 
- 
Click Edit. In the Filter parameters search field, search for rds.logical_replication.
- 
Set the value to 1, and click Save Changes.
- 
If you created a new parameter group, navigate back to your RDS instance page, click Modify, and scroll down to select your new parameter group. Click Continue, and select Apply immediately to make the change now, then click Modify DB instance. 
- 
Reboot your instance to apply the new setting. From the Actions menu for your database, select Reboot. 
- 
Make sure that the wal_levelparameter is now set tological:SHOW wal_level; wal_level ----------- logical (1 row)
 - Allow connections from Neon- You need to allow inbound connections to your AWS RDS Postgres instance from Neon. You can do this by editing your instance's CIDR/IP - Inbound security group, which you can find a link to from your AWS RDS Postgres instance page. - 
Click on the security group name. 
- 
Click on the security group ID. 
- 
From the Actions menu, select Edit inbound rules. 
- 
Add rules that allow traffic from each of the IP addresses for your Neon project's region. Neon uses 3 to 6 IP addresses per region for outbound communication, corresponding to each availability zone in the region. See NAT Gateway IP addresses for Neon's NAT gateway IP addresses. 
- 
When you're finished, click Save rules. noteYou can specify a rule for 0.0.0.0/0to allow traffic from any IP address. However, this configuration is not considered secure.
 - Create a publication on the source database- Publications are a fundamental part of logical replication in Postgres. They define what will be replicated. - To create a publication for a specific table: - CREATE PUBLICATION my_publication FOR TABLE playing_with_neon;- To create a publication for multiple tables, provide a comma-separated list of tables: - CREATE PUBLICATION my_publication FOR TABLE users, departments;- note- Defining specific tables lets you add or remove tables from the publication later, which you cannot do when creating publications with - FOR ALL TABLES.- For syntax details, see CREATE PUBLICATION, in the PostgreSQL documentation. 
- 
- Prepare your destination database- This section describes how to prepare your source Neon Postgres database (the subscriber) to receive replicated data from your AWS RDS Postgres instance. - Prepare your database schema- When configuring logical replication in Postgres, the tables in the source database you are replicating from must also exist in the destination database, and they must have the same table names and columns. You can create the tables manually in your destination database or use utilities like - pg_dumpand- pg_restoreto dump the schema from your source database and load it to your destination database. See Import a database schema for instructions.- If you're using the sample - playing_with_neontable, you can create the same table on the destination database with the following statement:- CREATE TABLE IF NOT EXISTS playing_with_neon(id SERIAL PRIMARY KEY, name TEXT NOT NULL, value REAL);- Create a subscription- After creating a publication on the source database, you need to create a subscription on your Neon destination database. - 
Use the Neon SQL Editor, psql, or another SQL client to connect to your destination database.
- 
Create the subscription using the using a CREATE SUBSCRIPTIONstatement.CREATE SUBSCRIPTION my_subscription CONNECTION 'postgresql://postgres:password@database-1.czmwaio8k05k.us-east-2.rds.amazonaws.com/postgres' PUBLICATION my_publication;- subscription_name: A name you chose for the subscription.
- connection_string: The connection string for the source AWS RDS Postgres database where you defined the publication.
- publication_name: The name of the publication you created on the source AWS RDS Postgres database.
 
- 
Verify the subscription was created by running the following command: SELECT * FROM pg_stat_subscription; subid | subname | pid | leader_pid | relid | received_lsn | last_msg_send_time | last_msg_receipt_time | latest_end_lsn | latest_end_time ------+-----------------+------+------------+-------+--------------+-------------------------------+-------------------------------+----------------+------------------------------- 16471 | my_subscription | 1080 | | | 0/300003A0 | 2024-08-13 20:25:08.011501+00 | 2024-08-13 20:25:08.013521+00 | 0/300003A0 | 2024-08-13 20:25:08.011501+00The subscription ( my_subscription) should be listed, confirming that your subscription was created.
 
- 
- Test the replication- Testing your logical replication setup ensures that data is being replicated correctly from the publisher to the subscriber database. - 
Run some data modifying queries on the source database (inserts, updates, or deletes). If you're using the playing_with_neondatabase, you can use this statement to insert some rows:INSERT INTO playing_with_neon(name, value) SELECT LEFT(md5(i::TEXT), 10), random() FROM generate_series(1, 10) s(i);
- 
Perform a row count on the source and destination databases to make sure the result matches. SELECT COUNT(*) FROM playing_with_neon; count ------- 30 (1 row)
 - Alternatively, you can run the following query on the subscriber to make sure the - last_msg_receipt_timeis as expected. For example, if you just ran an insert option on the publisher, the- last_msg_receipt_timeshould reflect the time of that operation.- SELECT subname, received_lsn, latest_end_lsn, last_msg_receipt_time FROM pg_catalog.pg_stat_subscription;
- 
- Switch over your application- After the replication operation is complete, you can switch your application over to the destination database by swapping out your AWS RDS source database connection details for your Neon destination database connection details. - You can find your Neon database connection details by clicking the Connect button on your Project Dashboard to open the Connect to your database modal. See Connect from any application. See Connect from any application.