本地数据库的数据怎么传上线上redis
答案:2 悬赏:30 手机版
解决时间 2021-02-20 05:14
- 提问者网友:椧運幽默
- 2021-02-19 12:51
本地数据库的数据怎么传上线上redis
最佳答案
- 五星知识达人网友:掌灯师
- 2021-02-19 13:17
你要把redis当成一个缓存服务器来使用,不要当成数据库,用来存一些不经常变动的数据,不要什么数据都往里面塞,要不维护起来很痛苦的
全部回答
- 1楼网友:一秋
- 2021-02-19 14:42
对于变化频率非常快的数据来说,如果还选择传统的静态缓存方式(memocached、file system等)展示数据,可能在缓存的存取上会有很大的开销,并不能很好的满足需要,而redis这样基于内存的nosql数据库,就非常适合担任实时数据的容器。
但是往往又有数据可靠性的需求,采用mysql作为数据存储,不会因为内存问题而引起数据丢失,同时也可以利用关系数据库的特性实现很多功能。
所以就会很自然的想到是否可以采用mysql作为数据存储引擎,redis则作为cache。而这种需求目前还没有看到有特别成熟的解决方案或工具,因此采用gearman+php+mysql udf的组合异步实现mysql到redis的数据复制。
mysql到redis数据复制方案
无论mysql还是redis,自身都带有数据同步的机制,比较常用的mysql的master/slave模式,就是由slave端分析master的binlog来实现的,这样的数据复制其实还是一个异步过程,只不过当服务器都在同一内网时,异步的延迟几乎可以忽略。
那么理论上也可以用同样方式,分析mysql的binlog文件并将数据插入redis。但是这需要对binlog文件以及mysql有非常深入的理解,同时由于binlog存在statement/row/mixedlevel多种形式,分析binlog实现同步的工作量是非常大的。
因此这里选择了一种开发成本更加低廉的方式,借用已经比较成熟的mysql udf,将mysql数据首先放入gearman中,然后通过一个自己编写的php gearman worker,将数据同步到redis。比分析binlog的方式增加了不少流程,但是实现成本更低,更容易操作。
我要举报
如以上问答信息为低俗、色情、不良、暴力、侵权、涉及违法等信息,可以点下面链接进行举报!
大家都在看
推荐资讯