172 похожих чатов

Всем привет. Может я ошибся чатом, заранее извиняюсь если не

по теме пишу.
У нас стоит задача переделать наш legacy сервис, который используется нашими проектами.
В двух словах это куча baremetal'a в разных датацентрах СНГ с единым API, через который мы запускаем игровые сервера (UDP, не нами написанные).
с 2011 года это работает и обновлять ОС, софт и сами игровые сервера это боль. Да еще и каждый отдельный игровой сервер привязан к определенной ноде с определенным ip-адресом. Это неудобно.
Сейчас для нового проекта нам необходимо решить все эти проблемы и то, что тут нужно юзать Docker для сборок игровых серверов, это однозначное решение.
Это дает нам гибкость для автоматического тестирования, выкатывания сразу во все регионы и легкого обновления сборки благодаря layers (скачиваем только мелкие diff's нодах).
Вопрос относительно оркестрации. Насколько уместно тут использовать Kubernetes? Мы хотим умный шедулинг по селекторам, affinity/antiaffinity, да и taints/tolerations куба очень привлекательны, хотим failover в случае падения (то есть перезапуск на другой ноде с минимальным простоем). По сути это stateful, нет никакой балансировки, все пользователи подключаются на один игровой сервер напрямую по указанным ip:port, состояние хранится в памяти и его невозможно реплицировать куда-то. Хотелось бы live migration контейнера в случае maintenance ноды, но с кубом CRIU не работает.
Виртуализация нам не нужна, это ненужный оверхед. Концепция контейнеров идеально нам подходит, т.к. все ворклоады наши.
Также хочется чтобы у каждого контейнера был свой, статический внешний ip-адрес, который бы в случае падения ноды переносился на другую ноду.
Важный момент: запускаем игровые сервера по требованию, нужно как можно быстрее это делать, потому что по ту сторону сидят и ждут пользователи.
P.S. смотрю в сторону куба потому что держим кластера с вебом на нем уже около года

2 ответов

3 просмотра

@pyToshka

у меня на шифте с польным ci/cd на jenkins

Похожие вопросы

Обсуждают сегодня

а зачем этот вопрос для удаления из чата?
Mёdkinson Medvezhkin
63
Эх кто-то пришел и весь праздник испортил :( You need complex FBX scene importing setup to change things on import? good luck with that. You need navigation and pathfinding? g...
Serg Gini
5
Какого хера? /Sources/App/Modules/User/Models/UserLinkApple.swift:21:20: warning: stored property '_id' of 'Sendable'-conforming class 'UserLinkApple' is mutable @ID(...
Alexander Sherbakov
14
Всем привет! Подскажите. Я написал приложение на Delphi 10.2 Tokyo под Windows 10. И передо мной стал вопрос о том чтобы сделать это приложение кроссплатформенным (под Linux и...
Дмитрий Завгородний
24
Привет всем. Подскажите где можно посмотреть, какая версия электрон, поддерживает версии windows? Некий changelog. Мне бы желательно, поддержку 7,8,10... latest, как понимаю и...
Anonym Squad
21
Почему стало ломаться на D11? "739002.86400000' is not a valid timestamp" function IncDateTime(aStamp:TTimeStamp;aKind:TTriggerKind;aInterval:Integer):TDateTime; //aStamp = 2...
Катерина Свиридова
8
У тебя в конфиге нигде нет deny all; или вообще любого deny?
Alexander Sherbakov
10
Портфолио: Зовут меня Александр, мне 36 лет. Город Пушкино. Общий рабочий стаж: ~14 лет Уровень квалификации: Senior Full-stack developer Где прочесть мой код? https://github....
Magic
10
Есть Pipeline для GitLab Runner (executor = "shell") В нём есть: default: before_script: - set -eo pipefail - source "$(~/bin/trdl use werf 2 stable)" - source...
Aleksandr Karabanov
1
Ребят, чет я уже не догоняю... Крч в коде на асм там происходит нечто вроде a+число (a+1, a+2 и т.д.). Но почему строка lea ecx, [edx+1] работает как a+1?? В edx берется адрес...
Alan 🔝 Бэброу
4
Карта сайта