ИМ
Игорь Максимов11 декабря 2018 г. 6:56

django и celery на разных серверах

django, celery

Доброго времени суток. Интересует такой вопрос как разнести приложение django и приложение celery на разные сервера.
Тоесть имею:
2 сервера в одной локальной сети web-server и storage. web-server у меня выполняет роль собственно веб-сервера с приложением, а storage выполняет роль хранилища для видео-контента. Сейчас у меня на web-server крутится приложение, celery+redis+ffmpeg(связка для конвертирования видео-контента). storage же сейчас выполнят только роль хранилища.
Хочу распределить нагрузку на 2 сервера чтобы операция конвертирования велась не на web-server а на storage.
Каким образом это все можно организовать?

Рекомендуем хостинг TIMEWEB
Рекомендуем хостинг TIMEWEB
Стабильный хостинг, на котором располагается социальная сеть EVILEG. Для проектов на Django рекомендуем VDS хостинг.

Вам это нравится? Поделитесь в социальных сетях!

9
Evgenii Legotckoi
  • 11 декабря 2018 г. 7:03

Добрый день.

Я пока с такой задачей не сталкивался, но когда столкнусь, то первое, что сделаю, то просто подниму оба инстанса приложения на обоих серверах. Если весь бэкенд написан в одном приложении web+celery.

И просто разнесу нагрузку с помощью nginx. Для команд конвертирования должны быть в данном случае отдельные вьюшки сделаны, а nginx будет отправлять запросы конвертирования в сторону сервера storage. Но это если у вас бэкенд web приложения отвечает за старт конвертирования и т.д.

Запросы в данном случае правильно будет через nginx маршрутизировать.

