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

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

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

27 ответов

8 просмотров

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

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
А как надо? Это приложение "умный кеш". Сам кеш л...

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

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

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

@MrMiscipitlick А можешь макрос написать, который будет вычислять смещение относительно переданных меток? Просто .label1-.label2, и вернуть значение.
КТ315
35
я не магистр хаскеля, но разве не может лейзи тип конвертнуться в не-лейзи запросив вычисление содержимого прям при инициализации?
deadgnom32 λ madao
100
А еще в перле можно уже @arr1 + @arr2?
Sergei Zhmylove
53
Подобного рода ;Следующие три строки это директивы ассемблера, ;которые можно не задавать, т.к.работаем в Visual Studio. ;Символ ";" - это начало однострочного комментария ...
Егор Анелькин
3
Кто-нибудь знает почему SPM клонирует репо целиком? Некоторые репы просто огромные, как та же swift-syntax которая нужна для использования макросов. Сначала подумал, что это...
iMike
6
Привет всем. появился вопрос. Разрабатываю сайт, в данный момент он запущен. Хостинг beget. Добавляю на сайт яндекс метрику с помощью полей client-settings (взято отсюда http...
Andrew
2
Подскажите, где смотреть результат выполнения программы? Код: ;.686 ;Система команд процессора 686 ;.MODEL FLAT,stdcall ;Модель памяти плоская, станда...
Егор Анелькин
5
еще вопрос, допустим мы создадим char массив из 10 элементов и присвоим ему через сканф 10 символов. и выведем все символы. Хотел спросить последний элемент /0 будет включать...
Anthem
11
открыть папку в проводнике: 1 - ShellExecute 2 - ExecuteProcess 3 - OpenDocument что лучше выбрать?
Alexey Kulakov
12
;.686 ;Система команд процессора 686 ;.MODEL FLAT,stdcall ;Модель памяти плоская, стандартный ;вызов процедуры ;option casemap:no...
Егор Анелькин
1
Карта сайта