From f7ca3aa22e78f2ae5d41e609688a159311e43b7a Mon Sep 17 00:00:00 2001 From: Jose Salvatierra Date: Fri, 26 Aug 2022 14:04:48 +0100 Subject: [PATCH] feat(docker): add production docker lecture Keep information on how to run locally using Flask dev server and volumes --- .../03_docker_with_gunicorn/README.md | 70 ++++++++++++++++++ .../README.md | 0 .../assets/copy-elephantsql-url.png | Bin .../select-plan-and-name-elephantsql.png | Bin .../README.md | 0 .../assets/render-add-env-var.png | Bin .../assets/render-database-url-env-var.png | Bin 7 files changed, 70 insertions(+) create mode 100644 docs/docs/11_deploy_to_render/03_docker_with_gunicorn/README.md rename docs/docs/11_deploy_to_render/{03_deploy_postgresql_database => 04_deploy_postgresql_database}/README.md (100%) rename docs/docs/11_deploy_to_render/{03_deploy_postgresql_database => 04_deploy_postgresql_database}/assets/copy-elephantsql-url.png (100%) rename docs/docs/11_deploy_to_render/{03_deploy_postgresql_database => 04_deploy_postgresql_database}/assets/select-plan-and-name-elephantsql.png (100%) rename docs/docs/11_deploy_to_render/{04_environment_variables => 05_environment_variables}/README.md (100%) rename docs/docs/11_deploy_to_render/{04_environment_variables => 05_environment_variables}/assets/render-add-env-var.png (100%) rename docs/docs/11_deploy_to_render/{04_environment_variables => 05_environment_variables}/assets/render-database-url-env-var.png (100%) diff --git a/docs/docs/11_deploy_to_render/03_docker_with_gunicorn/README.md b/docs/docs/11_deploy_to_render/03_docker_with_gunicorn/README.md new file mode 100644 index 00000000..1047f353 --- /dev/null +++ b/docs/docs/11_deploy_to_render/03_docker_with_gunicorn/README.md @@ -0,0 +1,70 @@ +# Run our Flask app with gunicorn in Docker + +Throughout the course, we've been working with a Docker image like this one: + +```dockerfile +FROM python:3.10 +EXPOSE 5000 +WORKDIR /app +COPY requirements.txt . +RUN pip install -r requirements.txt +COPY . . +CMD ["flask", "run", "--host", "0.0.0.0"] +``` + +This is all well and good for local development, but when we deploy our application we want to run it with the best performance possible. + +This is why we don't want to run the Flask development server and the Flask debugger. Instead, we'll use gunicorn to run our app. + +## Run our Flask app with gunicorn + +First let's add `gunicorn` to our `requirements.txt` file: + +```text title="requirements.txt" +flask +flask-smorest +python-dotenv +sqlalchemy +flask-sqlalchemy +flask-jwt-extended +passlib +flask-migrate +# highlight-start +gunicorn +# highlight-end +``` + +Then, let's change our `Dockerfile` to use `gunicorn`: + +```dockerfile +FROM python:3.10 +WORKDIR /app +COPY ./requirements.txt requirements.txt +# highlight-start +RUN pip install --no-cache-dir --upgrade -r requirements.txt +# highlight-end +COPY . . +# highlight-start +CMD ["gunicorn", "--bind", "0.0.0.0:80", "app:create_app()"] +# highlight-end +``` + +The `CMD` line change is the important one, as it runs `gunicorn` on port `80`, and we pass in the app factory function. + +:::tip +Note I've also changed the `pip install` line. Adding `--no-cache-dir` and `--upgrade` just makes sure we can't accidentally install from a cache directory (which shouldn't exist anyway!), and that we'll upgrade to the latest possible versions allowed by our `requirements.txt` file. +::: + +## Run the Docker container locally with the Flask development server and debugger + +If you use this `Dockerfile`, it doesn't mean you can't run it locally using the Flask development server. You don't have to lose the automatic restarting capabilities, or the Flask debugger. + +To run the Docker container locally, you'll have to do this from now on: + +```zsh +docker run -dp 5000:5000 -w /app -v "$(pwd):/app" teclado-site-flask sh -c "flask run" +``` + +This is similar to how we've ran the Docker container with our local code as a volume (that's what `-w /app -v "$(pwd):/app"` does), but at the end of the command we're telling the container to run `flask run` instead of the `CMD` line of the `Dockerfile`. That's what `sh -c "flask run"` does! + +Now you're ready to commit and push this to your repository and re-deploy to Render.com! diff --git a/docs/docs/11_deploy_to_render/03_deploy_postgresql_database/README.md b/docs/docs/11_deploy_to_render/04_deploy_postgresql_database/README.md similarity index 100% rename from docs/docs/11_deploy_to_render/03_deploy_postgresql_database/README.md rename to docs/docs/11_deploy_to_render/04_deploy_postgresql_database/README.md diff --git a/docs/docs/11_deploy_to_render/03_deploy_postgresql_database/assets/copy-elephantsql-url.png b/docs/docs/11_deploy_to_render/04_deploy_postgresql_database/assets/copy-elephantsql-url.png similarity index 100% rename from docs/docs/11_deploy_to_render/03_deploy_postgresql_database/assets/copy-elephantsql-url.png rename to docs/docs/11_deploy_to_render/04_deploy_postgresql_database/assets/copy-elephantsql-url.png diff --git a/docs/docs/11_deploy_to_render/03_deploy_postgresql_database/assets/select-plan-and-name-elephantsql.png b/docs/docs/11_deploy_to_render/04_deploy_postgresql_database/assets/select-plan-and-name-elephantsql.png similarity index 100% rename from docs/docs/11_deploy_to_render/03_deploy_postgresql_database/assets/select-plan-and-name-elephantsql.png rename to docs/docs/11_deploy_to_render/04_deploy_postgresql_database/assets/select-plan-and-name-elephantsql.png diff --git a/docs/docs/11_deploy_to_render/04_environment_variables/README.md b/docs/docs/11_deploy_to_render/05_environment_variables/README.md similarity index 100% rename from docs/docs/11_deploy_to_render/04_environment_variables/README.md rename to docs/docs/11_deploy_to_render/05_environment_variables/README.md diff --git a/docs/docs/11_deploy_to_render/04_environment_variables/assets/render-add-env-var.png b/docs/docs/11_deploy_to_render/05_environment_variables/assets/render-add-env-var.png similarity index 100% rename from docs/docs/11_deploy_to_render/04_environment_variables/assets/render-add-env-var.png rename to docs/docs/11_deploy_to_render/05_environment_variables/assets/render-add-env-var.png diff --git a/docs/docs/11_deploy_to_render/04_environment_variables/assets/render-database-url-env-var.png b/docs/docs/11_deploy_to_render/05_environment_variables/assets/render-database-url-env-var.png similarity index 100% rename from docs/docs/11_deploy_to_render/04_environment_variables/assets/render-database-url-env-var.png rename to docs/docs/11_deploy_to_render/05_environment_variables/assets/render-database-url-env-var.png