# 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

# 使用

当写好配置文件后,不可以使用 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

# 回调模式

// 前面的代码
ZMRedis::call(function($redis) {
    $redis->set("key1", "hello world");
    $result = $redis->get("key1");
    ctx()->reply($result);
});
// 后面的代码
1
2
3
4
5
6
7

# 二者的区别

选一个喜欢的就好。硬要是说区别的话,对象模式是在 PHP 自动回收这个 ZMRedis 对象时会归还连接,也可以通过手动 unset($obj) 进行回收,否则就会执行到函数结尾自动回收。切记不可将 $obj 对象持久化存到静态或全局变量等。

回调模式看似是回调,但是是同步执行的,不会发生顺序错乱。也就是说到了 ZMRedis::call() 方法里面的时候,后面的代码不会提前执行,是顺序执行的。回调的作用仅仅是用作自动回收连接对象。