Remember to add migrations to your repository. Please check `Migrations`_ section.
Since filesystem on Heroku is ephemeral (sqlite database will be lost at least once every 24 hours) the PostgreSQL is a recommended choice. Due to this fact the additional library is required: ``psycopg2-binary``.
Heroku CLI
**WARNING!**``psycopg2-binary`` package is a practical choice for development and testing but in production it is advised to use the package built from sources. Read more in the `psycopg2 documentation <http://initd.org/psycopg/docs/install.html?highlight=production%20advised%20use%20package%20built%20from%20sources#binary-install-from-pypi>`_
^^^^^^^^^^
If you want deploy by using Heroku CLI:
Deployment by using `Heroku CLI <https://devcenter.heroku.com/articles/heroku-cli>`_:
* create Heroku App. You can leave your app name, change it or leave it blank (random name will be generated)::
* create Heroku App. You can leave your app name, change it or leave it blank (random name will be generated)::
@ -174,19 +168,27 @@ If you want deploy by using Heroku CLI:
heroku buildpacks:add --index=1 heroku/nodejs
heroku buildpacks:add --index=1 heroku/nodejs
heroku buildpacks:add --index=1 heroku/python
heroku buildpacks:add --index=1 heroku/python
* add database addon which sets Postgres in version 11 in free `hobby-dev` plan (https://elements.heroku.com/addons/heroku-postgresql#hobby-dev) (it also sets `DATABASE_URL` environmental variable to created database)::
* add database addon which sets PostgresSQL in version 11 in free `hobby-dev <https://elements.heroku.com/addons/heroku-postgresql#hobby-dev>`_ plan (it also sets ``DATABASE_URL`` environmental variable to created database)::
* set environmental variables (change ``SECRET_KEY`` value for your own)::
`DATABASE_URL` environmental variable is set by database addon in previous step.
Please check `.env.example` to get overview which environmental variables are used in project.::
heroku config:set SECRET_KEY=not-so-secret
heroku config:set SECRET_KEY=not-so-secret
heroku config:set FLASK_APP=autoapp.py
heroku config:set FLASK_APP=autoapp.py
* deploy on Heroku::
* ``DATABASE_URL`` environmental variable is set by database addon.
Please check ``.env.example`` to get overview which environmental variables are used in the project.
* deploy on Heroku by pushing to the ``heroku`` branch::
git push heroku master
git push heroku master
If you keep your project on GitHub you can use 'Deploy to Heroku' button thanks to which the deployment can be done in web browser with minimal configuration required.
The configuration used by the button is stored in ``app.json`` file.