|
0 / 0 / 0
Регистрация: 28.12.2008
Сообщений: 7
|
||||||
Ограничение запросов29.01.2023, 18:44. Показов 2956. Ответов 5
Метки нет (Все метки)
Написать компонент, отвечающий за ограничение запросов пользователей к сервису.
Характеристики компонента — лимит запросов на пользователя, лимит запросов на сервис и продолжительность интервала (duration), за который учитываются запросы. Запрос к сервису, поступивший в момент времени time, отклоняется, если он удовлетворяет хотя бы одному из двух условий: Если в промежутке времени [time−duration, time] от данного пользователя было принято к выполнению не меньше пользовательского лимита запросов — должен возвращаться код ошибки «Too Many Requests». Если в промежутке времени [time−duration,time] суммарно от всех пользователей было принято к выполнению не меньше сервисного лимита запросов — должен возвращаться код ошибки «Service Unavailable». Условия проверяются последовательно друг за другом, пока не будет найдено первое условие, которому запрос удовлетворяет. Если запрос не удовлетворяет ни одному условию, то он выполняется. Формат ввода Программа получает на вход строку с тремя числами, разделенными пробелами: userLimit (1≤userLimit≤5⋅10**4) — лимит запросов на пользователя, serviceLimit (1≤serviceLimit≤5⋅10**4) — лимит запросов на сервис, duration (1≤duration≤10**9) — промежуток времени в миллисекундах, за который учитываются запросы для расчета лимитов. В следующих строках поступают описания запросов. Каждый запрос представлен двумя разделенными пробелом числами: time (1≤time≤10**9) — время поступления запроса, userId (1≤userId≤10**9) — идентификатор пользователя, выполнившего запрос. Входные данные завершаются строкой с числом −1. Гарантируется, что все времена в описании запросов не убывают, а количество запросов не превышает 5⋅10**4. Тестирующая система даст прочитать очередной запрос только после записи в стандартный вывод ответа на предыдущий запрос. Формат вывода Для каждого запроса необходимо вывести один из трех кодов ответа HTTP: 200 — если запрос будет выполнен. 429 — если запрос будет отклонен из-за превышения лимита запросов пользователем. 503 — если запрос будет отклонен из-за превышения сервисного лимита запросов. Не забывайте о том, что ваша программа должна сбрасывать буфер вывода после вывода строчки с тайм-аутом. Для сброса буфера вывода можно использовать fflush(stdout) в C++, System.out.flush() в Java, stdout.flush() в Python. Пример Ввод 2 5 5 1 100 1 100 2 100 2 200 2 300 2 400 2 500 3 500 5 200 6 100 7 200 -1 Вывод 200 200 429 200 200 200 503 503 503 429 200 Мой код, но где-то ошибка:
0
|
||||||
| 29.01.2023, 18:44 | |
|
Ответы с готовыми решениями:
5
Ограничение количества запросов Как установить ограничение на количество запросов в сутки от пользователя боту (Telegrambot) Ограничение запросов в mySql |
|
0 / 0 / 0
Регистрация: 28.12.2008
Сообщений: 7
|
|
| 29.01.2023, 19:11 [ТС] | |
|
ну типо в яндекс-контесте первый тест прошёл, второй не прошёл, я хз ) А тесты там скрыты кроме первого
0
|
|
|
0 / 0 / 0
Регистрация: 28.12.2008
Сообщений: 7
|
|
| 29.01.2023, 19:17 [ТС] | |
|
WA, неверный ответ
0
|
|
|
Status 418
|
||||||
| 30.01.2023, 11:37 | ||||||
Сообщение было отмечено element_of_death как решение
Решение
1
|
||||||
| 30.01.2023, 11:37 | |
|
Помогаю со студенческими работами здесь
6
Ограничение количества запросов Ограничение запросов за единицу времени Ограничение на число одновременных запросов Ограничение на количество запросов к vk api Ограничение на количество запросов к vk api Искать еще темы с ответами Или воспользуйтесь поиском по форуму: |
|
Новые блоги и статьи
|
|||
|
Программная установка даты и запрет ее изменения
Maks 02.04.2026
Алгоритм из решения ниже реализован на примере нетипового документа "СписаниеМатериалов", разработанного в конфигурации КА2.
Задача: при создании документов установить период списания автоматически. . .
|
Вывод данных через динамический список в справочнике
Maks 01.04.2026
Реализация из решения ниже выполнена на примере нетипового справочника "Спецтехника" разработанного в конфигурации КА2.
Задача: вывести данные из ТЧ нетипового документа. . .
|
Функция заполнения текстового поля в реквизите формы документа
Maks 01.04.2026
Алгоритм из решения ниже реализован на нетиповом документе "ВыдачаОборудованияНаСпецтехнику" разработанного в конфигурации КА2, в дополнении к предыдущему решению.
На форме документа создается. . .
|
К слову об оптимизации
kumehtar 01.04.2026
Вспоминаю начало 2000-х, университет, когда я писал на Delphi. Тогда среди программистов на форумах активно обсуждали аккуратную работу с памятью: нужно было следить за переменными, вовремя. . .
|
|
Идея фильтра интернета (сервер = слой+фильтр).
Hrethgir 31.03.2026
Суть идеи заключается в том, чтобы запустить свой сервер, о чём я если честно мечтал давно и давно приобрёл книгу как это сделать. Но не было причин его запускать. Очумелые учёные напечатали на. . .
|
Модель здравосоХранения 6. ESG-повестка и устойчивое развитие; углублённый анализ кадрового бренда
anaschu 31.03.2026
В прикрепленном документе раздумья о том, как можно поменять модель в будущем
|
10 пpимет, которые всегда сбываются
Maks 31.03.2026
1. Чтобы, наконец, пришла маршрутка, надо закурить. Если сигарета последняя, маршрутка придет еще до второй затяжки даже вопреки расписанию.
2. Нaдоели зима и снег? Не надо переезжать. Достаточно. . .
|
Перемещение выделенных строк ТЧ из одного документа в другой
Maks 31.03.2026
Реализация из решения ниже выполнена на примере нетипового документа "ВыдачаОборудованияНаСпецтехнику" с единственной табличной частью "ОборудованиеИКомплектующие" разработанного в конфигурации КА2. . . .
|