Яндекс открыл доступ к фреймворку для создания приложений с микросервисной архитектурой

02.08.2022      7735

Инструмент Userver опубликован как бесплатное open source решение. «Яндекс» уже несколько лет эффективно его использует в своих приложениях Go, «Еда», «Лавка», «Доставка» и другие. Фреймворк находится в стадии бета – переезда на открытую разработку.

Особенности разработки

«Яндекс» опубликовал исходный код Userver на GitHub, где также доступна документация к фреймворку, примеры использования и шаблоны для создания собственных сервисов. Все материалы доступны по свободной лицензии Apache 2.0. Инструмент позволяет вести разработку на языке C++.

При создании Userver компания опиралась на три принципа:

  • Простота. По словам представителей компании, стажеры при помощи фреймворка могут написать новый микросервис за неделю.
  • Надежность. Платформа помогает отслеживать ошибки на этапе компиляции и дает подсказки по устранению проблем.
  • Полнота. Userver поддерживает инструменты для тестирования, кэширования, логирования, использования баз данных, JSON, BSON, YAML и другие.

Ключевые возможности

Изначально Userver создавался для переноса приложения «Яндекс.Такси» с монолитной архитектуры на микросервисную. Фреймворк представляет собой корутинный движок для асинхронного взаимодействия по CPU с операционной системой. Языком разработки был выбран C++ благодаря возможности переиспользовать старый код, отсутствию привязки к конкретному вендору и поддержке статической типизации. Внутренняя архитектура инструмента заточена на максимально эффективное решение задач ожидания ввода-вывода.

При разработке приложения на Userver разработчику достаточно писать линейный код. Движок фреймворка самостоятельно обеспечивает эффективное использование кода, переключаясь на выполнение других корутин в специально отмеченных местах. Поэтому программа не простаивает в ожидании данных от ОС, а обрабатывает другие запросы.

 

Пример кода

 

В качестве преимуществ Userver в «Яндексе» отмечают применение языка C++. Если кодовая база на «плюсах», то удастся избежать внедрения нового языка и переписывания исходников. Также российский инструмент сразу предлагает всю необходимую функциональность.

Планы на будущее

Сейчас доступна лишь бета-версия фреймворка. В «Яндексе» рассказали, что Userver уже несколько лет успешно применяется в сотнях высоконагруженных сервисов компании.

Компания намерена развивать фреймворк как open source решение. Ближайшие доработки будут во вспомогательных репозиториях. Они коснутся улучшения сервиса динамической конфигурации, добавления новых примеров использования, внедрения новый функций, таких как приоритизация таск-процессоров. После этого компания выпустит первый релиз Userver.


Автор:
Аналитик


См. также

Новость Искусственный интеллект ИТ-Новость

ИИ научат разработке цифровых интегральных микросхем – несколько российских научных институтов заявили об участии в проекте. Проект рассчитан на 3 года – с 2024 по 2026.

23.07.2024    197    user1915669    0       

1

Новость Дата-центры Искусственный интеллект ИТ-Новость

Развитие искусственного интеллекта и цифровых сервисов в России стало причиной роста потребности в мощных центрах обработки данных. Эксперты прогнозируют, что дефицит ЦОД, который уже наблюдается сегодня, в ближайшие годы будет только усиливаться.

18.07.2024    356    AnastasiaKl    0       

1

Новость ИТ-Новость

В сентябре 2024 года видеоигры в России начнут маркировать – пока на добровольной основе. Геймерам будут сообщать о семи видах чувствительного (неприятного) контента в игре.

17.07.2024    409    user1915669    0       

1

Новость Законодательство ИТ-Новость

Депутаты Госдумы работают над законопроектом по ужесточению контроля за электросамокатами. Среди мер: обязательная регистрация СИМ (средств индивидуальной мобильности) и разработка системы отслеживания их перемещений.

10.07.2024    521    AnastasiaKl    2       

1

Новость Искусственный интеллект ИТ-Новость

В 2024 году «Сколково» выделит пилотным проектам в сфере искусственного интеллекта гранты на общую сумму 554 млн рублей. В результате отбора финансирование получат проекты с применением ИИ в областях производства, операционной деятельности и в работе предоставляемых сервисов.

12.04.2024    1057    AnastasiaKl    3       

3

Новость ИТ-Новость

Пятничное: в России вступил в силу стандарт подготовки по дисциплине «спортивное программирование». В стандарт вошли требования к физическим показателям спортсменов и скорости набора текста.

