mysql快速备份数据(如何使用Maxwell实时同步mysql数据)
mysql快速备份数据
如何使用Maxwell实时同步mysql数据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生成
但对应的queue和exchange和queue的绑定需要用户自己去实现
新建一个maxwell-test的queue:
把queue与exchange进行绑定:
注意,这里的routing key 是区分大小写的
在数据库中修改一条记录,可以看到maxwell-test队列里面有一第记录了。
全量同步
使用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 |
等待执行完成即可
以上就是如何使用maxwell实时同步mysql数据的详细内容,更多关于用maxwell同步mysql数据的资料请关注开心学习网其它相关文章!
原文链接:https://cloud.tencent.com/developer/article/1705132
- mysql里修改密码命令(MySQL修改账号密码方法大全小结)
- MySQL中NULL和空值的区别
- mysql主从复制如何解决延迟(MySQL 8.0.23中复制架构从节点自动故障转移的问题)
- mysql索引面试总结(Mysql数据库索引面试题程序员基础技能)
- mysql有哪些约束(MySQL完整性约束的定义与实例教程)
- mysql标签的用法(mysql 的indexof函数用法说明)
- mysql 分片键规则(MySql8 WITH RECURSIVE递归查询父子集的方法)
- mysql有数据但筛选值为空(解决从集合运算到mysql的not like找不出NULL的问题)
- win10安装mysql8.0如何启动(win10下mysql 8.0.23 安装配置方法图文教程)
- mysqlgroupby用法(MySQL Group by的优化详解)
- mysql自增主键创建过程(深入谈谈MySQL中的自增主键)
- 执行mysqldump命令后数据库无反应(关于xampp启动不了mysql数据库的解决方法)
- mysql架构图(深入了解Mysql逻辑架构)
- mysql将字符串转换成整数(MYSQL字符串强转的方法示例)
- mysqldump 命令详解(mysqldump你可能不知道的参数)
- mysql修改表结构的关键字(查看修改MySQL表结构命令)
- 硕博期刊 SCI SSCI CSSCI分不清 一文带你看懂主流期刊分类(硕博期刊SCISSCI)
- 辱华品牌新百伦官宣新代言人IU,个别粉丝希望get爱豆同款(辱华品牌新百伦官宣新代言人IU)
- 巅峰时期被爆床照,曾被选国民最讨厌女星,IU不为人知的黑历史(巅峰时期被爆床照)
- 每天1万吨牛奶倒进下水道,美国大萧条一幕重现(每天1万吨牛奶倒进下水道)
- 如何看待美国数十万加仑牛奶倒下水道 历史又重演了(如何看待美国数十万加仑牛奶倒下水道)
- 历史惊人的相似,美国80万加仑牛奶倒入下水道,意味着什么(历史惊人的相似)
热门推荐
- 用html5的canvas绘制剪裁图像(Html5 canvas画图白板踩坑)
- sqlserver2012海量数据查询(SQL Server 2012 多表连接查询功能实例代码)
- docker保存容器的配置文件(docker cp 拷贝文件 和 进入容器的操作)
- 织梦的控制层使用方法(织梦系统参数设置出现Token mismatch!提示的解决办法)
- dede标签使用(解决{dede:arclist keyword='动态获取关键词'})
- mysql高级概念(MySQL 自定义变量的概念及特点)
- sqlserver分表后如何查询(SQL Server中row_number分页查询的用法详解)
- html5怎么修改背景颜色(HTML5 body设置全屏背景图片的示例代码)
- 腾讯云服务器配置详解(腾讯云服务器安全组配置图文教程)
- mysql limit越大越慢(MySQL limit分页大偏移量慢的原因及优化方案)