黄p网站_在线看中文字幕_亚洲电影免费观看_成人激情视频_欧美成视频_中国av在线

場景

在業務量小的情況下,我們使用Redis單機連接池就可以滿足業務需求。因此,redis單機連接池就可以滿足我們的業務。因此我們會這樣寫:

示例

注冊連接池

use EasySwoole\Redis\Config\RedisConfig;
use EasySwoole\RedisPool\Redis;
Redis::getInstance()->register('redis',new RedisConfig());

使用

use EasySwoole\RedisPool\Redis;
use EasySwoole\Redis\Redis as RedisClient
Redis::invoke('redis', function (RedisClient $redis) {
    var_dump($redis->set('a', 1));
});

當業務量上來后,我們需要切換成集群模式的時候怎么辦。因此我們做的應該是:

注冊集群連接池

use EasySwoole\RedisPool\Redis;
use EasySwoole\Redis\Config\RedisClusterConfig;
Redis::getInstance()->register('redis',new RedisClusterConfig([
        ['172.16.253.156', 9001],
        ['172.16.253.156', 9002],
        ['172.16.253.156', 9003],
        ['172.16.253.156', 9004],
    ]
));

老業務代碼

use EasySwoole\RedisPool\Redis;
use EasySwoole\Redis\Redis as RedisClient
Redis::invoke('redis', function (RedisClient $redis) {
    var_dump($redis->set('a', 1));
});

對于之前的老業務代碼,就會出現、、、、此事,我的invoker回調參數是一個EasySwoole\Redis\RedisCluster實例,而非EasySwoole\Redis\Redis, 因此就會導致業務代碼報錯。

解決方案

Easyswoole Redis Pool組件,在2.1.1版本開始,基于easyswoole的magic pool 引入一個cask機制。可以指定實例化的class。

定義一個class

namespace App\Utility;

use EasySwoole\Redis\Redis;

class RedisClient extends Redis
{
    function fuck()
    {
        var_dump('waf');
    }
}

該class繼承自EasySwoole\Redis\Redis

注冊redis

use EasySwoole\Redis\Config\RedisConfig;
use EasySwoole\RedisPool\Redis;
use App\Utility\RedisClient
Redis::getInstance()->register('redis',$config,RedisClient::class);

使用redis

use EasySwoole\RedisPool\Redis;
use App\Utility\RedisClient
Redis::invoke('redis', function (RedisClient $redis) {
    var_dump($redis->set('a', 1));
});

遷移集群

修改注冊配置

use EasySwoole\RedisPool\Redis;
use EasySwoole\Redis\Config\RedisClusterConfig;
Redis::getInstance()->register('redis',new RedisClusterConfig([
        ['172.16.253.156', 9001],
        ['172.16.253.156', 9002],
        ['172.16.253.156', 9003],
        ['172.16.253.156', 9004],
    ]
),RedisClient::class);

繼承修改

修改App\Utility\RedisClient,讓它繼承EasySwoole\Redis\RedisCluster即可

而由于redis單機客戶端與集群客戶端的方法幾乎一致,因此可以不修改任何業務代碼,就是實現單機到集群的遷移

主站蜘蛛池模板: 国产一级视频在线观看 | 日韩成人中文字幕 | 久久99深爱久久99精品 | 日韩在线观看 | 精品久 | 欧美成人久久 | 天天色天天色 | 99精品国产高清在线观看 | 亚洲精品第一页 | 成人综合视频在线 | 亚洲协和影视 | 成人午夜啪啪好大 | 亚洲一区 | 三级成人在线 | 日韩欧美国产精品综合嫩v 国产高清av在线一区二区三区 | 国产综合久久久久久鬼色 | 欧美日韩精品一区二区三区 | 日本五月婷婷 | 日本在线观看网站 | 亚洲国产一区二区三区 | 亚洲国产精久久久久久久 | 国产精品毛片久久久久久 | 亚洲麻豆精品 | 大黄网站在线观看 | 国产视频91在线 | 国产激情久久久久久 | 男人天堂网址 | 91精品福利| 欧美在线综合 | 天天草天天干天天 | 瑟瑟视频在线看 | 久久在线视频 | 中文字幕在线观看 | 欧美极品一区 | 精品久久99 | 91麻豆精品国产91久久久更新时间 | 日本手机在线视频 | 国产精品视频 | a视频在线观看 | 亚洲八区 | 日韩在线不卡视频 |