如何使用Maxwell实时同步mysql数据

作者:周小董 时间:2024-01-18 01:43:23 

目录
  • Maxwell简介

  • Maxwell的配置与使用

    • 1.下载Maxwell安装包

    • 2.配置mysql,打开mysql binlog日志

    • 3.启动Maxwell,主要介绍数据写入rabbitmq的实战:

    • rabbitmq的操作

    • 全量同步

Maxwell简介

maxwell是由java编写的守护进程,可以实时读取mysql binlog并将行更新以JSON格式写入kafka、rabbitMq、redis等中,  这样有了mysql增量数据流,使用场景就很多了,比如:实时同步数据到缓存,同步数据到ElasticSearch,数据迁移等等。

maxwell官网:http://maxwells-daemon.io
 maxwell源代码:https://github.com/zendesk/maxwell

Maxwell的配置与使用

maxwell 依赖java sdk,所以需要先配置JDK环境。

1.下载Maxwell安装包


root@xxx maxwell]# pwd
/usr/local/maxwell
[root@xxx maxwell]# wget https://github.com/zendesk/maxwell/releases/download/v1.19.5/maxwell-1.19.5.tar.gz
[root@xxx maxwell]# tar zxvf maxwell-1.19.5.tar.gz
[root@xxx maxwell]# cd maxwell-1.19.5

2.配置mysql,打开mysql binlog日志


[root@xxx mysql]# vi /usr/local/mysql/my.cnf

[mysqld]
log-bin=mysql-bin #添加这一行就
binlog-format=ROW #选择row模式
server_id=1 #随机指定一个不能和其他集群中机器重名的字符串,如果只有一台机器,那就可以随便指定了

重启mysql服务,登陆mysql,查看binlog日志模式


mysql> show variables like '%log_bin%'
+---------------------------------+-------------------------------+
| Variable_name                   | Value                         |
+---------------------------------+-------------------------------+
| log_bin                         | ON                            |
| log_bin_basename                | /data/mysqldb/mysql-bin       |
| log_bin_index                   | /data/mysqldb/mysql-bin.index |
| log_bin_trust_function_creators | OFF                           |
| log_bin_use_v1_row_events       | OFF                           |
| sql_log_bin                     | ON                            |
+---------------------------------+-------------------------------+
6 rows in set (0.11 sec)

Maxwell需要在schema_database选项指定的数据库中存储状态的权限(默认库名称为maxwell),所以需要提前给权限:


#创建一个有同步数据的用户yhrepl
mysql> create user 'yhrepl'@'*' identified by 'scgaopan';
Query OK, 0 rows affected (0.10 sec)

#此用户yhrepl要有对需要同步的数据库表有操作权限
mysql> grant all privileges on test.* to 'yhrepl'@'%' identified by 'scgaopan';
Query OK, 0 rows affected (0.13 sec)

#给yhrepl有同步数据的权限
mysql> grant select,replication client,replication slave on *.* to 'yhrepl'@'%' identified by 'scgaopan';
Query OK, 0 rows affected (0.10 sec)
# Maxwell需要在schema_database选项指定的数据库中存储状态的权限(默认库名称为maxwell)
mysql> grant all privileges on maxwell.* to 'yhrepl'@'%' identified by 'scgaopan';
Query OK, 0 rows affected (0.09 sec)

3.启动Maxwell,主要介绍数据写入rabbitmq的实战:


[root@xxx maxwell-1.19.5]# vi /usr/local/maxwell/maxwell-1.19.5/config.properties
#日志级别
log_level=DEBUG

producer=rabbitmq
daemon=true

#监控的数据库, mysql用户必须拥有读取binlog权限和新建库表的权限
host=47.105.110.xxx
user=yhrepl
password=scgaopan

output_nulls=true
jdbc_options=autoReconnet=true

#监控数据库中的哪些表
filter=exclude: *.*,include: test.AA

#replica_server_id 和 client_id 唯一标示,用于集群部署
replica_server_id=64
client_id=test-id

#metrics_type=http
#metrics_slf4j_interval=60
#http_port=8111
#http_diagnostic=true # default false

