mirror of
				https://github.com/cookiecutter/cookiecutter-django.git
				synced 2025-11-04 01:47:28 +03:00 
			
		
		
		
	* Add support for Webpack as frontend pipeline * Rename CI jobs * Fix a couple of issues with Webpack + Docker * Don't include Boostrap CSS from CDN with Webpack * Rename variable * Set publicPath in prod webpack config * Fix removal of SASS files in post-gen hooks * Add Webpack to readme usage section * Run Django + Webpack dev server concurrently without Docker * Fix async runserver command with Gulp/Webpack * Upgrade django-webpack-loader to 1.5.0 * Pass variables required by Webpack at build time * Upgrade django-webpack-loader to 1.7.0 * Add missing condition * Add support for Azure Storage + Webpack * Whitespaces * Rename ROOT_DIR -> BASE_DIR * Rename jobs * Bump django-webpack-loader to latest * Document limitation of Docker + Webpack + no Whitenoise * Update section on custom Bootstrap compilation in generated readme
		
			
				
	
	
		
			129 lines
		
	
	
		
			3.7 KiB
		
	
	
	
		
			ReStructuredText
		
	
	
	
	
	
			
		
		
	
	
			129 lines
		
	
	
		
			3.7 KiB
		
	
	
	
		
			ReStructuredText
		
	
	
	
	
	
Deployment on Heroku
 | 
						|
====================
 | 
						|
 | 
						|
.. index:: Heroku
 | 
						|
 | 
						|
Script
 | 
						|
------
 | 
						|
 | 
						|
Run these commands to deploy the project to Heroku:
 | 
						|
 | 
						|
.. code-block:: bash
 | 
						|
 | 
						|
    heroku create --buildpack heroku/python
 | 
						|
 | 
						|
    heroku addons:create heroku-postgresql:mini
 | 
						|
    # On Windows use double quotes for the time zone, e.g.
 | 
						|
    # heroku pg:backups schedule --at "02:00 America/Los_Angeles" DATABASE_URL
 | 
						|
    heroku pg:backups schedule --at '02:00 America/Los_Angeles' DATABASE_URL
 | 
						|
    heroku pg:promote DATABASE_URL
 | 
						|
 | 
						|
    heroku addons:create heroku-redis:mini
 | 
						|
 | 
						|
    # Assuming you chose Mailgun as mail service (see below for others)
 | 
						|
    heroku addons:create mailgun:starter
 | 
						|
 | 
						|
    heroku config:set PYTHONHASHSEED=random
 | 
						|
 | 
						|
    heroku config:set WEB_CONCURRENCY=4
 | 
						|
 | 
						|
    heroku config:set DJANGO_DEBUG=False
 | 
						|
    heroku config:set DJANGO_SETTINGS_MODULE=config.settings.production
 | 
						|
    heroku config:set DJANGO_SECRET_KEY="$(openssl rand -base64 64)"
 | 
						|
 | 
						|
    # Generating a 32 character-long random string without any of the visually similar characters "IOl01":
 | 
						|
    heroku config:set DJANGO_ADMIN_URL="$(openssl rand -base64 4096 | tr -dc 'A-HJ-NP-Za-km-z2-9' | head -c 32)/"
 | 
						|
 | 
						|
    # Set this to your Heroku app url, e.g. 'bionic-beaver-28392.herokuapp.com'
 | 
						|
    heroku config:set DJANGO_ALLOWED_HOSTS=
 | 
						|
 | 
						|
    # Assign with AWS_ACCESS_KEY_ID
 | 
						|
    heroku config:set DJANGO_AWS_ACCESS_KEY_ID=
 | 
						|
 | 
						|
    # Assign with AWS_SECRET_ACCESS_KEY
 | 
						|
    heroku config:set DJANGO_AWS_SECRET_ACCESS_KEY=
 | 
						|
 | 
						|
    # Assign with AWS_STORAGE_BUCKET_NAME
 | 
						|
    heroku config:set DJANGO_AWS_STORAGE_BUCKET_NAME=
 | 
						|
 | 
						|
    git push heroku master
 | 
						|
 | 
						|
    heroku run python manage.py createsuperuser
 | 
						|
 | 
						|
    heroku run python manage.py check --deploy
 | 
						|
 | 
						|
    heroku open
 | 
						|
 | 
						|
Notes
 | 
						|
-----
 | 
						|
 | 
						|
Email Service
 | 
						|
+++++++++++++
 | 
						|
 | 
						|
The script above assumes that you've chose Mailgun as email service. If you want to use another one, check the `documentation for django-anymail <https://anymail.readthedocs.io>`_ to know which environment variables to set. Heroku provides other `add-ons for emails <https://elements.heroku.com/addons#email-sms>`_ (e.g. Sendgrid) which can be configured with a similar one line command.
 | 
						|
 | 
						|
.. warning::
 | 
						|
 | 
						|
    .. include:: mailgun.rst
 | 
						|
 | 
						|
Heroku & Docker
 | 
						|
+++++++++++++++
 | 
						|
 | 
						|
Although Heroku has some sort of `Docker support`_, it's not supported by cookiecutter-django.
 | 
						|
We invite you to follow Heroku documentation about it.
 | 
						|
 | 
						|
.. _Docker support: https://devcenter.heroku.com/articles/build-docker-images-heroku-yml
 | 
						|
 | 
						|
Optional actions
 | 
						|
----------------
 | 
						|
 | 
						|
Celery
 | 
						|
++++++
 | 
						|
 | 
						|
Celery requires a few extra environment variables to be ready operational. Also, the worker is created,
 | 
						|
it's in the ``Procfile``, but is turned off by default:
 | 
						|
 | 
						|
.. code-block:: bash
 | 
						|
 | 
						|
    # Set the broker URL to Redis
 | 
						|
    heroku config:set CELERY_BROKER_URL=`heroku config:get REDIS_URL`
 | 
						|
    # Scale dyno to 1 instance
 | 
						|
    heroku ps:scale worker=1
 | 
						|
 | 
						|
Sentry
 | 
						|
++++++
 | 
						|
 | 
						|
If you're opted for Sentry error tracking, you can either install it through the `Sentry add-on`_:
 | 
						|
 | 
						|
.. code-block:: bash
 | 
						|
 | 
						|
    heroku addons:create sentry:f1
 | 
						|
 | 
						|
 | 
						|
Or add the DSN for your account, if you already have one:
 | 
						|
 | 
						|
.. code-block:: bash
 | 
						|
 | 
						|
    heroku config:set SENTRY_DSN=https://xxxx@sentry.io/12345
 | 
						|
 | 
						|
.. _Sentry add-on: https://elements.heroku.com/addons/sentry
 | 
						|
 | 
						|
 | 
						|
Gulp or Webpack
 | 
						|
+++++++++++++++
 | 
						|
 | 
						|
If you've opted for Gulp or Webpack as frontend pipeline, you'll most likely need to setup
 | 
						|
your app to use `multiple buildpacks`_: one for Python & one for Node.js:
 | 
						|
 | 
						|
.. code-block:: bash
 | 
						|
 | 
						|
    heroku buildpacks:add --index 1 heroku/nodejs
 | 
						|
 | 
						|
At time of writing, this should do the trick: during deployment,
 | 
						|
the Heroku should run ``npm install`` and then ``npm build``,
 | 
						|
which run the SASS compilation & JS bundling.
 | 
						|
 | 
						|
If things don't work, please refer to the Heroku docs.
 | 
						|
 | 
						|
.. _multiple buildpacks: https://devcenter.heroku.com/articles/using-multiple-buildpacks-for-an-app
 |