Heroku is a great place to evaluate Metabase and take it for a quick spin with just a click of a button and a couple minutes of waiting time. If you decide to keep your Metabase running long term we recommend some upgrades as noted below to avoid limitations of the Heroku free tier.
Before doing anything you should make sure you have a Heroku account that you can access.
If you've got a Heroku account then all there is to do is follow this one-click deployment button
This will launch a Heroku deployment using a GitHub repository that Metabase maintains.
It should only take a few minutes for Metabase to start. You can check on the progress by viewing the logs at https://dashboard.heroku.com/apps/YOUR_APPLICATION_NAME/logs or using the Heroku command line tool with the heroku logs -t -a YOUR_APPLICATION_NAME
command.
Free
tierHeroku is very kind and offers a free tier to be used for very small/non-critical workloads which is great if you just want to evaluate Metabase and see what it looks like. If you like what you see and decide to use Metabase as an ongoing part of your analytics workflow we recommend these upgrades which are quite affordable and will allow you to fully utilize all of Metabase's capabilities without running into annoying limitations.
Upgrade your dyno to the Hobby
tier or one of the professional Standard
1x/2x dynos. The most important reason for this is that your dyno will never sleep and that allows Metabase to run all of its background work such as sending Pulses, syncing metadata, etc, in a reliable fashion.
Upgrade your Postgres database to the Basic
package or for more peace of mind go for the Standard 0
package. The primary reason for this upgrade is to get more than the minimum number of database rows offered in the free tier (10k), which we've had some users exhaust within a week. You'll also get better overall performance along with backups, which we think is worth it.
free
tier, if you don’t access the application for a while Heroku will sleep your Metabase environment. This prevents things like Pulses and Metabase background tasks from running when scheduled and at times makes the app appear to be slow when really it's just Heroku reloading your app. You can resolve this by upgrading to the hobby
tier or higher.Error R14 (Memory quota exceeded)
in the Heroku logs. If this happens regularly we recommend upgrading to the standard-2x
tier dyno.Now that you’ve installed Metabase, it’s time to set it up and connect it to your database.
DATABASECHANGELOGLOCK
table. Then just restart Metabase.Upgrading to the next version of Metabase is a simple process where you will grab the latest version of metabase-deploy and push it to Heroku.
Here's each step:
git clone https://github.com/metabase/metabase-deploy.git
cd metabase-deploy
git remote add heroku https://git.heroku.com/your-metabase-app.git
heroku buildpacks:add https://github.com/metabase/metabase-buildpack
git push -f heroku master
Wait for the deploy to finish
If there have been no new changes to the metabase-deploy repository, you will need to add an empty commit. This triggers Heroku to re-deploy the code, fetching the newest version of Metabase in the process.
git commit --allow-empty -m "empty commit"
git push -f heroku master
Can you improve this documentation? These fine people already did:
Allen Gilliland, Tom Robinson, Sameer Al-Sakran, Flamber Hansen, Kim Korte, Ludovic Perseghini & Mikhail TopolskiyEdit on GitHub
cljdoc is a website building & hosting documentation for Clojure/Script libraries
× close