How to Deploy a Python Flask App on Railway

A brief guide to deploying a Python Flask app on Railway.

In this post, we'll walk through the steps to deploy a Python Flask app on Railway.

What is Flask?

Flask is a lightweight web application framework written in Python. It is based on the Werkzeug WSGI toolkit and the Jinja2 template engine, and is one of the most popular Python frameworks around. It does not require specific tools or libraries, but supports a wide range of extensions for building web applications.

Source: flask.palletsprojects.com
Source: flask.palletsprojects.com

What is Railway?

Railway is a modern app hosting platform that makes it easy to deploy production-ready apps quickly. Railway offers persistent database services for PostgreSQL, MySQL, MongoDB, and Redis, as well as application services with a GitHub repository as the deployment source. For the latter, Railway can automatically determine the application runtime and deploy the service. Railway offers several one-click starters for popular applications, including Flask. Since we are just testing the waters, Railway's free tier should be sufficient to host the service.

Source: Railway.app
Source: Railway.app

Deploy a Simple Flask App on Railway

Sign up for an account with Railway using GitHub, and click Authorize Railway App when redirected. Review and agree to Railway's Terms of Service and Fair Use Policy if prompted. Launch the Flask one-click starter template (or click the button below) to deploy Flask instantly on Railway.

Deploy on Railway

You'll be given an opportunity to change the default repository name and set it private, if you'd like. Accept the defaults and click Deploy; the deployment will kick off immediately.

Deploy Flask one-click starter template on Railway
Deploy Flask one-click starter template on Railway

Once the deployment completes, a simple Flask app will be available at a default xxx.up.railway.app domain - launch this URL to access the app. If you are interested in setting up a custom domain, I covered it at length in a previous post - see the final section here.

If you want to modify the app, here's a few things to understand first:

  • The main.py file only includes the default / route, which launches the index.html file under the templates folder. Add the routes you need, along with the corresponding template files.
  • If you'd like to serve static files ( e.g. .css, .js or images), add a static folder to the root, with the corresponding css, js and img sub-folders to host your files. Then reference them accordingly in your template files.
  • A Procfile has been added to the root - this tells Railway how to run the app.

In conclusion, deploying a Python Flask app on Railway is a straightforward process, made even easier by the one-click template. Go forth and publish!

Subscribe to alphasec

Don’t miss out on the latest issues. Sign up now to get access to the library of members-only issues.
jamie@example.com
Subscribe