This project provides the three core rate limiter/semaphore implementations listed below, each of which uses a CacheService to issue tokens or permits for processes we wish to subject to rate or concurrency limits.
- Leaky Token Bucket - Used to allow burst rates but not beyond some configured limit. One the configured limit is past an exception occurs. See here for more information.
- Time Slice - Used to smooth out the rate at which operations can occur concurrently. If too many operations occur concurrently this will block. See here for more information.
- Semaphore - Only allow X concurrent events to occur within the sempahore. Operations block while waiting to enter the sempahore. See here for more information.
Please see examples in the Demo project.
Important Note: It's not ideal but for the demos to work you must first provide endpoint and port information for a redis cluster in src/main/resources/app.properties. Feel free to recommend a better way 😊
For our latest stable release use:
<dependency>
<groupId>com.echobox</groupId>
<artifactId>ebx-distributedratelimiters-sdk</artifactId>
<version>1.0.3</version>
</dependency>
- GitHub Issues: If you have ideas, bugs, or problems with our library, just open a new issue.
If you would like to get involved please follow the instructions here
We use semantic versioning.
All merges into DEV will automatically get released as a maven central snapshot, which can be easily included in any downstream dependencies that always desire the latest changes (see above for 'Most Up To Date' installation).
Each merge into the MASTER branch will automatically get released to Maven central and github releases, using the current library version. As such, following every merge to master, the version number of the dev branch should be incremented and will represent 'Work In Progress' towards the next release.
Please use a merge (not rebase) commit when merging dev into master to perform the release.
To create a full release to Maven central please follow these steps:
- Ensure the
CHANGELOG.md
is up to date with all the changes in the release, if not please raise a suitable PR intoDEV
. Typically the change log should be updated as we go. - Create a PR from
DEV
intoMASTER
. Ensure the version in thepom.xml
is the correct version to be released. Merging this PR intoMASTER
will automatically create the maven and github releases. Please note that a release is final, it can not be undone/deleted/overwritten. - Once the public release has been successful create a final PR into
DEV
that contains an incrementedpom.xml
version to ensure the correct snapshot gets updated on subsequent merges intoDEV
. This PR should also include:- An update to the
README.md
latest stable release version number. - A 'Work In Progress' entry for the next anticipated release in
CHANGELOG.md
.
- An update to the