ИМ
Игорь МаксимовDec. 11, 2018, 5:56 p.m.

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

django, celery

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

We recommend hosting TIMEWEB
We recommend hosting TIMEWEB
Stable hosting, on which the social network EVILEG is located. For projects on Django we recommend VDS hosting.

Do you like it? Share on social networks!

9
Evgenii Legotckoi
  • Dec. 11, 2018, 6:03 p.m.

Добрый день.

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

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

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

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

    Илья Чичак
    • Dec. 11, 2018, 6:18 p.m.

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

      Evgenii Legotckoi
      • Dec. 11, 2018, 6:25 p.m.
      • (edited)

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

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

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

        Илья Чичак
        • Dec. 11, 2018, 7:56 p.m.
        • (edited)
        • The answer was marked as a solution.

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

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

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

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

          Evgenii Legotckoi
          • Dec. 11, 2018, 8:26 p.m.

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

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

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

              Илья Чичак
              • Dec. 11, 2018, 10:01 p.m.
              • (edited)

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

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

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

              Вариант с 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 В СКРИПТАХ

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

                Илья Чичак
                • Dec. 11, 2018, 10:02 p.m.
                • (edited)

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

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

                1)
                , а не
                1.

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

                    Comments

                    Only authorized users can post comments.
                    Please, Log in or Sign up
                    Ua

                    Qt - Test 001. Signals and slots

                    • Result:84points,
                    • Rating points4
                    Ua

                    Qt - Test 001. Signals and slots

                    • Result:42points,
                    • Rating points-8
                    ОК

                    Qt - Test 001. Signals and slots

                    • Result:47points,
                    • Rating points-6
                    Last comments
                    ИМ
                    Игорь МаксимовNov. 22, 2024, 9:51 p.m.
                    Django - Tutorial 017. Customize the login page to Django Добрый вечер Евгений! Я сделал себе авторизацию аналогичную вашей, все работает, кроме возврата к предидущей странице. Редеректит всегда на главную, хотя в логах сервера вижу запросы на правильн…
                    Evgenii Legotckoi
                    Evgenii LegotckoiOct. 31, 2024, 11:37 p.m.
                    Django - Lesson 064. How to write a Python Markdown extension Добрый день. Да, можно. Либо через такие же плагины, либо с постобработкой через python библиотеку Beautiful Soup
                    A
                    ALO1ZEOct. 19, 2024, 5:19 p.m.
                    Fb3 file reader on Qt Creator Подскажите как это запустить? Я не шарю в программировании и кодинге. Скачал и установаил Qt, но куча ошибок выдается и не запустить. А очень надо fb3 переконвертировать в html
                    ИМ
                    Игорь МаксимовOct. 5, 2024, 4:51 p.m.
                    Django - Lesson 064. How to write a Python Markdown extension Приветствую Евгений! У меня вопрос. Можно ли вставлять свои классы в разметку редактора markdown? Допустим имея стандартную разметку: <ul> <li></li> <li></l…
                    d
                    dblas5July 5, 2024, 8:02 p.m.
                    QML - Lesson 016. SQLite database and the working with it in QML Qt Здравствуйте, возникает такая проблема (я новичок): ApplicationWindow неизвестный элемент. (М300) для TextField и Button аналогично. Могу предположить, что из-за более новой верси…
                    Now discuss on the forum
                    f
                    firstlunoxodFeb. 15, 2025, 1:46 p.m.
                    Рисование на QGraphicsScene при зажатой кнопке мыши Подскажите, пожалуйста! Как данный класс можно дополнить, чтобы созданные объекты можно было перемещать мышкой по сцене?
                    Дмитрий
                    ДмитрийFeb. 3, 2025, 4:24 p.m.
                    Создание deb-пакета. Как создать ярлык на рабочем столе после установки собственного deb-пакета? Всем привет. Сделал свой deb-пакет с программой. Всё устанавливается и работает. Ставлю по пути /usr/bin/my_application. Как для пользователя при установке пакета сразу создать ярлык на раб…
                    NW
                    Nayo WaiJan. 30, 2025, 7:22 p.m.
                    не запускается компьютер!!! Не запускается компьютер (точнее работает блок , но сам монитор вообще жесть)В общем я ничего с интернета не скачивала в последнее время. На компе никаких левых пр…
                    n
                    nklyJan. 3, 2025, 12:52 p.m.
                    Нужно запретить перемещение только некоторых итемов, остальные перемещать можно. Вопрос решен. Узнать QModelIndex элемента на который мы перетаскиваем другой элемент, можно с помощью функции indexAt(event->position().toPoint()) представления QTreeViev вызываемой в переопр…
                    M
                    MarselAug. 17, 2023, 12:26 a.m.
                    OAuth2.0 через VK, получение email Спасибо большое за помощь и простите за то что отнял время своей невнимательностью.

                    Follow us in social networks