开启辅助访问 切换到宽版

精易论坛

 找回密码
 注册

QQ登录

只需一步,快速开始

用微信号发送消息登录论坛

新人指南 邀请好友注册 - 我关注人的新帖 教你赚取精币 - 每日签到


求职/招聘- 论坛接单- 开发者大厅

论坛版规 总版规 - 建议/投诉 - 应聘版主 - 精华帖总集 积分说明 - 禁言标准 - 有奖举报

查看: 1980|回复: 3
收起左侧

[Mysql] 一步完成MySQL向Redis迁移

[复制链接]

发表于 2013-2-1 16:20:20 | 显示全部楼层 |阅读模式   山东省聊城市
redis-cli命令行工具有一个批量插入模式,是专门为批量执行命令设计的。这第一步就是把Mysql查询的内容格式化成redis-cli可用的数据格式。here we go!

在把一个大表从 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输出的每行中不包含列名。
结帖率:100% (3/3)

签到天数: 2 天

发表于 2024-3-22 22:10:46 | 显示全部楼层   山东省潍坊市
开源精神必须支持~
回复 支持 反对

使用道具 举报

结帖率:100% (3/3)

签到天数: 2 天

发表于 2024-3-22 22:09:49 | 显示全部楼层   山东省潍坊市
开源精神必须支持~
回复 支持 反对

使用道具 举报

结帖率:37% (7/19)
发表于 2013-2-10 16:51:06 | 显示全部楼层   北京市北京市
我发觉好位置全是我的
回复 支持 反对

使用道具 举报

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

本版积分规则 致发广告者

发布主题 收藏帖子 返回列表

sitemap| 易语言源码| 易语言教程| 易语言论坛| 易语言模块| 手机版| 广告投放| 精易论坛
拒绝任何人以任何形式在本论坛发表与中华人民共和国法律相抵触的言论,本站内容均为会员发表,并不代表精易立场!
论坛帖子内容仅用于技术交流学习和研究的目的,严禁用于非法目的,否则造成一切后果自负!如帖子内容侵害到你的权益,请联系我们!
防范网络诈骗,远离网络犯罪 违法和不良信息举报电话0663-3422125,QQ: 793400750,邮箱:wp@125.la
Powered by Discuz! X3.4 揭阳市揭东区精易科技有限公司 ( 粤ICP备12094385号-1) 粤公网安备 44522102000125 增值电信业务经营许可证 粤B2-20192173

快速回复 返回顶部 返回列表