# Redis
炸毛框架内置了 Redis 连接池,供开发者使用。使用前需要先安装 redis
扩展:
pecl install redis
1
如果是 Docker 环境,则默认已安装。
# 配置
配置文件在 config/global.php
的全局配置文件下,详情见 配置。
示例配置(假设 Redis Server 开到了本地):
/** Redis连接信息,host留空则启动时不创建Redis连接池 */
$config['redis_config'] = [
'host' => '127.0.0.1',
'port' => 6379,
'timeout' => 1,
'db_index' => 0,
'auth' => ''
];
1
2
3
4
5
6
7
8
2
3
4
5
6
7
8
# 使用
当写好配置文件后,不可以使用 reload 进行重载,因为连接池需要在主进程中声明配置,才可以应用到多个工作进程中。所以必须输入 stop
或 Ctrl+C 停止后再启动框架。
定义:ZM\Store\Redis\ZMRedis
因为使用的是连接池,所以每次使用完一个连接需要归还连接给连接池。框架封装了两种方式自动归还,你可以选择下面其中的任意一种。
以下的方式获取的 $redis
都是 redis
扩展的对象 \Redis
,关于 redis 扩展的方法文档,详情见:Redis 文档 (opens new window)。
# 对象模式
$obj = new ZMRedis();
$redis = $obj->get();
ctx()->reply($redis->ping("123"));
1
2
3
2
3
# 回调模式
// 前面的代码
ZMRedis::call(function($redis) {
$redis->set("key1", "hello world");
$result = $redis->get("key1");
ctx()->reply($result);
});
// 后面的代码
1
2
3
4
5
6
7
2
3
4
5
6
7
# 二者的区别
选一个喜欢的就好。硬要是说区别的话,对象模式是在 PHP 自动回收这个 ZMRedis
对象时会归还连接,也可以通过手动 unset($obj)
进行回收,否则就会执行到函数结尾自动回收。切记不可将 $obj
对象持久化存到静态或全局变量等。
回调模式看似是回调,但是是同步执行的,不会发生顺序错乱。也就是说到了 ZMRedis::call()
方法里面的时候,后面的代码不会提前执行,是顺序执行的。回调的作用仅仅是用作自动回收连接对象。