设为首页 收藏本站
查看: 1102|回复: 0

[经验分享] 简单实现redis数据实时插入MySQL过程

[复制链接]
累计签到:1 天
连续签到:1 天
发表于 2016-11-4 09:06:07 | 显示全部楼层 |阅读模式
  为什么要把REDIS已经持久化的数据还要插入MySQL呢,原因就不说了.....相信大神各有见解.....首先来了解基础信息:
一、一般来说,消息队列有两种场景:一种是发布者订阅者模式;一种是生产者消费者模式。利用redis这两种场景的消息队列都能够实现。定义:
  • 生产者消费者模式:生产者生产消息放到队列里,多个消费者同时监听队列,谁先抢到消息谁就会从队列中取走消息;即对于每个消息只能被最多一个消费者拥有。(常用于处理高并发写操作)
  • 发布者订阅者模式:发布者生产消息放到队列里,多个监听队列的消费者都会收到同一份消息;即正常情况下每个消费者收到的消息应该都是一样的。(常用来作为日志收集中一份原始数据对多个应用场景)---来自马神总结 j_0003.jpg
    该方式借助redis的list结构实现的,aa调用redis的lpush/rpush往特定key里塞入消息,Consumer调用brpop(阻塞方法)去不断监听该key。(aa为后面代码使用的key)
  • ###list实现的原则是FIFO

二、实现阻塞队列的原理


  • redis中有一个blpop、brpop的命令,阻塞的从列表(list)中取数据,当列表为空,则阻塞知道取到数据或超时。
  • blpop命令后面参数中可以跟多个list的key,内部是按照顺序进行访问的,基于这个原理可以实现高优先级队列。

三、简单实战过程
    ##最好安装一个PYCHARM的编程小工具,实用 j_0082.jpg

    实战要求:一台redis服务器、一个DB实例即可、一个简单的python脚本、一个简单验证
LET 'S GO..... j_0003.jpg j_0003.jpg
1、redis服务器(精简操作)
    a、测试环境直接用yum安装即可使用:yum -y  install redis
    b、登录redis命令为:redis-cli
QQ截图20161104090541.png
c、具体更多操作请度娘去
2、MySQL安装(略),
    a、安装好后,添加库和表,后面的脚本会用到。
    b、事例库表为
QQ截图20161104090548.png
Create Table: CREATE TABLE `redis_data` (
  `id` int(11) NOT NULL AUTO_INCREMENT,
  `id_type` varchar(20) DEFAULT NULL,
  `name` varchar(20) DEFAULT NULL,
  PRIMARY KEY (`id`)
) ENGINE=InnoDB AUTO_INCREMENT=1 DEFAULT CHARSET=latin1
3、一个简单的PYTHON脚本:
#!/usr/bin/env python
#_*_ coding:utf-8 _*_import redisimport timeimport jsonimport MySQLdbimport MySQLdbpool=redis.ConnectionPool(host='192.168.60.21',port=6379,db=0)r=redis.StrictRedis(connection_pool=pool)#key='_'.join(["gamelog_queue",str(date),str(log),str(cmd),str(response),str(sname),str(uid)])while True:    aa=r.brpop("aa",0)    if aa == None:        continue    #print "list brpop:",aa    bb=aa[0]    cc=aa[1]    #print type(bb),cc    value=[bb,cc]    #print value    try:        dbcon = MySQLdb.connect(host='192.168.9.63', user='dlan', port=3306, passwd='root123', db='suo', charset='utf8')        db_cursor = dbcon.cursor()        db_insert="insert into redis_test.redis_data values(null,%s,%s)"        db_cursor.execute(db_insert,value)        db_cursor.execute('commit')    except MySQLdb.Error, e:        print "error%s", e    1、从redis写数据:lpush aa redis_mysql_python    2、可以从PyCharm查看,可以把#号去掉,就可以显示    3、到数据库查看


运维网声明 1、欢迎大家加入本站运维交流群:群②:261659950 群⑤:202807635 群⑦870801961 群⑧679858003
2、本站所有主题由该帖子作者发表,该帖子作者与运维网享有帖子相关版权
3、所有作品的著作权均归原作者享有,请您和我们一样尊重他人的著作权等合法权益。如果您对作品感到满意,请购买正版
4、禁止制作、复制、发布和传播具有反动、淫秽、色情、暴力、凶杀等内容的信息,一经发现立即删除。若您因此触犯法律,一切后果自负,我们对此不承担任何责任
5、所有资源均系网友上传或者通过网络收集,我们仅提供一个展示、介绍、观摩学习的平台,我们不对其内容的准确性、可靠性、正当性、安全性、合法性等负责,亦不承担任何法律责任
6、所有作品仅供您个人学习、研究或欣赏,不得用于商业或者其他用途,否则,一切后果均由您自己承担,我们对此不承担任何法律责任
7、如涉及侵犯版权等问题,请您及时通知我们,我们将立即采取措施予以解决
8、联系人Email:admin@iyunv.com 网址:www.yunweiku.com

所有资源均系网友上传或者通过网络收集,我们仅提供一个展示、介绍、观摩学习的平台,我们不对其承担任何法律责任,如涉及侵犯版权等问题,请您及时通知我们,我们将立即处理,联系人Email:kefu@iyunv.com,QQ:1061981298 本贴地址:https://www.yunweiku.com/thread-295574-1-1.html 上篇帖子: Redis支持5种数据类型 下篇帖子: 使用redis代替文件存储session信息
您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

扫码加入运维网微信交流群X

扫码加入运维网微信交流群

扫描二维码加入运维网微信交流群,最新一手资源尽在官方微信交流群!快快加入我们吧...

扫描微信二维码查看详情

客服E-mail:kefu@iyunv.com 客服QQ:1061981298


QQ群⑦:运维网交流群⑦ QQ群⑧:运维网交流群⑧ k8s群:运维网kubernetes交流群


提醒:禁止发布任何违反国家法律、法规的言论与图片等内容;本站内容均来自个人观点与网络等信息,非本站认同之观点.


本站大部分资源是网友从网上搜集分享而来,其版权均归原作者及其网站所有,我们尊重他人的合法权益,如有内容侵犯您的合法权益,请及时与我们联系进行核实删除!



合作伙伴: 青云cloud

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