怎样实现两台redis服务器的数据迁移

怎样实现两台redis服务器的数据迁移

需求背景

有一台原本已用了一年的华为云服务器到期了,因为各方面的考虑,准备迁移到腾讯云上面去,因为redis里也有一些持久化保存的数据,所以也需要做迁移。

实现方案

首先考虑的是看redis本身有没有提供迁移工具,实际上也有,但不够灵活,而且比较麻烦,例如我只想迁移其中的一部分key,就做不到,用代码实现就很灵活,可以根据业务逻辑灵活处理,思路很简单,就是分享连接两台redis服务器,从旧服务器获取到想要的key往新服务器上写就行了。

参考代码

Tools::realTimeOutputPrepare();
		//获取新服务器的redis连接
        $newRedis = new Redis(['XXX'], [
            'auth'      => '***',
            'keyPrefix' => '***:'
        ]);
		//获取旧服务器的redis连接
        $oldRedis = new Redis(['XXX'], [
            'auth'      => '***',
            'keyPrefix' => '***:'
        ]);
        //获取指定前缀的所有key
        $oldList = $oldRedis->keys('session_*');
        $index = 1;
        $oldList = $oldList['***'];
        foreach($oldList as $tempKey){
            if(!$newRedis->exists($tempKey)){//避免多次执行时相互覆盖了新数据,所以如果存在则跳过
                $newRedis->set($tempKey, $oldRedis->get($tempKey));
                Tools::realTimeOutput('同步第'.$index++.'个key:'.$tempKey);
            }
        }

你可能感兴趣的:(计算机网络,redis,Php,redis,服务器,数据库)