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

У меня есть в кластере два DaemonSet-а: база данных и

клиент для этой базы.
Необходимо сделать так, что бы клиент конектился только к тому pod-у с базой, которая запущена на той же ноде, что и клиент.
Судя по доке, это решается сервисом с опцией internalTrafficPolicy: Local.
Но у меня так работает только на одной ноде (на мастере), на остальных нодах клиент не может подключиться к базе, хоть и резолвит имя сервиса в IP-адрес.
Если эту опцию убрать из сервиса, то везде всё работает, но конект роутится раунд-робином по всем нодам кластера. Т.е. в целом и база и клиент рабочие, и у меня какая-то проблема только с тем как работает internalTrafficPolicy: Local.
Может кто-то делал что-то подобное и может подтвердить, что всё должно работать нормально? Или оно всё ещё не стабильное (фича в статусе beta) и может не всегда работать?

27 ответов

24 просмотра

Объедини в один под и через локал хост)

Kirill-Kuzminykh Автор вопроса
Dobry kot
Объедини в один под и через локал хост)

Нельзя, там разные политики обновления этих приложений. Например клиент будет обновляться чаще.

Вот это я понимаю - использование Kubernetes на 200%

Kirill-Kuzminykh Автор вопроса
Solyar
Вот это я понимаю - использование Kubernetes на 20...

Я только начал переносить инфраструктуру в кубер и сразу столкнулся с этой проблемой. Так-то там будет всё сложнее. 😊

Kirill Kuzminykh
Нельзя, там разные политики обновления этих прилож...

Ну это я тебе придумал под стать архитектуре)))

чот ты фигню делаешь какую-то) вообще не так делать нужно

Kirill Kuzminykh
Я только начал переносить инфраструктуру в кубер и...

Скинь лучше задачу которую решаешь а мы тут тебе решение придумаем

Kirill-Kuzminykh Автор вопроса
kkv
чот ты фигню делаешь какую-то) вообще не так делат...

А как надо? Это приложение "умный кеш". Сам кеш лежит на диске, в базе данных хранится индекс и доп. информация о кеше. Роутинг запросов в кеш идёт по хешу от параметра в запросе. Т.е. я не могу просто так отправить запрос на node1, если кеш для него лежит на node2. Само приложение я ещё могу сделать не DaemonSet-ом, но база-данных должна быть прибита гвоздями к ноде, на которой лежит volume с файлами кеша. И обращаться к этой базе должен только тот pod с приложением который запущен на этой же ноде, что бы потом он мог достать из кеша файл, на который укажет база-данных. Разные ноды с приложением ничего не знают друг от друге, базы данных не объединены в какой-то кластер.

Kirill Kuzminykh
А как надо? Это приложение "умный кеш". Сам кеш л...

> Разные ноды ничего не знают друг от друге, базы данных не объединены в какой-то кластер. Вот это концептуальненько

Kirill Kuzminykh
А как надо? Это приложение "умный кеш". Сам кеш л...

а конкретнее? это 2 разных окружения одного приложения? ну разгнеси по разным неймспейсам и все

kkv
а конкретнее? это 2 разных окружения одного прилож...

Тут задачка в том чтобы соседи друг к другу ходили

Kirill-Kuzminykh Автор вопроса
Solyar
Тут задачка в том чтобы соседи друг к другу ходили

Вот именно, и у меня оно не работает так как написано в доке

Kirill-Kuzminykh Автор вопроса
Solyar
А что именно не работает?

Не работает опция internalTrafficPolicy: Local для сервиса.

Kirill Kuzminykh
Вот именно, и у меня оно не работает так как напис...

крч я бы просто навешал на ноды лейблы 2 этих БД разнес по разным неймспейсам и сиди себе натравливай клиентов по service

Kirill-Kuzminykh Автор вопроса
Онтошка
крч я бы просто навешал на ноды лейблы 2 этих БД р...

Руками? А масштабировать как? Новые неймспесы делать для каждой новой ноды и заново создавать все "объекты"? Хотелось бы просто добавить ноду в кластер, пометить её лейблом, который означает, что на ней надо развернуть приложение и дальше бы кубер сделал всё что нужно.

Solyar
Daemonset не умеет в PVС Template

умеет. чо бы нет. а в темлпейт нет

чат в реалном времене

Kirill Kuzminykh
Руками? А масштабировать как? Новые неймспесы дела...

звучит как огромный велосипед и костыльная архитектура

Kirill Kuzminykh
А как надо? Это приложение "умный кеш". Сам кеш л...

архитектор на тяжелых наркотиках сидит с детства ? что бывает, когда тянешь легаси в оркестратор. Предлагаю поступить кардинально. Вашим подам с "базойданных" прописать режим сети hostnetwork. А подам через dawnwardAPI закинуть адрес узла из status.hostIP - the IP of the node to which the Pod is assigned чтобы они ходили к БД своей на адрес узла.

Kirill Kuzminykh
А как надо? Это приложение "умный кеш". Сам кеш л...

можешь засунуть базу и приложение в один под, лол, кек

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

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

а через ESC-код ?
Alexey Kulakov
29
30500 за редактор? )
Владимир
47
Чёт не понял, я ж правильной функцией воспользовался чтобы вывести отладочную информацию? но что-то она не ловится
notme
18
У меня есть функция где происходит это: write_bit(buffer, 1); write_bit(buffer, 0); write_bit(buffer, 1); write_bit(buffer, 1); write_bit(buffer, 1); w...
~
13
Недавно Google Project Zero нашёл багу в SQLite с помощью LLM, о чём достаточно было шумно в определённых интернетах, которые сопровождались рассказами, что скоро всех "ибешни...
Alex Sherbakov
5
program test; {$mode delphi} procedure proc(v: int32); overload; begin end; procedure proc(v: int64); overload; begin end; var x: uint64; begin proc(x); end. Уж не знаю...
notme
6
Как передать управляющий символ в открытую через CreateProcess консоль? Собсна, есть процедура: procedure TRedirectThread.WriteData(Data: OEMString); var Written: Cardinal;...
Serjone
6
вы делали что-то подобное и как? может есть либы готовые? увидел картинку нокода, где всё линиями соединено и стало интересно попробовать то же в ddl на lua сделать. решил с ч...
Victor
8
Ребят в СИ можно реализовать ООП?
Николай
33
Подскажите пожалуйста, как в CustomDrawCell(Sender: TcxCustomGridTableView; ACanvas: TcxCanvas; AViewInfo: TcxGridTableDataCellViewInfo; var ADone: Boolean); получить наз...
A Z
7
Карта сайта