diff --git a/docs/deployment.md b/docs/deployment.md index 69c3a05b3..810db2580 100644 --- a/docs/deployment.md +++ b/docs/deployment.md @@ -26,7 +26,7 @@ But you can still change and update all the configurations with environment vari To see all the configurations and options, go to the Docker image page: tiangolo/uvicorn-gunicorn-fastapi. -### Build your Image +### Create a `Dockerfile` * Go to your project directory. * Create a `Dockerfile` with: @@ -37,6 +37,37 @@ FROM tiangolo/uvicorn-gunicorn-fastapi:python3.7 COPY ./app /app ``` +#### Bigger Applications + +If you followed the section about creating Bigger Applications with Multiple Files +, your `Dockerfile` might instead look like: + +```Dockerfile +FROM tiangolo/uvicorn-gunicorn-fastapi:python3.7 + +COPY ./app /app/app +``` + +#### Raspberry Pi and other architectures + +If you are running Docker in a Raspberry Pi (that has an ARM processor) or any other architecture, you can create a `Dockerfile` from scratch, based on a Python base image (that is multi-architecture) and use Uvicorn alone. + +In this case, your `Dockerfile` could look like: + +```Dockerfile +FROM python:3.7 + +RUN pip install fastapi uvicorn + +EXPOSE 80 + +COPY ./app /app + +CMD ["uvicorn", "app.main:app", "--host", "0.0.0.0", "--port", "80"] +``` + +### Create the **FastAPI** Code + * Create an `app` directory and enter in it. * Create a `main.py` file with: @@ -65,6 +96,8 @@ def read_item(item_id: int, q: str = None): └── Dockerfile ``` +### Build the Docker image + * Go to the project directory (in where your `Dockerfile` is, containing your `app` directory). * Build your FastAPI image: @@ -72,6 +105,8 @@ def read_item(item_id: int, q: str = None): docker build -t myimage . ``` +### Start the Docker container + * Run a container based on your image: ```bash @@ -81,18 +116,6 @@ docker run -d --name mycontainer -p 80:80 myimage Now you have an optimized FastAPI server in a Docker container. Auto-tuned for your current server (and number of CPU cores). -#### Bigger Applications - -If you followed the section about creating Bigger Applications with Multiple Files -, your `Dockerfile` might instead look like: - -```Dockerfile -FROM tiangolo/uvicorn-gunicorn-fastapi:python3.7 - -COPY ./app /app/app -``` - - ### Check it You should be able to check it in your Docker container's URL, for example: http://192.168.99.100/items/5?q=somequery or http://127.0.0.1/items/5?q=somequery (or equivalent, using your Docker host). diff --git a/docs/release-notes.md b/docs/release-notes.md index b8c5ab9ca..1cc2d7acb 100644 --- a/docs/release-notes.md +++ b/docs/release-notes.md @@ -1,5 +1,7 @@ ## Next +* Add deployment documentation for Docker in Raspberry Pi and other architectures. + * Trigger Docker images build on Travis CI automatically. PR #65. ## 0.7.0