## RateLimiter:二级限流器
> 二级限流器用于抢购等高并发场景
该工具依赖redis,如果缓存不是配置的redis会无效
第一级 主要用于限制入口流量
第二级 主要用于限制同时操作主流程的人数
## 使用
~~~
$limit = new RateLimiter('test', 10, 2, 180, 100);
$b= $limit->get($id);
~~~
### 构造函数
~~~
/**
* RateLimiter __construct.
*
* @param string $name 限流器名称
* @param int $time 一级限流时间单位秒
* @param int $count 一级限流允许的次数
* @param int $time2 二级限流时间单位秒
* @param int $count2 二级限流允许的次数
*/
~~~
### get方法
~~~
/**
* 获取令牌
*
* @param string $id 标识当前用户的身份,默认为 sessionId
*
* @return bool
*/
~~~
### remove 方法
~~~
/**
* 删除令牌
* 当用户已经在规定时间内完成任务了,应该主动删除令牌,让更多人进来
*
* @param string $id 标识当前用户的身份,默认为 sessionId
*/
~~~
### check 方法
~~~
/**
* 检查是否拥有令牌
* 如果有二级限速,只会检查二级
*
* @param string $id 标识当前用户的身份,默认为 sessionId
*
* @return bool
*/
~~~
- 序言
- 开始
- 安装 RapPhp
- 应用目录
- 配置文件
- 入口类
- MVC架构
- 控制器基础
- 前置方法
- 拦截器
- 动态路由
- Request和Response
- Cookie和Session
- 模板引擎
- 请求缓存
- 流程图
- 数据库
- 基础使用
- 查询语法
- 查询操作
- where
- order
- limit
- lock
- fields
- join
- distinct
- having
- group
- force
- 查询方法
- 多数据源
- 数据库类型
- Record模型
- 使用Record
- 增删改
- 查找方法
- 数据类型
- 基本类型
- JSON 数据类型
- time
- date
- attach
- const
- 迭代操作
- record 更多方法
- 注入与转json
- 多级缓存
- 多数据源
- 模型生成
- 回调事件
- IOC控制反转
- Ioc基础概念
- 依赖注入
- Scope作用域
- 构造器
- 循环依赖
- AOP面向切面
- AOP使用
- 切面
- AopBuild
- 生成 aop 文件
- 事件勾子
- 执行循序
- Swoole
- Http服务器
- 用户进程
- Context上下文(重要)
- 协程
- 特色功能
- 限流器
- 连接池
- 数据库连接池
- Redis 连接池
- 通用连接池
- Rpc 远程调用
- Rpc服务提供方
- Rpc客户端
- 熔断器与服务降级
- Redis 分布式锁
- 其他功能
- 缓存
- redis
- 文件存储
- 存储简介
- 本地存储
- OSS存储
- 配置
- 日志
- 验证器
- FileUtil
- 数组Util
- Http工具
- 多语言
- 命令行
- 使用命令行
- 生成模型文件
- AOP动态文件生成
- swoole_http服务器
- 自定义命令行
- 异常与调试
- 异常抛出
- 异常处理
- 部署
- URL重写
- DOCKER 镜像(重要)
- 附录
- 回调事件
- 开发规范
- Swoole开发注意点
- 热点行更新排队机制
