Flask Deploy on Heroku
This page explains how to deploy a Flask application on Heroku, the popular deployment platform.
Prerequisites
- Basic programming knowledge in Python
- Basic Flask knowledge and WSGI concept
- Comfortable using a terminal
- Already familiar with GIT
What is Flask
Flask is a lightweight WSGI web application framework. It is designed to make getting started quick and easy, with the ability to scale up to complex applications. Classified as a microframework, Flask is written in Python and it does not require particular tools or libraries. It has no database abstraction layer, form validation, or any other components where pre-existing third-party libraries provide common functions.
Flask Links
- Flask - the official website
- Flask Documentation
- What is Flask - a comprehensive resource about Flask
What is Heroku
Heroku's fully-managed platform that helps developers to deploy apps with ease. Heroku is a cloud-based, fully-managed platform as a service (Paas) for building, running, and managing apps.
A short-list with features:
- Runtime - Heroku empowers developers to deliver products using a CLI, called Heroku Toolbelt
- PostgreSQL DBMS - a powerful database already configured to be production-ready
- Automatic scaling - Heroku scales in an instant, both vertically and horizontally.
- Github integration - trigger production builds directly from Github commits
Heroku Links
- Heroku - the official website
- Heroku Documentation
To explain the process, we will use a simple Flask Boilerplate already enhanced for a Heroku deployment.
Sample project - Flask Boilerplate
Flask Boilerplate is a template codebase used by the AppSeed platform to generate Flask Apps enhanced with a basic set of features:
- UI-Ready, Jinja2 templating
- SQLite database, Flask-SQLAlchemy ORM
- Session-Based auth flow (login, register) via Flask-Login
- Deployment scripts: Docker, Gunicorn / Nginx, Heroku
As mentioned, the project comes pre-configured for Heroku. The relevant files are listed below:
- runtime.txt - specify the Python version used by Heroku during the build and deploy
- Procfile - configuration file that informs Heroku where to look for the WSGI interface
- requirements.txt - must contain the
gunicorn
module
Gunicorn module
Gunicorn Green Unicorn
is a Python WSGI HTTP Server for UNIX. It’s a pre-fork worker model ported from Ruby’s Unicorn project. The Gunicorn server is broadly compatible with various web frameworks, simply implemented, light on server resources, and fairly speedy.
For basic usage please access the PyPi page or the official docs.
File - runtime.txt
To build the deploy any python-based app, Heroku uses a default Python version python-3.6.10
or the one specified in the runtime.txt file. Supported environment, as per Heroku official documentation - Specifying a Python version:
- python-3.8.3
- python-3.7.7
- python-3.6.10 <-- The Default Version
- python-2.7.18
Procfile
Heroku apps include a Procfile that specifies the commands that are executed by the app on startup. As specified in the official docs, the Procfile is always a simple text file that is named Procfile without a file extension.
web: gunicorn run:app --log-file=-
For our sample, gunicorn
is called with run:app
argument.
How to deploy on Heroku
- Create a FREE account on Heroku platform
- Install the Heroku CLI that match your OS: Mac, Unix or Windows
- Open a terminal window and authenticate via
heroku login
command - Clone the sources and push the project for LIVE deployment
The full command list, executed on our sample project.
$ # Clone the source code:
$ git clone https://github.com/app-generator/boilerplate-code-flask.git
$ cd boilerplate-code-flask
$
$ # Check Heroku CLI is installed
$ heroku -v
heroku/7.25.0 win32-x64 node-v12.13.0 # <-- All good
$
$ # Check Heroku CLI is installed
$ heroku login
$ # this commaond will open a browser window - click the login button (in browser)
$
$ # Create the Heroku project
$ heroku create
$
$ # Trigger the LIVE deploy
$ git push heroku master
$
$ # Open the LIVE app in browser
$ heroku open
At this point, you should be able to visit the app in the browser.
Help & Resources
- Get support via Discord, in case something is not working
- Read more about Heroku - official docs
- Check out for more Flask Apps actively supported by AppSeed
- Flask Admin Dashboards - index provided by AppSeed