Данный проект используется в практической работе по изучению Nginx, а именно работе с обратным проксированием и с балансировкой нагрузки.
Порядок использования:
- Клонируем репозиторий:
$ git clone https://github.com/RuslanUsmanov/fastapi-nginx.git
- Создаем виртуальное окружение:
$ cd fastapi-nginx
$ python3 -m venv venv
- Активируем окружение и устанавливаем зависимости:
$ source venv/bin/activate
$ pip install -r requirements.txt
- Запускаем
FastAPI
c помощьюuvicorn
:
$ uvicorn src.main:app --port 8000
- Открываем в браузере http://localhost:8000/api/docs и проверяем работу FastAPI.
- Редактируем конфигурацию Nginx:
upstream backend {
server localhost:8000;
}
server {
listen 80;
server_name my.server.com;
...
location /api {
proxy_pass http://backend;
}
...
}
-
Перезапускаем Nginx.
-
Открываем в браузере http://my.server.com/api/ и убеждаемся что обратное проксирование работает.
-
Для балансировки нагрузки запускаем еще 1-2 экземпляра FastAPI на других портах, и дописываем сервера в секции
upstream
, например:
upstream backend {
server localhost:8000 weight=3;
server localhost:8001;
server localhost:8002;
}
При данной конфигурации каждые 5 запросов будут обрабатываться следующим образом: три запроса будут направлены на сервер на порту 8000, на сервера с портами 8001 и 8002 будет отправлено по одному запросу.
- Проверку балансировки можно осуществить путем обращения по адресу http://my.server.com/api/getpid. Данный API будет возвращать PID экземпляра FastAPI, обработавшего запрос.
- Собираем образ:
$ docker build -t имя_образа .
- Запускаем в контейнере:
$ docker run --rm -d -p 8080:80 имя_образа
Справка по используемым ключам:
--rm - удалить контейнер после его остановки;
-d - отсоединить потоки ввода/вывода от терминала;
-p проброс портов, в данном случае 80-ый порт контейнера пробрасывается в порт 8080 хоста.
- Для подключения в файловую систему контейнера:
$ docker exec -it id_или_имя_контейнера bash
Справка по используемым ключам:
-i - оставить стандартный поток ввода контейнера открытым;
-t - подключить tty контейнера к текущему терминалу.