#rabbitmq
rabbitmq_host=47.105.110.xxx
rabbitmq_port=5672
rabbitmq_user=guest
rabbitmq_pass=guest
rabbitmq_virtual_host=/
rabbitmq_exchange=maxwell
rabbitmq_exchange_type=topic
rabbitmq_exchange_durable=false
rabbitmq_exchange_autodelete=false
rabbitmq_routing_key_template=%db%.%table%
rabbitmq_message_persistent=false
rabbitmq_declare_exchange=true

启动Maxwell:


[root@xxx maxwell-1.19.5]# ./bin/maxwell
#可以后台启动
[root@xxx maxwell-1.19.5]# nohub ./bin/maxwell &

启动成功,此时会自动生成maxwell库,该库记录了maxwell同步的状态,最后一次同步的id等等信息,在主库失败或同步异常后,只要maxwell库存在,下次同步会根据最后一次同步的id。如果没有生成maxwell库或报错,可能config.properties中配置的mysql用户权限不够

rabbitmq的操作

rabbitmq的操作,启动maxwell后就有一个maxwell的exchage生成

如何使用Maxwell实时同步mysql数据

但对应的queue和exchange和queue的绑定需要用户自己去实现

新建一个maxwell-test的queue:

如何使用Maxwell实时同步mysql数据

把queue与exchange进行绑定:

如何使用Maxwell实时同步mysql数据

注意,这里的Routing key 是区分大小写的

在数据库中修改一条记录,可以看到maxwell-test队列里面有一第记录了。

如何使用Maxwell实时同步mysql数据

全量同步

使用maxwell-bootstrap命令


./bin/maxwell-bootstrap --database xhd --table xhd-sso --host 127.0.0.1 --user xiehd --password xiehd2018 --client_id maxwell_dev

同步xhd.xhd-sso表的所有数据,并指定client_id示maxwell_dev的maxwell执行同步

上一个命令先开着,然后再启动client_id=maxwell_dev的maxwell


./bin/maxwell --client_id maxwell_dev

等待执行完成即可

来源:https://cloud.tencent.com/developer/article/1705132

标签:Maxwell,同步,mysql,数据
0
投稿

猜你喜欢

  • Bootstrap显示与隐藏简单实现代码

    2023-08-24 17:30:54
  • php使用ZipArchive函数实现文件的压缩与解压缩

    2023-07-12 20:58:19
  • oracle数据库tns配置方法详解

    2023-07-20 16:14:10
  • AERGO SHIP:用于开发智能合约的包管理器

    2024-02-04 00:36:13
  • Python Dataframe 指定多列去重、求差集的方法

    2022-01-12 00:40:19
  • ASP中的面向对象类

    2011-04-11 10:34:00
  • vue通信方式EventBus的实现代码详解

    2024-05-10 14:16:38
  • JavaScript实现图片放大预览效果

    2023-08-23 02:41:17
  • MySQL环境下导入数据时是否需要禁用索引

    2009-01-04 12:42:00
  • Python面向对象编程之继承与多态详解

    2022-01-24 17:22:01
  • 垂直栅格与渐进式行距(上)

    2009-04-01 18:30:00
  • Python列表推导式,元组推导式,字典推导式,集合推导式

    2022-08-01 23:26:36
  • PHP将amr音频文件转换为mp3格式的操作细节

    2023-06-15 22:20:35
  • Python约瑟夫生者死者小游戏实例讲解

    2023-02-12 02:14:25
  • oracle删除已存在的表的实例

    2024-01-16 19:24:58
  • 详解Python如何使用Netmiko进行文件传输

    2021-06-20 19:49:17
  • Sysbench多线程性能测试工具

    2024-01-20 14:08:57
  • Python中使用Queue和Condition进行线程同步的方法

    2021-08-23 01:46:51
  • Python文本处理之按行处理大文件的方法

    2023-01-24 11:11:34
  • Vue使用Echarts画柱状图详解

    2024-05-29 22:22:29
  • asp之家 网络编程 m.aspxhome.com