16.02.2024    858    VKuser24342747    2       

1

Новость ИТ-Новость

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

19.01.2024    651    VKuser24342747    0       

2

Новость Законодательство ИТ-Новость

12 декабря вступил в силу Федеральный закон, меняющий срок, к которому все владельцы сайтов должны внести изменения в порядок авторизации пользователей на сайте. Закон вводит переходный период до 1 января 2025 года.

20.12.2023    795    VKuser24342747    2       

1
Комментарии
Подписаться на ответы Инфостарт бот Сортировка: Древо развёрнутое
Свернуть все
1. Axe 02.08.22 19:16 Сейчас в теме
И закрыл возможность загружать файлы больше 1Гб в яндекс диск. Волшебная компания, при упоминании которой начинается рвотный рефлекс.
Мне куда теперь базы данных загружать, в Google ? Американцам сливать ? В руководстве Яндекса исключительные кретины.
Lem0n; Aphanas; Obertone; sapervodichka; +4 3 Ответить
2. papami 56 02.08.22 19:40 Сейчас в теме
(1) Вы сейчас говорите про халяву?
Не знаю чем Вы занимаетесь. Представьте кто-то говорит. Этот Axe работает за деньги, а бесплатно не хочет работать, мне что теперь к другому специалисту обращаться?
Silenser; +1 Ответить
5. Axe 03.08.22 02:26 Сейчас в теме
(2) Не совсем корректный пример. Повторюсь. Есть google у которого нет таких ограничений и уверен есть и другие сервисы без этих ограничений.
К примеру Rutube всю жизнь был дохлой площадкой, именно из-за рекламы, им невозможно было пользоваться.
Логично предположить, что написав коммент на этом ресурсе про базы, занимаюсь я 1С.
Я к тому что, разработчики совсем не думают о внутренних пользователях. Зато американцы с удовольствием предоставляют нам свои, причем бесплатно.
Речь о консолидации IT сферы России и внутренней безопасности страны.
Получается что из-за яндекса в америку утекают наши данные. Из-за жадности содрать лишние 100 рублей.
8. mrChOP93 97 03.08.22 06:28 Сейчас в теме
(5)
Получается что из-за яндекса в америку утекают наши данные. Из-за жадности содрать лишние 100 рублей.

Получается что из-за погромиста в америку утекают наши данные. Из-за жадности заплатить за удобный сервис лишние 100 рублей.
papami; user788221; +2 3 Ответить
17. papami 56 03.08.22 20:46 Сейчас в теме
(8) Если копнуть глубже - из-за "программиста", который не знает как разбить один большой файл на несколько маленьких, чтобы "обойти" защиту от нубов.

Но основная проблема не в утечках данных, не в том как такие "программисты" мыслят и какие аргументы они приводят в спорах. Проблема в том, что в спорах они представляются "программистами 1С", специалистами из сферы 1С, выражают как-то иначе свою связь с 1С, тем самым представляют целую отрасль и опускают ее ниже плинтуса в глазах тех, кто реально знает, о чем говорит.
FatPanzer; mrChOP93; +2 Ответить
15. papami 56 03.08.22 20:00 Сейчас в теме
(5) Подобный ход мыслей напоминает мультик "Добро пожаловать!" (1986). Про лося, который сначала всех добродушно приютил у себя на рогах, а потом они ему начали высказывать свои претензии, что он ни туда идет и т.д.))))

Здесь присутствуют люди из разных областей, ну собственно, с примером я не сильно ошибся.
Про логику сложно говорить, с учетом Вашей позиции по халяве и той причинно-следственной связи, которую Вы вывели про Яндекс и утечку Ваших данных.

