在Java中,可以使用Guava库中的RateLimiter类来实现限流器。以下是一个简单的示例:
<dependency>
<groupId>com.google.guava</groupId>
<artifactId>guava</artifactId>
<version>30.1-jre</version>
</dependency>
import com.google.common.util.concurrent.RateLimiter;
public class RateLimiterExample {
public static void main(String[] args) {
// 创建一个限流器,每秒最多允许10个请求
RateLimiter rateLimiter = RateLimiter.create(10);
// 模拟100个请求
for (int i = 0; i < 100; i++) {
// 请求前检查限流器是否允许请求
if (rateLimiter.tryAcquire()) {
System.out.println("请求 " + (i + 1) + " 通过");
} else {
System.out.println("请求 " + (i + 1) + " 被拒绝");
}
try {
// 模拟请求耗时操作
Thread.sleep(100);
} catch (InterruptedException e) {
e.printStackTrace();
}
}
}
}
在这个示例中,我们创建了一个限流器,每秒最多允许10个请求。然后,我们模拟了100个请求,并使用tryAcquire()
方法检查限流器是否允许请求。如果允许,则执行请求;否则,拒绝请求。
注意:RateLimiter是线程安全的,可以在多线程环境中使用。