作者热门文章
- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
我想在 Scala 中使用 RateLimiter 来限制方法调用的频率。
我需要类似于 Guava 实现的东西: http://docs.guava-libraries.googlecode.com/git/javadoc/com/google/common/util/concurrent/RateLimiter.html
我知道我可以原生使用 Guava,但我想知道 Scala 中是否有更好的原生解决方案,有或没有 Akka
最佳答案
就我个人而言,我会使用 Guava。但是您可以使用 futures 轻松创建自己的。
class RateLimiter(delayMs: Int) {
private[this] var last: Long = System.currentTimeMillis
private[this] val done = scala.actors.Futures.alarm(0)
def request = {
val now = System.currentTimeMillis
val elapsed = synchronized {
val elapsed = now - last
last = if (elapsed < delayMs) last+delayMs else now
elapsed
}
if (elapsed < delayMs) scala.actors.Futures.alarm(delayMs-elapsed)
else done
}
}
然后,您可以为要限制访问的每个方法或一组方法创建一个限制器,并通过调用 request()
来启动该方法;如果需要,这将使用 Future
来阻止。如果你想要的不是至少这么多毫秒的间隔,你只需要改变一点数学和/或跟踪更多的状态。
关于scala - 如何在 Scala 中实现速率限制器?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/12617801/
我是一名优秀的程序员,十分优秀!