> 백엔드 개발 > PHP 튜토리얼 > Redis 지정 라이브러리 번호를 마이그레이션하는 PHP 공유 예

Redis 지정 라이브러리 번호를 마이그레이션하는 PHP 공유 예

*文
풀어 주다: 2023-03-18 11:24:01
원래의
1266명이 탐색했습니다.

有些时候需求变动会涉及到迁移数据库,那么redis数据库指定库号迁移需要如何操作呢?本文通过介绍了php实现redis数据库指定库号迁移的方法,希望使大家对redis数据库指定库号迁移有一定的了解。

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

[root@localhost ~]# php 1.php 
1/407 
101/407 
201/407 
301/407 
401/407
로그인 후 복사

PHP实例代码如下:

<?php 
$from = &#39;10.0.2.52:6379/7&#39;; 
$to   = &#39;127.0.0.1:6379/7&#39;; 
$from_redis = redis_init($from); 
$to_redis   = redis_init($to); 
$keys  = $from_redis->keys(&#39;*&#39;); 
$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(&#39;/^([^:]+)(:[0-9]+)?\\/(.+)?/&#39;, $conf, $ms); 
    $host = $ms[1]; 
    $port = trim($ms[2], &#39;:&#39;); 
    $db = $ms[3]; 
    $redis->connect($host, $port); 
    $redis->select($db); 
    return $redis; 
} 
?>
로그인 후 복사

相关推荐:

关于Redis集群故障的分析

详解Redis的主从同步

redis计数器防止刷单方法介绍

위 내용은 Redis 지정 라이브러리 번호를 마이그레이션하는 PHP 공유 예의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

관련 라벨:
원천:php.cn
본 웹사이트의 성명
본 글의 내용은 네티즌들의 자발적인 기여로 작성되었으며, 저작권은 원저작자에게 있습니다. 본 사이트는 이에 상응하는 법적 책임을 지지 않습니다. 표절이나 침해가 의심되는 콘텐츠를 발견한 경우 admin@php.cn으로 문의하세요.
인기 튜토리얼
더>
최신 다운로드
더>
웹 효과
웹사이트 소스 코드
웹사이트 자료
프론트엔드 템플릿