По поводу консолидации IT сферы, с удовольствием ознакомлюсь с Вашим личным вкладом на пользу страны на бесплатной основе.
3. webester 26 02.08.22 19:50 Сейчас в теме
(1)Удивительное дело, новость, про микросервисы, но всегда найдется человек которому обидно, что компания не хочет бесплатно выполнять его хотелки. На тему
Мне куда теперь базы данных загружать, в Google
На эту тему холивары начались триста лет назад, когда яндекс сначала вообще запретил, а потом разрешил, но начал резать скорость по всяким оберткам для аплодов типа rclone. Техподдержка так и сказала, Яндекс диск, для домашнего использования, для коммерческого использования (в том числе, чтобы хранить базы)будьте добры используйте наше прекрасное Yandex Object Storage. Я никого не оправдываю, но тоже считаю, что все стоит денег(в случае с диском, там вообще копейки), в том числе работа серверов. И да ваши базы не нужны не американцам не русским, ни даже вашему соседу. Только вам. Поэтому смело грузите на гугл диск, в крайнем случае можно шифровать, либо архиватором, либо тем же самым rclone
Perfolenta; Drivingblind; mrChOP93; Obertone; +4 Ответить
6. Axe 03.08.22 02:30 Сейчас в теме
(3) ни рубля не отдам криворуким и жадным разработчикам яндекса, которые ни поисковик не могут нормальный сделать, ни браузер, который из каждой дырки навязывает всего его везде поставить по дефолту. Это просто взрыв мозга пользоваться их сервисами, которые они пишут ногами
Aphanas; dima_home; Obertone; +3 Ответить
11. eiv76 03.08.22 09:20 Сейчас в теме
(6) Как Вы любите свой мозг взрывать, раз продолжаете пользоваться, ведь оценка, это результат сравнения. Поскольку сравниваете значит сравнивали с более лучшими ресурсами. Получается как в анекдоте."Ежик кололся и плакал, но продолжал лезть на кактус"
Perfolenta; papami; +2 Ответить
12. Axe 03.08.22 13:43 Сейчас в теме
(11) Я патриот своей страны, и хочу чтобы в моей стране были качественные сервисы. На минуточку, сейчас 2022 год. Где в Яндекс поиске Тёмная тема ? И не надо тут про браузер рассказывать. Вопрос именно про поисковик.
16. papami 56 03.08.22 20:08 Сейчас в теме
(12)
Чтобы в стране были качественные сервисы, и вообще - софт. Нужно начать с себя. Стать спецом хотя бы в своей сфере.

По поводу отсутствия темной темы в поисковике - это реально драма конечно. Нужно консолидировать всю IT-сферу страны и отмечать соответствующий день отсутствия Темной темы в поиске Яндекса раз в год.
4. sapervodichka 6867 03.08.22 00:39 Сейчас в теме
(1)
возможность загружать файлы больше 1Гб в яндекс диск

спасибо за инфу, в натуре ))) я и не знал. Лично я там подписку делал на 1Тб (700 руб/год), т.к. тоже часто базы гоняю, заплатил вообщем за хороший сервис, возможность загружать большие файлы есть, а 700 руб небольшая справедливая цена.
alex_bob; Drivingblind; Obertone; Светлый ум; +4 1 Ответить
13. reset2 17 03.08.22 17:27 Сейчас в теме
(4) Мне показывает 2290 при оплате на год. Как за 700 получить?
14. sapervodichka 6867 03.08.22 18:27 Сейчас в теме
(13) я не помню уже, может за хорошее поведение, но у меня 700 руб. именно Диск, а не весь Яндекс + (весь примерно 2500 в год)
Прикрепленные файлы:
18. reset2 17 03.08.22 22:25 Сейчас в теме
(14) я тоже себя хорошо вел( Но ты видимо лучше.
Прикрепленные файлы:
sapervodichka; +1 Ответить
19. sapervodichka 6867 03.08.22 22:40 Сейчас в теме
(18) капец цена ))
7. webester 26 03.08.22 03:00 Сейчас в теме
(6)Н - ненависть. Разработчик яндекса увел жену? Бывает) тогда непонятно, чем вам так не угодило ограничение в сервисе, которым вы не пользуетесь. Как вообще могут вызывать столько злобы продукты которыми не пользуешься. Я с удовольствием плачу за музыку, держу в курсе, яндекс музыку писали уже не ногами, чем-то чуть выше, может быть даже руками(но это не точно) предложка вроде адекватная, музыки много да и книги есть. Пользоваться удобно. И бонусом еще фильмы с сериалами. Диском не пользуюсь, а так возможно и ограничения нет на размер файла. В связи с подпиской +
user788221; +1 1 Ответить
9. titanium2008 45 03.08.22 09:00 Сейчас в теме
Ж - жадность.
10. alex_bob 246 03.08.22 09:16 Сейчас в теме
Прикольное объяснение названия проекта прочитал на habr. Когда прочитал его первый раз, подумал, при чем здесь User? Оказывается, логика такая
Микросервер -> микро - греческая μ -> u (вроде бы распространенная замена). Получается u-server или Userver.
Оставьте свое сообщение