Migrate from Heroku

Migrating your app from Heroku to Railway is very simple. We even support Procfiles out of the box. (Only a single process is supported for now).

All you need to do is create a project in Railway, push your code, and migrate your envionment variables.

This guide will step you through the process of migrating a simple web service, using the Railway CLI.

Screenshot of Railway Up

Working Directory

In your terminal, ensure your current working directory is the same directory where your service code is located.

This is important so that as you complete the following steps, the Railway CLI is properly linked.

1. Login to Railway from the CLI

Ensure your CLI is authenticated to your Railway account:

railway login

This command will prompt to open a browser to complete authentication. Once authenticated, commands executed by the Railway CLI, will be performed in the context of your Railway account.

2. Create a New Project

Now, let's create a new project:

railway init

This command will prompt you to define a name for your service.

3. Deploy the Service

Once your project is created, you can push your code into the project and assign a domain.

Push the Code

Push the code into a service in Railway:

railway up -d

At this point, the service is being deployed, but let's give it a domain.

Assign a Domain

The service we are migrating is a web service that should be available over the Internet, so let's assign a domain:

railway domain

Now the service will be available over the Internet via the provided domain.

4. Migrate the Environment Variables

Finally, we will import the environment variables from Heroku into Railway.

Video of importing variables from Heroku

Open the Project in Railway

Let's pop over to our new project in the Railway canvas.:

railway open

This will open the project in your browser.

Add Heroku Variables to the Service

From the project canvas, import the Heroku variables into the service:

  • click on the service
  • click Variables tab
  • open the command palette using CMD + K or Ctrl + K.
  • search for Import variables from Heroku
  • confirm the Heroku service and hit Enter

Your Heroku variables will be imported into the service, and it will automatically redeploy.

Note: The first time you import variables from Heroku, you will be prompted to Allow Railway to connect to your Heroku account.

Conclusion

Following this guide, we have successfully migrated a simple web service from Heroku to Railway, including importing variables from Heroku into Railway.

We have completed the migration by pushing our code directly from our local machine into a service in Railway. Once you are comfortable with Railway, you may want to integrate deployments into your development workflow.

For more advanced operations, like migrating your databases from Heroku to Railway, the process will be a bit more involved, but we are happy to help work out a solution!

Need Help?

If you run into any issues, or would like help with your migrations, we would be more than happy to answer your questions on our Discord or over email at team@railway.app.


Edit this file on GitHub