Нам нужны твои мозги

Хотите расти как разработчик и найти крутую работу? Не протирайте штаны — займитесь Open Source проектами. Так легче всего попасть в лучшие команды разработчиков и положить себе в резюме настоящий проект, вместо нелепых «примеров кода». Но найти подходящий проект для участия сложно. Начинаются лень и отговорки, а за ними — отсутствие профессионального роста, критики по-настоящему крутых программистов, уныние и застой.

На Cult of Martians мы собираем интересные задачи для современных веб-программистов. Можно выбрать подходящую по сложности, продолжительности и специализации. Задачи не выдуманы «из воздуха» — каждая решает насущную проблему, и решить ее можно через создание нового Open Source проекта или улучшение существующего. Решайте задачи, прокачивайтесь, присылайте решение на оценку. Лучших могут пригласить к себе на работу компании, программистам которых понравится ваше решение.

Бэк: Альтернативная реализация gRPC сервера для AnyCable (PoC)

Для продвинутых, задача на пару дней

AnyCable использует gRPC для коммуникации между сервером веб-сокетов и Ruby приложением. Официальная библиотека для работы с gRPC в Ruby является сложной оберткой над библиотекой на C и имеет проблемы с поддержкой (отставание от версий Ruby, баги, которые медленно закрываются, регрессии производительности).

Компания Cookpad разрабатывает альтернативный SDK для работы с gRPC в Ruby: grpc_kit.

Задача — попробовать переписать RPC сервер AnyCable на grpc_kit.

Польза: познакомиться с AnyCable и gRPC, принести пользу сообществу.

Целью данной задачи является написать proof-of-concept использования grpc_kit для AnyCable — и определить проблемы и недостатки данного решения, если мигрировать не получится. Если же миграция возможна, имеет смысл сравнить производительность официальной библиотеки и grpc_kit (можно, например, использовать k6).

На что стоит обратить внимание:

  • Поддерживаемые параметры конфигурации сервера (например, один из важных параметров для AnyCable — это max_connection_age_ms).
  • Модель конкурентной работы (реализация в gem grpc использует пул тредов для обработки запросов). Например, посмотреть на griffin.

Инструкции по выполнению:

  1. Задать вопросы по задаче и обсудить варианты решения на GitHub.
  2. Форкнуть проект AnyCable на GitHub.
  3. Сделать Pull Request с описанием и бенчмарками (при наличии).