![](https://img-blog.csdnimg.cn/20201014180756754.png?x-oss-process=image/resize,m_fixed,h_64,w_64)
mysql
无名_小卒
这个作者很懒,什么都没留下…
展开
-
监听mysql表内容变化,mysql开启binlog
binlog 就是binary log,二进制日志文件,这个文件记录了mysql所有的增、删、改语句。通过binlog日志我们可以做数据恢复,做主从复制等等。可以看到,只要有了这个binlog,我们就拥有了mysql的完整备份了。 我们时常会碰到这样的需求,就是要监听某个表的变化,然后来做一些操作。 如果该表数据只增加、不删除修改的话,要监听比较简单,可以定时去查询最新的id即可。但要有删除、修改操作的话,免不了就得全表扫描,效率极低。倘若该表发生变化时,能触发个事件之类的可供监听,那最好不过。 现在转载 2020-05-22 14:34:09 · 350 阅读 · 0 评论 -
监听mysql表内容变化,使用canal
mysql本身是支持主从的(master slave),原理就是master产生的binlog日志记录了所有的增删改语句,将binlog发送到slave节点进行执行即可完成数据的同步。 canal是阿里开源的一个中间件,它就是通过解析binlog来完成数据变更的监听的。 https://github.com/alibaba/canal 可以看到,canal是这样工作的:canal有一个server工程,该server自己伪装为mysql的一个slave节点,然后向master请求所有的变更日志。同转载 2020-05-22 14:38:00 · 1519 阅读 · 0 评论