## RapCo
rapphp本身对 swoole 各项能力是全面支持的,RapCo主要是针对 swoole 协程做了简单的封装,
1.rapphp保证了项目在 swoole环境使用协程,在 apache,nginx环境下或降级为同步执行,
2.同时提供了 group 的功能,可以做多协程等;
3.同时提供了 group 的功能,可以做多协程等待;
4.注意下在http服务下,其实每个请求都在一个协程内,我们创建的协程是该协程的子协程
### 协程内执行
```
RapCo::go(function(){
});
```
### 协程内执行,并带上当前协程的 context
和 `RapCo::go`的主要区别是`RapCo::goWithContext`会带上 context,如果你想获取request或保持数据库切换等需要获取获取 context 内数据的情况下使用
```
RapCo::goWithContext(function(){
});
```
### 分组功能
会创建一个组,在组内可以并发执行多个协程,并等待所有协程执行完毕
~~~
$result=[];
$group = RapCo::group();//创建分组
$group->goWithContext(function()use(&$result){
result['name']=1;
});
$group->goWithContext(function()use(&$result){
$result['test']=2;
});
$group->wait();//等待两个协程全部执行完成
return $result;//结果 ['name'=>1,'test'=>2]
~~~
### 数组迭代
会为数组内每个item 都单独创建一个协程,并等待每个协程执行完毕
~~~
$m=['a'=>'a','b'=>'b'];
RapCo::each($m,function($item){
})
~~~
- 序言
- 开始
- 安装 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开发注意点
- 热点行更新排队机制
