Giter Site home page Giter Site logo

fastapi-nginx's Introduction

Данный проект используется в практической работе по изучению Nginx, а именно работе с обратным проксированием и с балансировкой нагрузки.

Порядок использования:

  1. Клонируем репозиторий:
$ git clone https://github.com/RuslanUsmanov/fastapi-nginx.git
  1. Создаем виртуальное окружение:
$ cd fastapi-nginx
$ python3 -m venv venv
  1. Активируем окружение и устанавливаем зависимости:
$ source venv/bin/activate
$ pip install -r requirements.txt
  1. Запускаем FastAPI c помощью uvicorn:
$ uvicorn src.main:app --port 8000
  1. Открываем в браузере http://localhost:8000/api/docs и проверяем работу FastAPI.
  2. Редактируем конфигурацию Nginx:
upstream backend {
        server localhost:8000;
    }

server {
    listen 80;
    server_name my.server.com;
    ...
    location /api {
        proxy_pass http://backend;
    }
    ...
}
  1. Перезапускаем Nginx.

  2. Открываем в браузере http://my.server.com/api/ и убеждаемся что обратное проксирование работает.

  3. Для балансировки нагрузки запускаем еще 1-2 экземпляра FastAPI на других портах, и дописываем сервера в секции upstream, например:

upstream backend {
        server localhost:8000 weight=3;
        server localhost:8001;
        server localhost:8002;
    }
При данной конфигурации каждые 5 запросов будут обрабатываться следующим образом: три запроса будут направлены на сервер на порту 8000, на сервера с портами 8001 и 8002 будет отправлено по одному запросу.
  1. Проверку балансировки можно осуществить путем обращения по адресу http://my.server.com/api/getpid. Данный API будет возвращать PID экземпляра FastAPI, обработавшего запрос.

Для запуска в Docker

  1. Собираем образ:
$ docker build -t имя_образа .
  1. Запускаем в контейнере:
$ docker run --rm -d -p 8080:80 имя_образа

Справка по используемым ключам:

 --rm - удалить контейнер после его остановки;

 -d - отсоединить потоки ввода/вывода от терминала;

 -p проброс портов, в данном случае 80-ый порт контейнера пробрасывается в порт 8080 хоста.
  1. Для подключения в файловую систему контейнера:
$ docker exec -it id_или_имя_контейнера bash

Справка по используемым ключам:

 -i - оставить стандартный поток ввода контейнера открытым;

 -t - подключить tty контейнера к текущему терминалу.

fastapi-nginx's People

Contributors

ruslanusmanov avatar

Watchers

 avatar

Recommend Projects

  • React photo React

    A declarative, efficient, and flexible JavaScript library for building user interfaces.

  • Vue.js photo Vue.js

    🖖 Vue.js is a progressive, incrementally-adoptable JavaScript framework for building UI on the web.

  • Typescript photo Typescript

    TypeScript is a superset of JavaScript that compiles to clean JavaScript output.

  • TensorFlow photo TensorFlow

    An Open Source Machine Learning Framework for Everyone

  • Django photo Django

    The Web framework for perfectionists with deadlines.

  • D3 photo D3

    Bring data to life with SVG, Canvas and HTML. 📊📈🎉

Recommend Topics

  • javascript

    JavaScript (JS) is a lightweight interpreted programming language with first-class functions.

  • web

    Some thing interesting about web. New door for the world.

  • server

    A server is a program made to process requests and deliver data to clients.

  • Machine learning

    Machine learning is a way of modeling and interpreting data that allows a piece of software to respond intelligently.

  • Game

    Some thing interesting about game, make everyone happy.

Recommend Org

  • Facebook photo Facebook

    We are working to build community through open source technology. NB: members must have two-factor auth.

  • Microsoft photo Microsoft

    Open source projects and samples from Microsoft.

  • Google photo Google

    Google ❤️ Open Source for everyone.

  • D3 photo D3

    Data-Driven Documents codes.