Chapter 18: Deployment on Heroku (v0.18)

This commit is contained in:
Miguel Grinberg 2017-10-16 22:24:15 -07:00
parent 7d16e19169
commit ae62fc9251
No known key found for this signature in database
GPG Key ID: 36848B262DF5F06C
4 changed files with 22 additions and 10 deletions

1
Procfile Normal file
View File

@ -0,0 +1 @@
web: flask db upgrade; flask translate compile; gunicorn microblog:app

View File

@ -68,15 +68,20 @@ def create_app(config_class=Config):
mail_handler.setLevel(logging.ERROR) mail_handler.setLevel(logging.ERROR)
app.logger.addHandler(mail_handler) app.logger.addHandler(mail_handler)
if not os.path.exists('logs'): if app.config['LOG_TO_STDOUT']:
os.mkdir('logs') stream_handler = logging.StreamHandler()
file_handler = RotatingFileHandler('logs/microblog.log', stream_handler.setLevel(logging.INFO)
maxBytes=10240, backupCount=10) app.logger.addHandler(stream_handler)
file_handler.setFormatter(logging.Formatter( else:
'%(asctime)s %(levelname)s: %(message)s ' if not os.path.exists('logs'):
'[in %(pathname)s:%(lineno)d]')) os.mkdir('logs')
file_handler.setLevel(logging.INFO) file_handler = RotatingFileHandler('logs/microblog.log',
app.logger.addHandler(file_handler) maxBytes=10240, backupCount=10)
file_handler.setFormatter(logging.Formatter(
'%(asctime)s %(levelname)s: %(message)s '
'[in %(pathname)s:%(lineno)d]'))
file_handler.setLevel(logging.INFO)
app.logger.addHandler(file_handler)
app.logger.setLevel(logging.INFO) app.logger.setLevel(logging.INFO)
app.logger.info('Microblog startup') app.logger.info('Microblog startup')

View File

@ -7,8 +7,10 @@ load_dotenv(os.path.join(basedir, '.env'))
class Config(object): class Config(object):
SECRET_KEY = os.environ.get('SECRET_KEY') or 'you-will-never-guess' SECRET_KEY = os.environ.get('SECRET_KEY') or 'you-will-never-guess'
SQLALCHEMY_DATABASE_URI = os.environ.get('DATABASE_URL') or \ SQLALCHEMY_DATABASE_URI = os.environ.get('DATABASE_URL', '').replace(
'postgres://', 'postgresql://') or \
'sqlite:///' + os.path.join(basedir, 'app.db') 'sqlite:///' + os.path.join(basedir, 'app.db')
LOG_TO_STDOUT = os.environ.get('LOG_TO_STDOUT')
MAIL_SERVER = os.environ.get('MAIL_SERVER') MAIL_SERVER = os.environ.get('MAIL_SERVER')
MAIL_PORT = int(os.environ.get('MAIL_PORT') or 25) MAIL_PORT = int(os.environ.get('MAIL_PORT') or 25)
MAIL_USE_TLS = os.environ.get('MAIL_USE_TLS') is not None MAIL_USE_TLS = os.environ.get('MAIL_USE_TLS') is not None

View File

@ -37,3 +37,7 @@ typing_extensions==4.5.0
urllib3==1.26.15 urllib3==1.26.15
Werkzeug==2.3.3 Werkzeug==2.3.3
WTForms==3.0.1 WTForms==3.0.1
# requirements for Heroku
psycopg2-binary==2.9.6
gunicorn==20.1.0