# redis插件
该插件提供 redis 连接池, ESD 默认已经加载,如需使用请添加配置。
## 插件配置
以下为必填设置
~~~
redis:
default: (连接标识)
host: '192.168.65.2' (主机名)
test:(多个连接通过此标记区分)
host: '192.168.65.2'
port: '6380'
~~~
### 可选配置
password 连接密码
select_db 连接数据库,默认为0
port 端口,默认6379
pool_max_number 连接池最大连接 默认 10
>[danger] 注意此连接数指的是一个woker的最大连接数,如果您配置了多个连接标识,那么每个连接标识都会保留10个连接;如果您启动了4个worker进程,配置了2个连接标识,则会最多保留40*2个连接实例。
## 插件使用
### 方法1
在需要使用的对象中添加 `use GetRedis;`
然后可使用 `$this->redis() `对象获取redis实例。
### 方法2
>[danger] 通过注解使用,通过给属性增加以下注解来使用,**注意该方式无法更改连接标识**
~~~
/**
* @Inject()
* @var \Redis
*/
protected $redis;
~~~
### 切换连接
使用 `$this->redis('test') ` 切换连接。
## 案例
~~~
public function test_redis(){
$key = '123';
$this->redis()->set($key, $key);
$val = $this->redis()->get($key);
assert($key,$val);
$this->log(Logger::DEBUG,'assert redis set/get',['a' => $key, 'b' =>$val]);
$this->redis('test')->set($key, $key);
$val = $this->redis('test')->get($key);
assert($key,$val);
$this->log(Logger::DEBUG,'assert redis set/get',['a' => $key, 'b' =>$val]);
$info = $this->redis('test')->info();
return $info;
}
~~~
- 前言
- 捐赠ESD项目
- 使用篇-通用
- 环境
- 安装
- 规范
- 压力测试
- 配置
- 如何设置YML配置
- server配置
- 端口配置
- 项目结构
- 事件派发
- 日志
- 注解
- DI容器
- 自定义进程
- 并发及协程池
- Console插件
- Scheduled插件
- Redis插件
- AOP插件
- Saber插件
- Mysql插件
- mysql事务
- Actuator插件
- Whoops插件
- Cache插件
- PHPUnit插件
- Security插件
- Session插件
- EasyRoute插件
- http路由
- ProcessRpc插件
- AutoReload插件
- AnnotationsScan插件
- Tracing-plugin插件
- MQTT插件
- Pack插件
- AMQP插件
- Validate插件
- Uid插件
- Topic插件
- Blade插件
- CsvReader插件
- hashed-wheel-timer-plugin插件
- 使用篇-HTTP
- 路由
- 静态文件
- 路由定义
- 修饰方法
- 路由分组
- 资源路由
- 端口作用域
- 异常处理
- 跨域请求
- 路由缓存
- 控制器
- 控制器初始化
- 前置操作
- 跳转和重定向
- 异常处理
- 请求
- 请求对象
- 请求信息
- request消息
- response消息
- stream消息
- url接口
- 验证器
- 内置验证器
- 内置过滤器
- 使用篇-WS
- 如何使用
- 路由
- 使用篇-TCP
- 插件篇-PluginSystem
- 微服务篇-ESDCloud
- CircuitBreaker插件
- SaberCloud插件
- 分布式链路追踪系统
- Consul插件