让你的程序提供 Rpc能力很简单
配置
```
'rpc_service'=>[
'open'=>true,
]
```
这样就可以了,
下面开始编程
## Rpc 接口包
在自己项目外在开个项目(包), 这个包Rpc提供方的项目和 使用 Rpc 使用方的项目,都会依赖于这个包
包结构如下

### 接口
```
interface ITestService {
public function test($name,$age);
}
```
### 降级服务
```
class TestServiceDegrade implements ITestService {
public function test($name, $age) {
return '我是降级服务,当服务不可用时会调用我';
}
}
```
### Rpc注册器
```
class TestRpcRegister implements RpcRegister {
//返回 [接口1=>降级服务1,
// 接口2=>降级服务2
// ]
//如果懒提供方不提供降级服务
//返回 [接口1=>降级服务1,
// 接口2, //服务2没有降级服务
// 接口3=>降级服务3,
// ]
public function register() {
return [
ITestService::class=>TestServiceDegrade::class
];
}
}
```
## 下面在自己项目里写接口实现
写实现
>[info] 注意必须实现RPCable接口声明该类是对外提供的
```
class TestServiceImpl implements ITestService ,RPCable {
public function test($name, $age) {
return '我是提供方';
}
}
```
注入到 Ioc里
```
Ioc::bind(ITestService::class,TestServiceImpl::class);
```
- 序言
- 开始
- 安装 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开发注意点
- 热点行更新排队机制
