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

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

следующий ключ?

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

16 ответов

15 просмотров

я не работал с хазелкастом но вижу есть метод - https://docs.hazelcast.org/docs/4.0.2/javadoc/com/hazelcast/map/IMap.html#getQueryCache-java.lang.String-com.hazelcast.query.Predicate-boolean- мб попробовать сюда передать предикат в котором будешь проверять что ключ не заблочен и что нужен 1 элемент?

As@@t-A Автор вопроса
Михаил
я не работал с хазелкастом но вижу есть метод - ht...

я так понял это вроде запроса sql)) понятно что даже близко не оно, но смысл понял - а что идея хорошая, изучу детальнее

As@@t A
спасибо!

напиши потом, к какому решению придешь

As@@t-A Автор вопроса
As@@t A
обязательно

не смог разобраться как применить для лока (

As@@t-A Автор вопроса
As@@t A
не смог разобраться как применить для лока (

такую жесть написал, хочется получше что-то.. public class Helpers { public Map.Entry<Object, Object> getNextNoLockKey(HazelcastInstance hazelcastInstance, IMap hazelcastMap){ Map.Entry<Object, Object> entry = hazelcastInstance.getMap("work-map").entrySet().iterator().next(); if(hazelcastMap.isLocked(entry.getKey())){ System.out.println("ключ заблокирован"); return getNextNoLockKey(hazelcastInstance, hazelcastMap); }else{ System.out.println("ключ НЕ заблокирован"); return entry; } } }

As@@t A
такую жесть написал, хочется получше что-то.. p...

а то, что Михаил написал, чем не подходит? зачем тут рекурсию делать? keySet.stream().filter(e-> !map.isLocked(e)).findFirst()

As@@t-A Автор вопроса
Владислав Хакин
а то, что Михаил написал, чем не подходит? зачем т...

пробую как Вы сказали public class Helpers { public static String getNextNoLockKey(IMap hazelcastMap){ return hazelcastMap.keySet().stream().filter(e-> !hazelcastMap.isLocked(e)).findFirst().toString(); } }

As@@t-A Автор вопроса
As@@t A
пробую как Вы сказали public class Helpers { ...

сработало, но только при условии что текущий поток заблокировал опрделенные ключи, а вот если другие потоки ключи заблокировали, тогда текщий поток даже не способен проверить на isLock "message": "Current thread is not owner of the lock! -> <not-locked>", Видимо мне нужен другой подход

As@@t-A Автор вопроса
Владислав Хакин
а то, что Михаил написал, чем не подходит? зачем т...

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

As@@t A
сработало, но только при условии что текущий поток...

это exception? это получается, что ключ заблокирован, но другим потоком. Можно считать - заблокированным вцелом, при filter. просто сделать try-catch в filter может это xy проблем и не нужно определять незаблокированный ключ вообще?

As@@t-A Автор вопроса
Владислав Хакин
это exception? это получается, что ключ заблокиров...

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

As@@t A
Хотя вопрос а как потом получить разблокированный ...

ну следующий в списке нужно проверить, пока не найдется разблокированный

As@@t-A Автор вопроса
Владислав Хакин
ну следующий в списке нужно проверить, пока не най...

Тогда уж циклом each бахнуть и проверять до первого свободного .. но вдруг миллион ключей - что тогда?

As@@t A
Тогда уж циклом each бахнуть и проверять до первог...

так стрим тоже самое сделает. А если миллион ключей, то xy проблем и вопрос для чего это вообще?)

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

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

Какой-то там пердун в 90-х решил, что есть какая-то разная типизация. Кого вообще это волнует?
КТ315
49
void terminal_scroll() { memmove(terminal_buffer, terminal_buffer + VGA_WIDTH, buffer_size - VGA_WIDTH); memset(terminal_buffer + buffer_size - VGA_WIDTH, 0, VGA_WIDTH); ...
Егор
47
Всем привет! Подскажите, пожалуйста, в чем ошибка? Настраиваю подключение к MySQL. Либы лежат рядом с exe. Все как по "учебнику"
Евгений
16
А можете как-то проверить меня по знаниям по ассемблеру?
A A
132
Здравствуйте! У меня появилась возможность купить книгу "Изучай Haskell во имя добра!". Но я где-то слышал, что эта книга устарела. Насколько это правда??
E
22
Здравствуйте! Я вот на stepic решаю задачи на хаскеле https://stepik.org/lesson/8443/step/8?unit=1578 мой код import Data.List (isInfixOf) removing :: String -> [String] ->...
E
10
Камрады, кто тесно работал с vtv, хотел уточнить. Ширина column задаётся жёстко на этапе создания дерева или можно в рантайме ее менять программно (не мышкой)?
Ed Doc
10
да ладно ... что там неочевидного ? глянуть в исх-ки датасета и/или кверика чтобы понять в каком месте и как выполняется обращения к св-вам blablaSQL - минутное дело, даже е...
Сергей
7
Здесь для arm кто-нибудь кодит ?
Nothing
52
Всем привет, у меня есть сервер принимающий входящие HTTP подключения, как проверить, что подключение было через прокси или нет, есть какие то поля в заголовках по которым мо...
DS
8
Карта сайта