Prerequisite: Remote Servers
Heroku is a cloud platform that lets companies build, deliver, monitor and scale apps — we're the fastest way to go from idea to URL, bypassing all those infrastructure headaches. - Heroku website
Heroku provides developers with the ability to configure and manage remote servers. Each Heroku server has its own unique HTTP address. Users usually access the server by visiting its address in a web browser, whereas developers and administrators usually access the server from the command-line over what is usually an HTTPS or SSH connection.
Heroku servers can host applications written in popular programming languages like Python, Ruby, Node.js, and more.
In addition to using the online platform to interface with Heroku, we will use the Heroku command-line utility (CLI).
References:
- Heroku CLI Reference
- Heroku CLI Source Code
- Heroku CLI Installation Guide
- Heroku for "Pythonic apps and APIs"
- Heroku Python Support
- Heroku Getting Started with Python
Before you can use the Heroku CLI, you'll need a Heroku account.
Take a moment to register for a new account unless you already have one.
After registering, make sure to confirm your account by clicking a confirmation link the confirmation email sent to you by Heroku.
Security Alert: consider eventually enabling multi-factor authentication on your Heroku account to keep your account and your servers safe from intrusion. Don't worry about doing this now if you don't feel like it, but take a moment to do so when you have time.
NOTE: In order to provision some services like databases and email, you may need to provide Heroku with billing information. You can expect to not be charged as long as you are using the free version of each of these services. Just be aware.
Check to see if the Heroku CLI is already installed, and if so, what version:
# Mac Terminal
which heroku #> /usr/local/bin/heroku
# Windows Command Prompt
where heroku #> ...
heroku --version #> heroku/7.4.1 darwin-x64 node-v10.4.1
If it is not installed, follow the official installation guide for operating system-specific instructions. As usual, Mac users are able and encouraged to install via Homebrew (brew tap heroku/brew && brew install heroku
). Windows users should install with all default preferences, including making sure "Add PATH to Heroku" is checked.
After installing the Heroku CLI, log-in to Heroku from the command-line using your account credentials:
heroku login # this will prompt you for a username and password
List applications:
heroku apps
NOTE, for other commands below, you can specify which app to run the command against by providing the
-a
flag followed by the app name (e.g.-a my-app-name
).
Create a Heroku application server (from within the root directory of an existing project):
heroku create
# or optionally specify a name, like:
# heroku create my-app-name
... Or alternatively create a new application via the Heroku online console, and note its name (e.g. "my-app-name"), and associate an existing repository with it (from within the root directory of an existing project):
heroku git:remote -a my-app-name
After doing so, you should be able to verify the repository is configured with a remote address called "heroku":
git remote -v
Get environment variables currently set on the server:
heroku config -a my-app-name
Set environment variables on the server:
heroku config:set MY_SECRET_MESSAGE="abc123" -a my-app-name
Deploy the application's source code to the application server:
git push heroku main
# or if you need to deploy from a different branch:
# git push heroku mybranch:main
Visit the application in a browser and note its URL for future reference:
heroku open -a my-app-name
Check your application's server logs:
heroku logs -a my-app-name