当前位置: 首页 > news >正文

MaxWell原理概述

文章目录

      • 1.MaxWell概述
      • 2.Maxwell输出数据格式
      • 3.Maxwell原理
        • 3.1 MySQL二进制日志
        • 3.2 MySQL主从复制

1.MaxWell概述

  Maxwell 是由美国Zendesk公司开源,用Java编写的MySQL变更数据抓取软件。它会实时监控Mysql数据库的数据变更操作(包括insert、update、delete),并将变更数据以 JSON 格式发送给 Kafka、Kinesi等流数据处理平台。官网地址:http://maxwells-daemon.io/

2.Maxwell输出数据格式

image-20230227193429227

注:Maxwell输出的json字段说明:

字段解释
database变更数据所属的数据库
table表更数据所属的表
type数据变更类型
ts数据变更发生的时间
xid事务id
commit事务提交标志,可用于重新组装事务
data对于insert类型,表示插入的数据;对于update类型,标识修改之后的数据;对于delete类型,表示删除的数据
old对于update类型,表示修改之前的数据,只包含变更字段

3.Maxwell原理

  Maxwell的工作原理是实时读取MySQL数据库的二进制日志(Binlog),从中获取变更数据,再将变更数据以JSON格式发送至Kafka等流处理平台。(可以进行主从复制和读写分离

3.1 MySQL二进制日志

  二进制日志(Binlog)是MySQL服务端非常重要的一种日志,它会保存MySQL数据库的所有数据变更记录。Binlog的主要作用包括主从复制和数据恢复。Maxwell的工作原理和主从复制密切相关。

3.2 MySQL主从复制

MySQL的主从复制,就是用来建立一个和主数据库完全一样的数据库环境,这个数据库称为从数据库。

1)主从复制的应用场景:
(1)做数据库的热备:主数据库服务器故障后,可切换到从数据库继续工作。
(2)读写分离:主数据库只负责业务数据的写入操作,而多个从数据库只负责业务数据的查询工作,在读多写少场景下,可以提高数据库工作效率。

2)主从复制的工作原理:
(1)Master主库将数据变更记录,写到二进制日志(binary log)中
(2)Slave从库向mysql master发送dump协议,将master主库的binary log events拷贝到它的中继日志(relay log)
(3)Slave从库读取并回放中继日志中的事件,将改变的数据同步到自己的数据库。

image-20230227193739303

很简单,就是将自己伪装成slave,并遵循MySQL主从复制的协议,从master同步数据。

http://www.lryc.cn/news/23282.html

相关文章:

  • 电子技术——AB类输出阶
  • Archlinux个人安装流程
  • 【Autoware】2小时安装Autoware1.13(保姆级教程)
  • JVM 堆内存模型
  • linux-中断下半部
  • SpringMVC源码:HandlerMapping加载1
  • 【ArcGIS】12 投影
  • 【微信小程序-原生开发+TDesign】通用功能页封装——地点搜索(含腾讯地图开发key 的申请方法)
  • h5: 打开手机上的某个app
  • Hot Chocolate 构建 GraphQL .Net Core 服务
  • linux shell 入门学习笔记16 流程控制开发
  • 机器学习:基于朴素贝叶斯对花瓣花萼的宽度和长度分类预测
  • 给VivoBook扩容重装系统
  • vue 依赖注入使用教程
  • 【再临数据结构】Day1. 稀疏数组
  • 二十四、MongoDB 聚合运算( aggregate )
  • 【C++】6.模板初阶
  • Docker部署Airbyte
  • 2023王道考研数据结构笔记第一章绪论
  • 告别空指针让代码变优雅,Optional使用图文例子源码解读
  • 【C++】哈希——unordered系列容器|哈希冲突|闭散列|开散列
  • mysql-面试
  • 【夏虫语冰】Win10局域网下两台电脑无法ping通: 无法访问目标主机
  • 大数据框架之Hadoop:MapReduce(三)MapReduce框架原理——Join多种应用
  • SSRF漏洞原理、危害以及防御与修复
  • CV学习笔记-ResNet
  • 百亿数据,毫秒级返回查询优化
  • cpp之STL
  • 基于Spring Boot开发的资产管理系统
  • Markdown总结