通过acquire方法看懂RateLimiter限流机制
关键方法
1)resync,动态计算剩余令牌数量和下次发放时间;
2)reserveEarliestAvailable,预定令牌,允许超发,超发后重新计算剩余令牌数量清零,并且会延长nextFreeTicketMicros下一次获取令牌的时间;
如果超发,下一次发放令牌请求,会sleep到超发时刻;
acquire获取令牌的时候,计算下次获取令牌时间,如果没有足够令牌会sleep再返回;
public double acquire(int permits) {
// 预定令牌
// mutex控制并发,以达到限流目的
long microsToWait = reserve(permits);
// 不可中断的sleep,while循环sleep纳秒级,详情请看源码
// 发生条件在reserve里
stopwatch.sleepMicrosUninterruptibly(microsToWait);
// 返回sleep时间
return 1.0 * microsToWait / SECONDS.toMicros(1L);
}
预定方法,mutex做同步控制
final long reserve(int permits) {
// 判断>0
checkPermits(permits);
// 同步控制
synchronized (mutex()) {
return reserveAndGetWaitLength(permits, stopwatch.readMicros());
}
}
单例mutex&#