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

Друзья, никто не имплементил ConcurrentHashMap с таймаутом на чтение (expiring

keys)? Юз кейс следующий: необходимо сделать rate-limiter: простой веб сервис который ограничивает доступ к ресурсу (5 запросов/5 секунд). Если лимит превышен, то возвращаем 503, если нет то 200. Каждые 5 секунд ограничение снимается (count=0). Естественно нужно чтобы было thread safe. Задумка атомарно инкрементить значение в мапе по ключу (для каждого clientId). Но теперь нужно сбрасывать каждые 5 секунд счётчик на ноль.

7 ответов

5 просмотров

Что касается expire'а, то можно поиграться с Гуавовским Cache'ом

а готовые либы не смотрели? Например https://github.com/vladimir-bukhtoyarov/bucket4j/blob/master/doc-pages/basic-usage.md#example-3---limiting-the-rate-of-access-to-rest-api

camel, guava. если это тестовое - ну погуглите "leaky bucket java"

Можно попробовать решить только на коллекциях JDK, но немножко поменяв подход к алгоритму, и используя sliding window На эту тему есть неплохая статья от фигмы(https://www.figma.com/blog/an-alternative-approach-to-rate-limiting/)

Может проще на проксе сделать, тот же nginx поставить и на нем разрулить и по запросам и по тайм-ауту

а требование именно на concurenthashmap?

Можно просто когда приходит первый запрос от этого пользователя (в хеш мапе лежит значение 5) то просто сабмитим таску в scheduled executor через секунду на восстановление этого счётчика

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

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

Есть какой-нибудь для Delphi/FPC T*Compression(Decompression)Stream на базе LZ4/Zstd/любой другой быстрый(и хорошо сжимающий) алгоритм А ещё лучше в pure pascal А ещё лучше од...
notme
48
Такой вопросец - есть функция function MySuperDuperConcat(const a: array of AnsiString): AnsiString; Как мне в её теле сделать вот так? Result:=Concat(a); А не грустный вариан...
notme
15
type TObj = object procedure Init; virtual; end; TObj1 = object(TObj) procedure Init; override; end; procedure TObj1.Init; begin inherited; end; procedur...
Alexander 👋
29
А чем вам питонисты не угодили?😂
.
79
Всем привет. Поделитесь, пожалуйста, опытом. Есть форма, на которой имеется dbgrid и кнопки: добавить, редактировать, удалить. Если нет записей в dbgrid, то кнопки редактирова...
Евгений
4
Всем привет, написал код ниже, но он выдает сегфолт, в чем причина? #include <stdio.h> #include <stdlib.h> #include <string.h> struct product { char *name; float price; };...
buzz базз
83
Вот смотрите у меня есть два стрима сейчас fs, cs: TStream; fs := TFileStream.Create('filename'); cs := TCompressionStream.Create(compression_level, fs); Я хочу сделать так: ...
notme
5
type TExtensions<GExtender>=class function GetExtension<GEntityExtenderType>:GEntityExtenderType; end; function TExtensions<GExtender>.GetExtension<GEntityExtenderType...
zamtmn
8
Всем здравствуйте! Я хотел узнать сколько стоит средняя месячная зарплата у Electron js разработчиков? Мне очень это важно и нужно, плиз помогите узнать эту инфу! Для Джунио...
U.K.
10
Можно ли загрузить скрипт py в бота чтобы он работал по нему? как это сделать?
huskadam #RCC Фанат? @hitlerpvp
13
Карта сайта