А потом уже спокойно написал бы полностью отдельное приложение, которое будет отвечать за всю эту кухню по конвертации.

    Илья Чичак
    • 11 декабря 2018 г. 7:18

    У вас не получится передать нормально сообщение в целери на другом сервере. Даже если будет один и тот же проект на разных хостах. Как вариант - вынести логику обработки в отдельное приложение, его разместить на втором сервере и снабдить каким-нибудь API. И заставить первое приложение отсылать запрос на второй сервер для запуска какой-либо обработки.

      Evgenii Legotckoi
      • 11 декабря 2018 г. 7:25
      • (ред.)

      Теоретически, можно просто через nginx слать все запросы, касающиеся загрузки, конвертации и работы с celery в сторону storage сервера.

      Это должно работать, если не смешивать одно с другим на одном сервере. Фактически одно приложение и будет получаться.

      В противном случае не работал бы вариант с большим количеством серверов и большим количеством инстансов приложения для балансировки нагрузки. А я уверен, что у того же самого инстаграмма, который также базируется на Django имеются подобные варианты.

        Илья Чичак
        • 11 декабря 2018 г. 8:56
        • (ред.)
        • Ответ был помечен как решение.

        Я тут подумал:

        Допустим, мы разворачиваем один и тот же проект на двух тачках. На одной из них запускаем redis, rabbitmq. при этом рэбита мы запускаем в сетевом режиме: https://www.rabbitmq.com/networking.html (только при условии, что тачка с рэбитом не светит наружу, иначе дыра в безопасности). оба проекта смотрят на рэббита на второй машине. celery workers запускаются на второй машине.

        впринципе должно работать=)

        Главное, чтобы машина с рэббитом была недоступна извне, только с первой.

          Evgenii Legotckoi
          • 11 декабря 2018 г. 9:26

          Главное, чтобы машина с рэббитом была недоступна извне, только с первой.

          Пожалуй либо так, не пробовал, но примерно о таком и думал. Просто в тачку с рэббитом можно пускать через шлюзовой nginx на первой машине только по определённым запросам например.

            ИМ
            • 11 декабря 2018 г. 10:41

            Да, так все работает. Спасибо вам.
            Еще маленький вопросик по проекту на 2 серверах: Если мысль их синхронизировать средствами rsync или же монтировать средствами nfs с первого сервера на второй?

              Илья Чичак
              • 11 декабря 2018 г. 11:01
              • (ред.)

              Имеете в виду, чтобы код проекта размазывался по обоим серверам?

              Если да, то категорически не советую.

              Запуская сервер джанго через гуникорн, он полностью инициализирует проект. Если в этот момент синхронизация не закончилась - все, приехали.

              Вариант с NFS - дополнительная нагрузка на сеть. (Правда это всего лишь попытка отговорить=))

              В целом, есть ряд проблем и возможных проблем :

              1. В будущем возможно возникновение дополнительных настроек специфичных для конкретного сервера
              2. В настоящем - все равно требуется перезапуск сервиса или какой там у вас способ запуска проекта используется=)

              Варианты решения проблемы:

              1. Написать на основном сервере bash скрипт, который будет разворачивать проект, а потом ходить по ssh на второй и делать то же самое=)
              2. Почитать про различные системы деплоя, типа ansible (правда там есть свои ограничения, тонкости и нюансы)

              для баш скрипта - все крайне просто:

              1. git pull
              2. pip install -r requirements.txt
              3. sudo service nginx restart
              4. sudo service gunicorn restart
              5. sudo service celery_worker_restart
              6. ssh server2
              7. повторить

              =)

              НАПИСАНИЕ СКРИПТОВ НА BASH

              ФУНКЦИИ BASH В СКРИПТАХ

              кстати, опять же, этот скрипт будет очень удобно хранить в репозитории. так будет возможность из любого места запустить процесс (в отличии от ансибла, где он должен быть установлен и сконфигурирован на машине, с которой запускается процесс)

                Илья Чичак
                • 11 декабря 2018 г. 11:02
                • (ред.)

                кстати, списки странно рендерятся из маркдауна=) там с красивым супом случайно перебор не случился?=)

                а, не, сам дурак=) меня почему-то переклинило, что список делается через

                1)
                , а не
                1.

                  ИМ
                  • 12 декабря 2018 г. 7:07

                  Нет. тут все проще, и никаких скриптов думаю не нужно. Там где у меня запускается redis+celery+ffmpeg нужно всего лишь одно приложение для конвертации которое статическое. Весь проект туда не обязательно шмалять.

                    Комментарии

                    Только авторизованные пользователи могут публиковать комментарии.
                    Пожалуйста, авторизуйтесь или зарегистрируйтесь
                    AD

                    C++ - Тест 004. Указатели, Массивы и Циклы

                    • Результат:50баллов,
                    • Очки рейтинга-4
                    m
                    • molni99
                    • 26 октября 2024 г. 11:37

                    C++ - Тест 004. Указатели, Массивы и Циклы

                    • Результат:80баллов,
                    • Очки рейтинга4
                    m
                    • molni99
                    • 26 октября 2024 г. 11:29

                    C++ - Тест 004. Указатели, Массивы и Циклы

                    • Результат:20баллов,
                    • Очки рейтинга-10
                    Последние комментарии
                    i
                    innorwall15 ноября 2024 г. 8:26
                    Qt/C++ - Урок 031. QCustomPlot - строим график по времени buy generic priligy We can just chat, and we will not lose too much time anyway
                    i
                    innorwall15 ноября 2024 г. 6:03
                    Qt/C++ - Урок 060. Настройка внешнего вида приложения в рантайме I didnt have an issue work colors priligy dapoxetine 60mg revia cost uk August 3, 2022 Reply
                    i
                    innorwall14 ноября 2024 г. 22:42
                    Как Копировать Файлы в Linux If only females relatives with DZ offspring were considered these percentages were 23 order priligy online uk
                    i
                    innorwall14 ноября 2024 г. 20:09
                    Qt/C++ - Урок 068. Hello World с использованием системы сборки CMAKE в CLion ditropan pristiq dosing With the Yankees leading, 4 3, Rivera jogged in from the bullpen to a standing ovation as he prepared for his final appearance in Chicago buy priligy pakistan
                    Сейчас обсуждают на форуме
                    i
                    innorwall14 ноября 2024 г. 14:39
                    добавить qlineseries в функции priligy amazon canada 93 GREB1 protein GREB1 AB011147 6
                    i
                    innorwall11 ноября 2024 г. 21:55
                    Всё ещё разбираюсь с кешем. priligy walgreens levitra dulcolax carbs The third ring was found to be made up of ultra relativistic electrons, which are also present in both the outer and inner rings
                    9
                    9Anonim25 октября 2024 г. 19:10
                    Машина тьюринга // Начальное состояние 0 0, ,<,1 // Переход в состояние 1 при пустом символе 0,0,>,0 // Остаемся в состоянии 0, двигаясь вправо при встрече 0 0,1,>…
                    ИМ
                    Игорь Максимов3 октября 2024 г. 14:05
                    Реализация навигации по разделам Спасибо Евгений!

                    Следите за нами в социальных сетях