mirror of
https://github.com/encode/django-rest-framework.git
synced 2024-11-26 03:23:59 +03:00
docs: Add a note on concurrency and races (#6950)
Refs #5181 Co-authored-by: Adam Johnson <me@adamj.eu>
This commit is contained in:
parent
86673a337a
commit
b1004a4733
|
@ -106,6 +106,12 @@ If you need to use a cache other than `'default'`, you can do so by creating a c
|
||||||
|
|
||||||
You'll need to remember to also set your custom throttle class in the `'DEFAULT_THROTTLE_CLASSES'` settings key, or using the `throttle_classes` view attribute.
|
You'll need to remember to also set your custom throttle class in the `'DEFAULT_THROTTLE_CLASSES'` settings key, or using the `throttle_classes` view attribute.
|
||||||
|
|
||||||
|
## A note on concurrency
|
||||||
|
|
||||||
|
The built-in throttle implementations are open to [race conditions][race], so under high concurrency they may allow a few extra requests through.
|
||||||
|
|
||||||
|
If your project relies on guaranteeing the number of requests during concurrent requests, you will need to implement your own throttle class. See [issue #5181][gh5181] for more details.
|
||||||
|
|
||||||
---
|
---
|
||||||
|
|
||||||
# API Reference
|
# API Reference
|
||||||
|
@ -214,3 +220,5 @@ The following is an example of a rate throttle, that will randomly throttle 1 in
|
||||||
[identifying-clients]: http://oxpedia.org/wiki/index.php?title=AppSuite:Grizzly#Multiple_Proxies_in_front_of_the_cluster
|
[identifying-clients]: http://oxpedia.org/wiki/index.php?title=AppSuite:Grizzly#Multiple_Proxies_in_front_of_the_cluster
|
||||||
[cache-setting]: https://docs.djangoproject.com/en/stable/ref/settings/#caches
|
[cache-setting]: https://docs.djangoproject.com/en/stable/ref/settings/#caches
|
||||||
[cache-docs]: https://docs.djangoproject.com/en/stable/topics/cache/#setting-up-the-cache
|
[cache-docs]: https://docs.djangoproject.com/en/stable/topics/cache/#setting-up-the-cache
|
||||||
|
[gh5181]: https://github.com/encode/django-rest-framework/issues/5181
|
||||||
|
[race]: https://en.wikipedia.org/wiki/Race_condition#Data_race
|
||||||
|
|
Loading…
Reference in New Issue
Block a user