黄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單機客戶端與集群客戶端的方法幾乎一致,因此可以不修改任何業務代碼,就是實現單機到集群的遷移

主站蜘蛛池模板: 日韩一区二区不卡 | 欧美精品理论片大全 | 欧美日韩久久久久 | 中文字幕在线资源 | 国产美女视频一区 | 国产欧美精品区一区二区三区 | 日韩激情一区二区三区 | a级在线| 精品久久久久一区二区国产 | 日日天天 | 操操操av | 久久久久久一区 | 中文字幕在线观看的电影 | 美女黄视频网站 | 国产最新精品 | 草草成人| 国产精品久久久久永久免费观看 | 欧美在线一区二区三区 | 婷婷色狠狠 | 亚洲精品乱 | 久爱国产 | 久久99精品久久久久久琪琪 | 91网在线观看 | 色综合免费视频 | 免费一二区 | 午夜四虎| 精品久久久久久久久久久久久久 | 日韩一二 | 亚洲视频 欧美视频 | 日本免费在线视频 | 成人免费视频网站在线观看 | 日本精品在线 | 精品国偷自产在线 | 视频一区二区三区在线观看 | jlzzjlzz国产精品久久 | 成人免费网站视频 | 免费午夜电影 | 国产精品久久久久久久久免费高清 | 国产黄色免费视频 | 久久成人精品 | 日本不卡在线 |