63 lines
7.2 KiB
Markdown
63 lines
7.2 KiB
Markdown
1. Зачем сложные системы (например, социальная сеть ВКонтакте) пишутся в "распределенном" стиле, где каждое отдельное приложение
|
||
(или сервис) функционально выполняет только ограниченный спектр задач?
|
||
|
||
Их пишут в таком стиле, чтобы если один из серверов "упадет", то другие смогут поддерживать работу приложения. Таким образом, если бы
|
||
ВКонтакте писался на монолите, то все приложение со всеми функциями не было бы доступно. В случае же с распределенным, какой-то отдельный
|
||
функционал или мини-приложение может не работать, но это не так глобально и не так ощущается пользователями, как если бы приложение
|
||
не работало целиком. Такие системы отказоустойчивы, а также более надежны и производительны.
|
||
|
||
2. Для чего были созданы системы оркестрации приложений?
|
||
Каким образом они упрощают / усложняют разработку и сопровождение распределенных систем?
|
||
|
||
Оркестрация - автоматическое размещение, координация и управление сложными компьютерными системами и службами. Условно, определяют систему
|
||
в контейнеры и управляет ими, отслеживает, как они работают, управляет жизненным циклом контейнеров.
|
||
|
||
Они были созданы для автоматизации процессов, управления инфраструктурой и масштабируемости.
|
||
|
||
Упрощают развертывание и обновление приложений, помогают отслеживать зависимость между сервисами и обеспечивают их корректное взаимодействие.
|
||
|
||
Усложняют из-за сложности настройки и постепенного увеличения числа компонентов.
|
||
|
||
3. Для чего нужны очереди обработки сообщений и что может подразумеваться под сообщениями?
|
||
|
||
Очереди обработки сообщений — это важный компонент архитектуры распределенных систем, который обеспечивает асинхронную и надежную передачу
|
||
данных между различными компонентами или сервисами.
|
||
|
||
Очереди поддерживают асинхронность, то есть возможность работы компонентов независимо друг от друга, что значит, что один компонент может
|
||
отправить сообщение в очередь и продолжить свою работу, не дожидаясь его обработки.
|
||
|
||
Надежность - использование очередей уменьшают вероятность потери сообщений.
|
||
|
||
Также очереди помогают распределять нагрузку между приложениями.
|
||
|
||
Под сообщениями могут подразумеваться:
|
||
События: Информация о том, что произошло в системе. Например, "пользователь зарегистрировался", "заказ был размещен", "файл был загружен".
|
||
|
||
Команды: Указания другим компонентам системы выполнить какие-то действия, например, "обработать платеж", "выполнить задачу" или "отправить уведомление".
|
||
|
||
Данные: Конкретные данные, которые необходимо передать, например, JSON-объект с информацией о заказе или текст сообщения.
|
||
|
||
Запросы: Запросы на получение информации или выполнения определенных операций, которые могут быть обработаны позже.
|
||
|
||
Ошибки или уведомления: Информация о проблемах или событиях, требующих внимания, например, "не удалось записать данные в базу" или "недостаточно прав".
|
||
|
||
4. Какие преимущества и недостатки распределенных приложений существуют на Ваш взгляд?
|
||
|
||
Преимущества заключаются в масштабируемости, отказоустойчивости и производительности. Также важную роль играет гибкость - можно разрабатывать
|
||
и тестировать компоненты независимо друг от друга. Из этого также следует разделение ответственности - отдельные компоненты отвечают за
|
||
конкретные задачи.
|
||
|
||
К недостаткам я бы отнесла сложность разработки, меньшую степень безопасности, а также проблемы с сетью. Из-за того, что компоненты разделены
|
||
по разным узлам, это может привести к задержкам в работе. Касательно безопасности, распределенные системы больше подвержены атакам из-за
|
||
большого количества узлов.
|
||
|
||
|
||
5. Целесообразно ли в сложную распределенную систему внедрять параллельные вычисления?
|
||
Приведите примеры, когда это действительно нужно, а когда нет.
|
||
|
||
Это нужно, когда существует необходимость в обработке больших данных, в научных вычислениях, сложных вычислительных задачах и
|
||
обработке событий в реальном времени.
|
||
|
||
Это нецелесообразно внедрять в систему, когда существуют сложные алгоритмы с последовательной логикой или частыми взаимодействиями,
|
||
а также когда речь идет о небольших и простых в вычислении задач.
|