首页 / REDIS / 一步完成MySQL向Redis迁移
一步完成MySQL向Redis迁移
内容导读
互联网集市收集整理的这篇技术教程文章主要介绍了一步完成MySQL向Redis迁移,小编现在分享给大家,供广大互联网技能从业者学习和参考。文章包含2555字,纯文字阅读大概需要4分钟。
内容图文
![一步完成MySQL向Redis迁移](/upload/InfoBanner/zyjiaocheng/1151/048a754ad47c44d4b05665a9dcb06f2c.jpg)
在把一个大表从 MySQL 迁移到 Redis 时,你可能会发现,每次提取、转换、导入一条数据是让人难以忍受的慢!这里有一个技巧,你可以通过使用管道把 MySQL 的输出直接输入到 redis-cli输入端,这可以使两个数据库都能以他们的最顶级速度来运行。
使用了这个技术,我把 800 万条 MySQL 数据导入到 Redis 的时间从 90 分钟缩短到了两分钟。
Mysql到Redis的数据协议
redis-cli命令行工具有一个批量插入模式,是专门为批量执行命令设计的。这第一步就是把Mysql查询的内容格式化成redis-cli可用的数据格式。here we go!
我的统计表:
- CREATE TABLE events_all_time (
- id int (11) unsigned NOT NULL AUTO_INCREMENT,
- action varchar (255) NOT NULL ,
- count int (11) NOT NULL DEFAULT 0,
- PRIMARY KEY (id),
- UNIQUE KEY uniq_action ( action )
- );
准备在每行数据中执行的redis命令如下:
- HSET events_all_time [ action ] [ count ]
按照以上redis命令规则,创建一个events_to_redis.sql文件,内容是用来生成redis数据协议格式的SQL:
- -- events_to_redis.sql
- SELECT CONCAT(
- "*4\r\n" ,
- ‘$‘ , LENGTH(redis_cmd), ‘\r\n‘ ,
- redis_cmd, ‘\r\n‘ ,
- ‘$‘ , LENGTH(redis_key), ‘\r\n‘ ,
- redis_key, ‘\r\n‘ ,
- ‘$‘ , LENGTH(hkey), ‘\r\n‘ ,
- hkey, ‘\r\n‘ ,
- ‘$‘ , LENGTH(hval), ‘\r\n‘ ,
- hval, ‘\r‘
- )
- FROM (
- SELECT
- ‘HSET‘ as redis_cmd,
- ‘events_all_time‘ AS redis_key,
- action AS hkey,
- count AS hval
- FROM events_all_time
- ) AS t
ok, 用下面的命令执行:
- mysql stats_db --skip-column-names --raw < events_to_redis.sql | redis-cli --pipe
很重要的mysql参数说明:
--raw: 使mysql不转换字段值中的换行符。
--skip-column-names: 使mysql输出的每行中不包含列名。
redis数据批量导入导出
针对工作中可能用到 将某台服务器中的redis数据 导出然后导入到新的服务器中,一种方法是redis-dump工具,但是
他需要安装ruby环境,安装环境的过程中还可能出现意想不到的错误。所以不得不选用其他方法了。一下 是几点思路
供参考。
1、数据导出,不用自己写,也不用第三方脚本,
echo "HGETALL
xxx" | redis-cli -h localhost -p 6379
echo "HGETALL xxx" |
redis-cli -h localhost -p 6379 >>
wordlist.raw
2.这样得到的结果,你可以上到服务器上
查看 wordlist.raw文件
3.整理成输入需要的文件格式
$f =
‘xx.oo‘;
$lines = 0;
$inkey =
0;
$rawfile = ‘xx.oo‘;
$hashkey =
‘xx‘;
$buff = ‘‘;
$fp =
fopen($rawfile,‘w‘);
$fps =
fopen($f,‘r‘);
while($line=
fgets($fps)){
$inkey = !$inkey;
if
($inkey){
$f = ‘bayes_wordlist.raw‘;
$lines =
0;
$inkey = 0;
$rawfile =
‘bayes_wordlist.3.raw‘;
$hashkey =
‘bayes_wordlist‘;
$buff = ‘‘;
$fp =
fopen($rawfile,‘w‘);
$fps =
fopen($f,‘r‘);
while($line=
fgets($fps)){
$inkey = !$inkey;
if
($inkey){
$line =
sprintf(‘"%s"‘,trim($line));
$buff = "HSET $hashkey
".trim($line);
}
else
{
$buff
.= ‘
"‘.trim($line).‘"‘;
fwrite($fp,$buff."\r\n");
}
}
$buff
= "HSET $hashkey
".trim($line);
}
else
{
$buff
.= ‘
"‘.trim($line).‘"‘;
fwrite($fp,$buff."\r\n");
}
}
如果选择哪个库
要在首行写入 select x
4.利用redis-cli进行导入
echo `date`
> pipe.log && cat xx.oo | redis-cli >> pipe.log &&
echo `date` >>
pipe.log
5.加上了时间记录,和对导入结果进行纪录,真正执行导入的语句是
cat
wordlist.raw | redis-cli,当然严谨些的话redis-cli后面还要加-h localhost -p
6379等参数。
原文:http://www.cnblogs.com/hujihon/p/3745351.html
内容总结
以上是互联网集市为您收集整理的一步完成MySQL向Redis迁移全部内容,希望文章能够帮你解决一步完成MySQL向Redis迁移所遇到的程序开发问题。 如果觉得互联网集市技术教程内容还不错,欢迎将互联网集市网站推荐给程序员好友。
内容备注
版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 gblab@vip.qq.com 举报,一经查实,本站将立刻删除。
内容手机端
扫描二维码推送至手机访问。