Migrate from Render to Coherence
This guide will show you how to easily migrate your application from Render to Coherence. By running in your own cloud account on Amazon Web Services (AWS) or Google Cloud Platform (GCP), you get the compliance, cost, and customization benefits that only the large public cloud providers can offer. Read more about Coherence vs. Platform as a Service (PaaS) provider hosting here.
Coherence offers the features you love on Render, like built-in CI/CD and preview environments, with a great developer experience including a developer portal and a CLI. When you use Coherence, you don't need to be a DevOps expert to manage a world-class deployment platform - leave that part to us. Additionally, you can use your cloud credits with Coherence, making it the perfect choice for startups.
What You'll Learn
This guide will show you how to:
- Prepare an application deployed on Render for deployment on Coherence
- Deploy the application on Coherence
- Migrate the data from your Render database to Coherence
- Transfer your domain from Render to Coherence
Prerequisites
To follow along, you'll need:
- A Coherence account
- A GitHub account
- Administrator access to a Google Cloud Platform (GCP) or Amazon Web Services (AWS) account
- An app on Render that you want to migrate. If you don't have one, you can fork our example Django application
1. Prepare your Render application for migration
Coherence offers flexibility in how it builds and deploys your application:
Option A: Use Nixpacks (Recommended)
If you don't have a Dockerfile, Coherence will automatically use Nixpacks to build your container. This means you don't need to make any changes to your application structure.
Option B: Use an existing Dockerfile
If you've been using a Dockerfile with Render, Coherence will use that Dockerfile to deploy your application. No additional preparation is needed.
Option C: Write a Dockerfile (if necessary)
If your application doesn't have a Dockerfile and you prefer not to use Nixpacks, you'll need to write a Dockerfile for your application. Here's an example for a Django application:
FROM python:3.12
WORKDIR /app
COPY requirements.txt /app/
RUN pip install --upgrade pip
RUN pip install -r requirements.txt
COPY . /app/
RUN python manage.py collectstatic --no-input
Update Django settings for Coherence
Remove Render-specific configuration and update your project settings to ensure your app works correctly in a Coherence environment, including proper handling of AWS Application Load Balancer (ALB) health checks. For GCP, the health check IP will not apply (but the ALLOWED_HOSTS
still needs to know what domain you are serving on). Django is used in this example, and your application may or may not have a similar setting depending on the framework you're using.
In your Django project's settings.py
file, replace Render-specific code with Coherence-specific settings:
import os
from socket import gethostbyname, gethostname
DEBUG = False
ALLOWED_HOSTS = [
os.environ.get('CNC_ENVIRONMENT_DOMAIN'),
gethostbyname(gethostname()), # This allows AWS ALB health checks
]
# If you're using a custom domain, add it to ALLOWED_HOSTS as well
if os.environ.get('CNC_CUSTOM_DOMAIN'):
ALLOWED_HOSTS.append(os.environ.get('CNC_CUSTOM_DOMAIN'))
# If you have additional allowed hosts set in an environment variable
if os.environ.get('ADDITIONAL_ALLOWED_HOSTS'):
ALLOWED_HOSTS.extend(os.environ.get('ADDITIONAL_ALLOWED_HOSTS').split(','))
This configuration does the following:
- It sets
DEBUG
toFalse
for production environments. - It adds the Coherence environment domain to
ALLOWED_HOSTS
. - It includes the container's private IP address in
ALLOWED_HOSTS
to allow AWS ALB health checks. - It conditionally adds a custom domain to
ALLOWED_HOSTS
if one is set in the environment variables. - It allows for additional hosts to be added via an environment variable, if needed.
Remember to set the ADDITIONAL_ALLOWED_HOSTS
environment variable in your Coherence environment if you're using other domains or need to allow additional hosts.
Note on AWS ALB Health Checks
The AWS Application Load Balancer (ALB) performs health checks by sending requests to the container's private IP address. Django's ALLOWED_HOSTS
setting needs to include this IP address to accept these health check requests. The gethostbyname(gethostname())
function call dynamically retrieves the container's IP address, ensuring that health checks will succeed even if the IP changes.
Configure the database
This configuration uses the DATABASE_URL
environment variable, which Coherence will provide, just as Render did. Ensure your settings.py
file includes the following database configuration:
import dj_database_url
DATABASES = {
'default': dj_database_url.config(
default=os.environ.get('DATABASE_URL'),
conn_max_age=600
)
}
Save your startup command
Note the command used to start your application. For a Django application, it might look like this:
python -m gunicorn mysite.asgi:application -k uvicorn.workers.UvicornWorker
You'll need this command when configuring your service in Coherence.
2. Deploy your application on Coherence
Now that your code is prepared, let's set up your application on Coherence.
Create a new application
- In the Coherence dashboard, click New application
- Give the application a name
- Select Google Cloud as the provider and Cloud Run as the architecture
- Click Continue
Create a collection
- On the application's landing page, click Create collection
- Give the collection a name
- Click Create Collection
Configure an environment
- In the collection, click New Environment
- Give the environment a name
- Select the appropriate environment type (Staging is recommended for initial testing)
- Click Create
Add Coherence services
Create a backend service
- Click the environment name to enter the environment homepage
- Go to the Services tab
- Click New service and select the framework for your project under Container
- Configure the service:
- Name: Give the service a name
- Start Command: Enter the command you saved earlier
- Enter "/" under URL path
- Container source: Choose Repository
- Click Add one under Repo
- Paste in the link to your GitHub code repository
- Enter "/" under Context
- If you're using a Dockerfile, enter "Dockerfile" under Dockerfile. Otherwise, leave it blank to use Nixpacks
- Select your track branch (e.g.,
main
) - Click Create service
After creating the service, add necessary Environment Variables using the Variables
tab. The UI also offers bulk import options, and the Coherence CLI also offers environment variable management capability for scripting.
Create a database service
- In the Services tab, click New service and select Postgres
- Configure the database:
- Name: Give the service a name
- Engine: Enter "postgres"
- Version: Choose the appropriate version
- Click Create service
Connect to your cloud provider
Follow the steps in our Google Cloud guide or AWS guide to connect Coherence to your cloud account.
Start a provisioning task
When Coherence has been granted access to your cloud account, submit a provisioning task so that Coherence can automatically set up and manage the necessary cloud resources for your collection.
- Select the Provision Tasks tab for the collection
- Click Submit new task to submit a provisioning task
Wait for this step to complete before moving on, it is expected to take several minutes.
Submit a build & deployment pipeline
- Go to the Deployments tab for the environment
- Click New deployment
- Select the branch and commit to submit from
- Click Submit deployment to start the build & deploy pipeline
View your deployed application
Once the build is complete:
- In your Coherence dashboard, navigate to your environment
- Click the URL at the top of the environment details page to open your deployed application
3. Migrate the data
This is a crucial step in the migration process. Don't hesitate to contact the Coherence team if you need assistance.
Export data from Render
- In your Render dashboard, go to your PostgreSQL database
- Click the Connection tab
- Copy the External Database URL
- Use
pg_dump
to export your data:
pg_dump "your-render-external-database-url" > render_db_dump.sql
Choose a migration method
You can migrate data to Coherence in two ways:
- Using the Coherence CLI (
cocli
) - Migrating directly to your cloud database
Set up a CNC toolbox
Set up a CNC toolbox to interact with your Coherence environment from your local machine:
- Install
cocnc
by following the instructions in the CNC documentation. - Install
cocli
by following the instructions in the cocli GitHub repository. - Install the Google Cloud CLI by following the instructions in the Google Cloud documentation.
- Authenticate the Google Cloud CLI with these commands:
gcloud auth application-default login
gcloud auth login
Start a toolbox
First, set up authentication.
- In the Coherence dashboard, navigate to your profile.
- Click Create token.
- Give the token a name and select an expiration period.
- Click Create token.
- Copy the token value.
- Run the following command on your local machine with your access token:
export COHERENCE_ACCESS_TOKEN="your-access-token-here"
Next, set your app ID and collection ID to variables.
In your terminal, add your app name and collection name to the command below:
app_id=$(cocli apps list | jq '.[] | select(.title=="Your App Name") | .id')
collection_id=$(cocli collections list -a $app_id | jq '.data[] | select(.name=="your-collection-name") | .id')
To start a toolbox, replace main
with your environment name in the following command:
cocli cnc -c $collection_id -- toolbox start main --proxy-only
Keep the toolbox running while you migrate the data in a new terminal.
Migrate the data to the Coherence project
To import your data to your new Coherence-managed database:
- Open a new terminal in the folder containing
render_db_dump.sql
file. - Get the
psql
database connection string from Coherence by copying the value of theDATABASE_URL
variable found in the Variables tab on your environment homepage. - Run the following command, replacing
<database-connection-string>
with your database connection string andpath/to/render_db_dump.sql
with the path to your migration file:
psql -d <database-connection-string> < path/to/render_db_dump.sql
To migrate your data directly to GCP, first authorize your public IP.
- Get your public IP. Find your public IP here.
- Navigate to your GCP console.
- Navigate to SQL in the left menu.
- Navigate to Connections and open the Networking tab.
- Scroll down to Authorized networks.
- In New network, give your network a name and add your public IP address in the Network field.
- Click Add network, then click Save at the bottom of the page.
Connect to your Cloud SQL database on your local machine with the following command:
psql -d <database-connection-string> < path/to/render_db_dump.sql
Verify the data migration
Check your application to ensure your data has been successfully migrated.
4. Migrate the domain
The final step is to update your domain settings to point to your Coherence-hosted application.
Remove the domain from Render
- In your Render dashboard, go to your web service
- Navigate to the Settings tab
- Remove the custom domain from your Render service
Change DNS settings for the domain
- Log in to your domain registrar's dashboard
- In the Coherence dashboard, navigate to your environment homepage and select the Custom domains tab
- Add your custom domain to the Domain field
- Copy the provided DNS record and add it to your domain registrar's settings
- Click Add domain to save the configuration
Wait for DNS propagation (up to 48 hours).
Once DNS propagation is complete, visit your domain to verify that your website is accessible and your migrated data is functioning correctly.
Conclusion
Congratulations! You've successfully migrated your application from Render to Coherence. Enjoy the benefits of running your application on your own cloud infrastructure while maintaining the ease of use you're accustomed to with PaaS providers.
If you encounter any issues or have questions during the migration process, don't hesitate to reach out to the Coherence support team. We're here to ensure your migration is smooth and successful.