Skip to content

Simple dashboard template with plotly and dash deployed on heroku

License

Notifications You must be signed in to change notification settings

pwerden/ds-simple-plotly-dash-template

 
 

Repository files navigation

ds-simple-plotly-dash-template

With this template you can create a simple repo to create a plotly-dash that can be deployed on heroku. For a cool list of resources check awesome dash!

Aim

The aim of this template is to give a starting point to set-up an easy plotly dash and to employ it locally and to the internet. Also included are links to additional resources.

Getting started

Don't clone this repository. It's a template: create your own repository by using "use this template".

What is in this repository

File
01_notebook_plotly_dash.ipynb First glance at the dash syntax
app.py Py-File which contains the dash for deployment
Procfile Procfile, needed by Heroku to know how to run your app
Runtime Required for deployment, to use specific python version
requirements.txt libraries needed by your app

The next steps

  1. Set up the environment
  2. Work in notebook to get acquainted with dash plots
  3. Work in app.py-File to create a dash
  4. Check if Dashboard is working locally with
  • $ python app.py
  • $ gunicorn app:server
  1. Deploy to Heroku
  2. Enjoy the result

This little graph should help you clarify the steps you need to take until your online dashboard is ready. from charts to dashboard to online dashboard deployed on heroku (Delete Heroku-Dashboard.png when using this repo as template :) )


Setup information

Requirements:

  • python = 3.9.11 (you can install it with pyenv install 3.9.11)

Setup environment with:

$ make setup

There are two requirement files in this template:

  1. requirements_dev.txt This is the requirements file you can use locally to set everything up and develop the dashboard. You can add as much here as you want to.
  2. requirements.txt This is the requirements that Heroku uses. Because Memory for the App is very limited it should not contain the development environment (e.g. jupyter) and as few libraries as possible.

You should work with python 3.9.11, this is the version that Heroku is currently (May 2022, check heroku documentation for updates) using .

General Tips for deployment of dash to Heroku

Prior to deployment on Heroku

  • Make sure you clean up, process and strip down the data as much as you can first.
  • You can only use about 500MB of memory on Heroku, so don't waste space.
  • Test your app locally thoroughly first. Use an environment that uses the "requirements.txt" for this so you are using the same packages as will be used on Heroku.

You should test everything locally with $ python app.py and $ gunicorn app:server Make sure you restart your server (locally) so all your changes take effect.

Make sure you have these three files in the repo:

  1. Runtime.txt
  2. requirements.txt
  3. Procfile

Deployment to Heroku

The General steps are:

  1. First you need to login or create an Account on Heroku
  2. click on New -> New Apps (on the right side)
  3. Pick an unique name, this is gonna be reflected in your apps URL
  4. Select europe

You can use either use the Heroku CLI or the github connection to deploy your app (as of now the github connection is not working, due to a security breach):

Heroku CLI:

  1. Install the Heroku CLI via npm:
    npm install -g heroku
  2. Log in with the Heroku CLI:
    heroku login
  3. Create a git repository if you are not working with a github repository:
    cd my-project/
    git init
    heroku git:remote -a <app-name>
    if you are working with github repository you can simply run:
    heroku git:remote -a <app-name>
  4. Push your code to Heroku:
    git add .
    git commit -m "my-commit-message"
    git push heroku main
  5. Wait until your app is deployed on Heroku.
  6. Hit view on Heroku and
  7. Enjoy your dashboard!

Github connection:

  1. Use the github connection (allow and set this up if required)
  2. Pick your repository
  3. Select the branch (you should have a specific repository for the visualization or, at least, a specific branch)
  4. Hit deploy and wait for the build
  5. Hit view and
  6. Enjoy!

About

Simple dashboard template with plotly and dash deployed on heroku

Resources

License

Stars

Watchers

Forks

Releases

No releases published

Packages

No packages published

Languages

  • Python 59.7%
  • Jupyter Notebook 35.8%
  • Makefile 4.0%
  • Procfile 0.5%