На прошлой неделе инженеры компании Uber рассказали в своём блоге о том, как они создали собственное решение для интернет-общения, схожее с популярными Slack и HipChat, но основанное на свободном продукте Mattermost. Их детище получило название uChat.
В компании Uber работают 14 тысяч человек, а её операции распределены по 620 городам мира. Раньше в качестве корпоративного онлайн-чата в Uber использовали популярный сервис Slack, а около года назад (весной 2016) перешли на его конкурента — Atlassian HipChat. Однако оба этих продукта не удовлетворяли потребностям Uber в «надёжном общении сотрудников на десктопах и мобильных устройствах вне зависимости от их местонахождения в мире». Основные требования Uber к онлайн-чату — это масштабируемость для растущего числа сотрудников с учётом сопутствующих расходов, а также простая интеграция с многочисленными инструментами, решающими инженерные, эксплуатационные и бизнес-задачи.
Инженеры Uber начали свои поиски с технологии Internet Relay Chat (IRC) и последующего тестирования существующих альтернатив, а пришли к созданию собственной платформы обмена сообщениями uChat, в которой активно применяются Open Source-продукты: чат Mattermost и система управления конфигурациями Puppet (корпоративный стандарт в Uber). Инженерам компании удалось перейти на новое решение за 3 месяца, обеспечив стабильную доставку более 1 миллиона сообщений в день для десятков тысяч пользователей в едином окружении.
Основные работы Uber с Mattermost были нацелены на производительность: инженеры стремились гарантировать стабильное функционирование чата для случая с 70 тысячами одновременно присутствующих там пользователей и отправляющих от 80 до 200 сообщений в секунду. Для этого были созданы специальные нагрузочные тесты (опубликованы на GitHub), а также проведён анализ пользовательского интерфейса (например, «существующие интерфейсы не позволяли производить поиск более чем по 20 тысячам каналов одновременно»), по итогам чего были сделаны необходимые изменения в коде. Далее была разработана схема деплоя нового чата с применением подхода IaC (инфраструктура как код) на базе Puppet (с модулем Puppet Code Manager). Завершающий этап — создание своих пользовательских интерфейсов (на базе React Native) для мобильных устройств на базе iOS и Android. Последние наработки тоже выложены как Open Source на GitHub.
Итог — достижение 99,9-процентной доступности с uChat, после чего использование старой системы для общения было прекращено. Инженеры Uber планируют реализовать больше возможностей в ближайшие месяцы, следуя обратной связи от своих пользователей, и внедрить в uChat дополнительные улучшения от Mattermost и его Open Source-сообщества.
На прошлой неделе в блоге облачной платформы Microsoft Azure был представлен новый сервис Azure Container Instances (ACI), призванный упростить деплой контейнеров, а вместе с ним — ACI Connector for Kubernetes.
Представленные Azure Container Instances являются новым способом Azure предоставлять контейнеры «с большой простотой и скоростью, без необходимости в управлении какой-либо инфраструктурой виртуальных машин» — проще говоря, они позиционируются как самый простой путь для запуска контейнера в облаке Azure. Сегодня ACI работают в режиме предварительной версии и поддерживают только Linux-контейнеры, а поддержка Windows должна появиться в ближайшие недели.
Azure Container Instances не стоит путать с инструментами для оркестровки контейнеров, поскольку ACI не заменяют их, а лишь предоставляют строительные блоки для их функционирования. Однако одновременно с анонсом ACI корпорация Microsoft анонсировала и свой Open Source-проект ACI Connector for Kubernetes, который реализует для кластеров Kubernetes возможность деплоя контейнеров Azure Container Instances. Новый инструмент использует консольную утилиту kubectl и является экспериментальным. Код ACI Connector for Kubernetes написан на языке TypeScript и опубликован под свободной лицензией MIT на GitHub.
Одновременно с этим архитектор Azure Джон Госсман (John Gossman) объявил о том, что Microsoft стала платиновым членом некоммерческой организации Cloud Native Computing Foundation (CNCF), развивающей ряд Open Source-проектов для контейнеров и облачной (cloud-native) инфраструктуры. В управляющий совет CNCF от Microsoft вошёл Гейб Монрой (Gabe Monroy), старший менеджер по контейнерам в Microsoft Azure и бывший технический директор компании Deis, которую ранее в этом году поглотила Microsoft.