Deploy a Flask App
Flask is a Python micro framework for building web applications.
This guide covers how to deploy a Flask app to Railway in four ways:
Now, let's create a Flask app!
Create a Flask App
Note: If you already have a Flask app locally or on GitHub, you can skip this step and go straight to the Deploy Flask App to Railway.
To create a new Flask app, ensure that you have Python and Flask installed on your machine.
Follow the steps blow to set up the project in a directory.
Create a project directory and cd
into it.
mkdir flaskproject
cd flaskproject
Create a virtual environment
python -m venv env
Activate the virtual environment
source env/bin/activate
Note: For windows developers, run it as env\Scripts\activate
in your terminal.
Install Flask
python -m pip install flask
Now create a new file, helloworld.py
in the flaskproject
directory. Add the following content to it:
import os
from flask import Flask
app = Flask(__name__)
@app.route('/')
def hello():
return 'Hello world, welcome to Railway!'
from flask import Flask
:- This line imports the Flask class from the Flask framework, which is used to create and manage a web application.
app = Flask(__name__)
:- This line creates an instance of the Flask class and assigns it to the app variable.
- The
__name__
argument helps Flask identify the location of the application. It's useful for determining resource paths and error reporting.
@app.route('/')
:- The
@app.route('/')
decorator sets up a URL route for the app. When the root URL(/)
is accessed, Flask will execute the function immediately below this decorator.
- The
def hello():
- The
hello
function returns a plain text message, "Hello world, welcome to Railway!", which is displayed in the browser when the root URL of the app is accessed.
- The
Run the Flask app locally
To run the application, use the flask
command.
flask --app helloworld run
Open your browser and go to http://127.0.0.1:5000
to see the app running with a local development server.
Prepare the Flask app for deployment
- Run the following command to install a production web server, gunicorn:
pip install gunicorn
Next, run the following command to serve the app with gunicorn:
gunicorn main:app
- Open your browser and go to
http://127.0.0.1:8000
to see the app running with a production server.
Create a requirements.txt
file to store the dependencies of the packages needed to run the app.
pip freeze > requirements.txt
Note: It's only safe to run the command above in a virtual environment, else it will freeze all python packages installed on your system.
- Finally, create a
nixpacks.toml
file in the root directory of the app. Add the following content to it:
# nixpacks.toml
[start]
cmd = "gunicorn main:app"
This setup instructs Railway to use Gunicorn as the server to start the application.
Note: The nixpacks.toml file is a configuration file used by Nixpacks, a build system developed and used by Railway, to set up and deploy applications.
In this file, you can specify the instructions for various build and deployment phases, along with environment variables and package dependencies.
With these changes, your Flask app is now ready to be deployed to Railway!
Deploy Flask App to Railway
Railway offers multiple ways to deploy your Flask app, depending on your setup and preference. Choose any of the following methods:
One-Click Deploy from a Template
We highly recommend that you eject from the template after deployment to create a copy of the repo on your GitHub account.
Note: You can also choose from a variety of Flask app templates created by the community.
Deploy from the CLI
- Install the Railway CLI:
- Install the CLI and authenticate it using your Railway account.
- Initialize a Railway Project:
- Run the command below in your Flask app directory.
railway init
- Follow the prompts to name your project.
- After the project is created, click the provided link to view it in your browser.
- Run the command below in your Flask app directory.
- Deploy the Application:
- Use the command below to deploy your app:
railway up
- This command will scan, compress and upload your app's files to Railway. You’ll see real-time deployment logs in your terminal.
- Use the command below to deploy your app:
- Verify the Deployment:
- Once the deployment completes, go to View logs to check if the server is running successfully.
- Set Up a Public URL:
- Navigate to the Networking section under the Settings tab of your new service.
- Click Generate Domain to create a public URL for your app.
Deploy from a GitHub Repo
To deploy a Flask app to Railway directly from GitHub, follow the steps below:
-
Create a New Project on Railway:
- Go to Railway to create a new project.
-
Deploy from GitHub:
- Select Deploy from GitHub repo and choose your repository.
- If your Railway account isn’t linked to GitHub yet, you’ll be prompted to do so.
- Select Deploy from GitHub repo and choose your repository.
-
Deploy the App Service:
- Click Deploy on the Railway project canvas to apply your changes.
-
Verify the Deployment:
- Once the deployment completes, go to View logs to check if the server is running successfully.
Note: During the deployment process, Railway will automatically detect that it’s a Python app.
-
Set Up a Public URL:
- Navigate to the Networking section under the Settings tab of your new service.
- Click Generate Domain to create a public URL for your app.
Use a Dockerfile
- Create a
Dockerfile
in the app's root directory. - Add the content below to the
Dockerfile
:# Use the Python 3 official image # https://hub.docker.com/_/python FROM python:3 # Run in unbuffered mode ENV PYTHONUNBUFFERED=1 # Create and change to the app directory. WORKDIR /app # Copy local code to the container image. COPY . ./ # Install project dependencies RUN pip install --no-cache-dir -r requirements.txt # Run the web service on container startup. CMD ["gunicorn", "main:app"]
- Either deploy via the CLI or from GitHub.
Railway automatically detects the Dockerfile
, and uses it to build and deploy the app.
Note: Railway supports also deployment from public and private Docker images.
Next Steps
Explore these resources to learn how you can maximize your experience with Railway:
Edit this file on GitHub