加入收藏 | 设为首页 | 会员中心 | 我要投稿 李大同 (https://www.lidatong.com.cn/)- 科技、建站、经验、云计算、5G、大数据,站长网!
当前位置: 首页 > 站长学院 > PHP教程 > 正文

php实现redis数据库指定库号迁移的方法

发布时间:2020-12-13 02:20:46 所属栏目:PHP教程 来源:网络整理
导读:《php实现redis数据库指定库号迁移的方法》要点: 本文介绍了php实现redis数据库指定库号迁移的方法,希望对您有用。如果有疑问,可以联系我们。 PHP教程 本篇章节讲解php实现redis数据库指定库号迁移的办法,供大家参考研究.具体如下: PHP教程 redi

《php实现redis数据库指定库号迁移的方法》要点:
本文介绍了php实现redis数据库指定库号迁移的方法,希望对您有用。如果有疑问,可以联系我们。

PHP教程本篇章节讲解php实现redis数据库指定库号迁移的办法,分享给大家供大家参考.具体如下:

PHP教程redis普通的数据库迁移,只能整个redis save,或者利用主从,当然也可以安装一个redis-dump,不过比较麻烦,这里提供一种php的脚本,实现指定库号的迁移,其实也就是遍历根据存储类型,读出来,插入新库,效果是这样:

代码如下:
[root@localhost ~]# php 1.php
1/407
101/407
201/407
301/407
401/407

PHP实例代码如下:
代码如下:
<?php
$from = '10.0.2.52:6379/7';
$to?? = '127.0.0.1:6379/7';
$from_redis = redis_init($from);
$to_redis?? = redis_init($to);
$keys? = $from_redis->keys('*');
$count = 0;
$total = count($keys);
foreach($keys as $key){
??? if(++$count % 100 == 1){
??????? echo "$count/$totaln";
??? }
??? $type = $from_redis->type($key);
??? switch($type){
??????? case Redis::REDIS_STRING:
??????????? $val = $from_redis->get($key);
??????????? $to_redis->set($key,$val);
??????????? break;
??????? case Redis::REDIS_LIST:
??????????? $list = $from_redis->lRange($key,-1);
??????????? foreach($list as $val){
??????????????? $to_redis->rPush($key,$val);
??????????? }
??????????? break;
??????? case Redis::REDIS_HASH:
??????????? $hash = $from_redis->hGetAll($key);
??????????? $to_redis->hMSet($key,$hash);
??????????? break;
??????? case Redis::REDIS_ZSET:
??????????? $zset = $from_redis->zRange($key,-1,true);
??????????? foreach($zset as $val=>$score){
??????????????? $to_redis->zAdd($key,$score,$val);
??????????? }
??????????? break;
??? }
}
function redis_init($conf){
??? $redis = new Redis();
??? preg_match('/^([^:]+)(:[0-9]+)?/(.+)?/',$conf,$ms);
??? $host = $ms[1];
??? $port = trim($ms[2],':');
??? $db = $ms[3];
??? $redis->connect($host,$port);
??? $redis->select($db);
??? return $redis;
}
?>

PHP教程希望本文所述对大家的php程序设计有所赞助.

欢迎参与《php实现redis数据库指定库号迁移的方法》讨论,分享您的想法,编程之家 52php.cn为您提供专业教程。

(编辑:李大同)

【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容!

    推荐文章
      热点阅读