从高层次上看,如何实现 API 使用配额系统?
特别是,它必须满足以下要求:
- 即时的
- 快速,不会显着减慢 API
- 如果使用内存缓存,需要在突然关闭后恢复(有利于 API 客户端的配额精度的小损失是可以的)
- 速率限制(DOS 保护)
- 缩放良好
是否有任何普遍接受的架构模式/算法来实现此类系统?
从高层次上看,如何实现 API 使用配额系统?
特别是,它必须满足以下要求:
是否有任何普遍接受的架构模式/算法来实现此类系统?
您的 API 是否有可用的数据库?如果是这样,只需在其中为您要测量或限制的每个注册帐户存储一个计数器。
当有人登录时,使用AOP之类的技术来确保每个 API 调用都会通过您的限制算法运行,这应该很简单。24小时节流系统的伪代码:
read access_count from DB
access_count++
if access_count > limit then
respond with something like 429 - Too Many Requests
else
store access_count in DB
end
以上假设您有一个批处理作业,该作业每晚遍历数据库并将所有访问计数器清除为 0 以用于第二天的流量。
其可扩展性将取决于您的数据库选择。任何数据库都可以处理这个问题,尤其是较新的 NoSQL/NewSQL 之一。