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

利用vps做网站青岛排名推广

利用vps做网站,青岛排名推广,网站建设的安全性,小语种企业网站建设1. 需求概述 业务开发中经常需要根据一些数据变更实现相对应的操作。例如,一些用户注销自己的账户,系统可以给用户自动发短信确认,这时有两种解决方案,一种是耦合到业务系统中,当用户执行注销操作的时候,执…

1. 需求概述

业务开发中经常需要根据一些数据变更实现相对应的操作。例如,一些用户注销自己的账户,系统可以给用户自动发短信确认,这时有两种解决方案,一种是耦合到业务系统中,当用户执行注销操作的时候,执行发短信的操作,既是是通过MQ也是要耦合业务代码的,第二种方案基于数据库层面的操作,通过监听binlog实现自动发短信操作,这样就可以与业务系统解耦。
本示例主要基于mysql-binlog-connector实现对数据库的监听,并集成springboot的方案。

2. 技术选型

基于binlog实现数据同步的方案有两种:
一种是mysql-binlog-connector,另一种是ali的canal。
mysql-binlog-connector:是通过引入依赖jar包实现,需要自行实现解析,但是相对轻量。
canal:是数据同步中间件,需要单独部署维护,功能强大,支持数据库及MQ的同步,维护成本高。
根据实际业务场景,按需索取,业务量小,业务简单,轻量可以通过mysql-binlog-connector,业务量大,逻辑复杂,有专门的运维团队,可以考虑canal,比较经过阿里高并发验证,相对稳定。

3. 方案设计

1.支持对不同数据库,不同表的配置监听。
2.封装细节数据库,对外提供统一监听。
3.讲结果集封装位方便操作数据结构。
5.讲监听信息统一放入阻塞队列。
6.实现多线程消费。

4. 配置验证

1、正常开启状态

mysql> show variables like 'log_bin';
+---------------+-------+
| Variable_name | Value |
+---------------+-------+
| log_bin       | ON    |
+---------------+-------+
1 row in set (0.02 sec)
mysql> show binary logs;
+------------------+-----------+
| Log_name         | File_size |
+------------------+-----------+
| mysql-bin.000001 |       154 |
+------------------+-----------+
1 row in set (0.09 sec)

2、权限不足情况

mysql> show binary logs;
1227 - Access denied; you need (at least one of) the SUPER, REPLICATION CLIENT privilege(s) for this operation

3、未开启状态(默认情况下是不开启的)

mysql> show binary logs;
ERROR 1381 - You are not using binary logging

5. 代码示例

详见工程代码:https://github.com/xzxiaoshan/mysql-binlog-demo

5.1. 事件中断问题

当binlog服务上线之后,服务默认会在log文件的最新position处进行监听。格式如下:

Connected to 192.168.10.220:3306 at test-bin.000557/270069874 (sid:65535, cid:1089065)

其中 test-bin.000557 是磁盘上的 binlog 文件名称,270069874 是对应该 binlog 文件中的 position 位置。

但由于binlog服务下线,重新启动后,默认又开始在最新position处进行监听,会丢失一不分binlog的事件,所以每次事件均需要记录当前的position位置。
当重新启动服务时,使用记录的position位置初始化BinaryLogClient。

注:单实例可以使用记录到本地文件的方式存储,如果需要考虑多实例分布式问题则需要考虑存储到redis等共享存储中。因为事件属于高频操作,所以建议使用redis或者MQ这种写入速度较快的存储方式。

5.2 文件轮换问题

当有人发出一个FLUSH LOGS语句或者当前二进制日志文件变大超过max_binlog_size时,binlog的文件名会重新一个新的文件,所以我们也要监听ROTATE事件并进行binlogFileName的记录。

记录binlogFileName和Position的代码详见文件 SaveBinlogFilenameAndPositionListener.java


(END)

http://www.dinnco.com/news/44879.html

相关文章:

  • 做网页设计卖钱的网站外贸推广是做什么的
  • 广西住房和城乡建设厅官方网站百度搜索引擎营销案例
  • 德宏企业网站建设江苏seo和网络推广
  • 什么网站容易做百度权重家庭优化大师免费下载
  • 工程建设监理学校网站刷粉网站推广快点
  • 做网站可以参考的网站关键词优化心得
  • python爬虫爬小说来做网站站长工具网站测速
  • 百度网站链接提交页面aso排名优化
  • 网站制作包括数据库吗怎么制作链接网页
  • 网站提交做外链有什么作用网络营销客服主要做什么
  • 建网站那种服务器好站长工具流量统计
  • 自己搭建小程序手机百度seo快速排名
  • 湛江免费网站制作重庆二级站seo整站优化排名
  • 帝国cms做搜索网站武汉百度推广入口
  • 怎样在阿里巴巴做网站域名解析在线查询
  • 网站建设与制作的流程网站排名怎么做
  • html5手机app网站模板网络营销软件商城
  • 成都有啥好玩的地方东莞网站seo优化托管
  • 网做 网站有哪些百度百科创建
  • 做网站 侵权上海seo顾问推推蛙
  • 做网站的网站企业策划推广公司
  • 织梦cms发布侵权网站清单千锋教育前端学费多少
  • 网站无备案seo创业
  • 如何做淘宝商城网站设计郑州众志seo
  • 百度网站怎样做推广本周国内新闻
  • wordpress中文免费seo网站快速排名软件
  • 天津做网站联系方式seo优化招聘
  • 网站互动功能公关公司提供的服务有哪些
  • 怎么把网站做10万ip网站seo推广优化教程
  • 网站需求怎么做淘宝指数查询官网