找回密码
 立即注册

QQ登录

只需一步,快速开始

查看: 1836|回复: 0
打印 上一主题 下一主题

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

[复制链接]

2647

主题

2647

帖子

7881

积分

论坛元老

Rank: 8Rank: 8

积分
7881
跳转到指定楼层
楼主
发表于 2018-2-14 05:50:19 | 只看该作者 回帖奖励 |正序浏览 |阅读模式

            本文实例讲述了php实现redis数据库指定库号迁移的方法,分享给大家供大家参考。具体如下:
redis普通的数据库迁移,只能整个redis save,或者利用主从,当然也可以安装一个redis-dump,不过比较麻烦,这里提供一种php的脚本,实现指定库号的迁移,其实也就是遍历根据存储类型,读出来,插入新库,效果是这样:
[U]复制代码[/U] 代码如下:[root@localhost ~]# php 1.php
1/407
101/407
201/407
301/407
401/407
PHP实例代码如下:
[U]复制代码[/U] 代码如下:keys('*');
$count = 0;
$total = count($keys);
foreach($keys as $key){
    if(++$count % 100 == 1){
        echo "$count/$total\n";
    }
    $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, 0, -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, 0, -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中使用redis
  • php Session存储到Redis的方法
  • PHP中redis的用法深入解析
  • redis安装、配置、使用和redis php扩展安装教程
  • 30个php操作redis常用方法代码例子
  • Php-Redis安装测试笔记
  • php操作redis缓存方法分享
  • PHP实现操作redis的封装类完整实例
  • PHP的Laravel框架结合MySQL与Redis数据库的使用部署
  • PHP实现的redis主从数据库状态检测功能示例
  • PHP数据库操作三:redis用法分析
            
  • 分享到:  QQ好友和群QQ好友和群 QQ空间QQ空间 腾讯微博腾讯微博 腾讯朋友腾讯朋友
    收藏收藏
    回复

    使用道具 举报

    您需要登录后才可以回帖 登录 | 立即注册

    本版积分规则

    用户反馈
    客户端