首页
导航
博客
电子书
算法
众创
代码
随贴
关于我们
您好,欢迎来到码863代码分享网! 请
[登录]
/
[注册]
搜 索
标题:
*
140
字
TAG标签:
(用空格隔开)
30
字
恢复历史版本:
请选择分类
html
python
javascript
php
sql
c
c++
c#
java
plain
所有人可见
仅自己可见
编辑器:UEditor
编辑器:TinyMCE
编辑器:Editor.md
HTML转MD
HTML转MD2
<h2><a href="https://www.jianshu.com/p/926956e7c058">https://www.jianshu.com/p/926956e7c058</a></h2><h2>准备</h2><ul class=" list-paddingleft-2"><li><p>MySQL 5.6</p></li><li><p>Canal 1.0.24</p></li><li><p>Kafka 1.0.0</p></li><li><p>Zookeeper 3.4.11</p></li><li><p>Spring Boot</p></li><li><p>JDK 8</p></li><li><p>IntelliJ Idea 14.1.7</p></li></ul><h2>背景</h2><p>在实际工作中,多个系统使用相同的用户等业务数据是常有的事情。随着需求的迭代式开发,系统的增加。系统的业务数据变更通知逐渐成为痛点,将数据变更逐一通知到其他系统在系统少的时候勉强可以接受,但是系统变多,需要通知的业务数据增多再使用此类的方式无疑是得不偿失的,且极不易维护,耦合性太强,牵一发而动全身。此时,引入中间件无疑是一种明智的选择。将系统从繁杂的通知中解脱出来,把通知这件事交给中间件来做。而这是基于业务操作最终会落实到数据库中,这也是本文方案可行的前提。</p><h2>架构图</h2><p><img data-original-src="//upload-images.jianshu.io/upload_images/2393477-8eff25124078858a.png" data-original-width="733" data-original-height="495" data-original-format="image/png" data-original-filesize="58174" class="" data-image-index="0" style="cursor: zoom-in;" src="//upload-images.jianshu.io/upload_images/2393477-8eff25124078858a.png?imageMogr2/auto-orient/strip|imageView2/2/w/733/format/webp"/></p><p>image</p><h2>实现</h2><h3>Canal Server搭建</h3><h4>MySQL配置</h4><ul class=" list-paddingleft-2"><li><p>进入C:\Program Files\MySQL\MySQL Server 5.6目录</p></li><li><p>编辑<strong>my.ini</strong>文件(按需修改),打开mysql bin log功能,如下</p></li></ul><pre class="line-numbers language-ini">[mysqld] # Remove leading # and set to the amount of RAM for the most important data # cache in MySQL. Start at 70% of total RAM for dedicated server, else 10%. # innodb_buffer_pool_size = 128M # Remove leading # to turn on a very important data integrity option: logging # changes to the binary log between backups. # log_bin # These are commonly set, remove the # and set as required. basedir = C:\Program Files\MySQL\MySQL Server 5.6 datadir = C:\Program Files\MySQL\MySQL Server 5.6\data # port = ..... # server_id = ..... log-bin=mysql-bin #添加这一行即可 #选择row模式 binlog-format=ROW #配置mysql replaction需要定义,不能和canal的slaveId重复 server_id=1 # Remove leading # to set options mainly useful for reporting servers. # The server defaults are faster for transactions and fast SELECTs. # Adjust sizes as needed, experiment to find the optimal values. # join_buffer_size = 128M # sort_buffer_size = 2M # read_rnd_buffer_size = 2M sql_mode=NO_ENGINE_SUBSTITUTION,STRICT_TRANS_TABLES</pre><ul class=" list-paddingleft-2"><li><p>canal的原理是模拟自己为mysql slave,所以这里一定需要拥有做为mysql slave的相关权限(canal server配置需要用到此用户)</p></li></ul><pre class="line-numbers language-sql">CREATE USER canal IDENTIFIED BY 'canal'; GRANT SELECT, REPLICATION SLAVE, REPLICATION CLIENT ON *.* TO 'canal'@'%';-- GRANT ALL PRIVILEGES ON *.* TO 'canal'@'%' ;FLUSH PRIVILEGES;</pre><ul class=" list-paddingleft-2"><li><p>重启mysql server</p></li><li><p>查看bin log状态</p></li></ul><pre class="line-numbers language-sql">show binlog events;</pre><p><img data-original-src="//upload-images.jianshu.io/upload_images/2393477-4c0eecab96e54f18.png" data-original-width="891" data-original-height="48" data-original-format="image/png" data-original-filesize="4915" class="" data-image-index="1" style="cursor: zoom-in;" src="//upload-images.jianshu.io/upload_images/2393477-4c0eecab96e54f18.png?imageMogr2/auto-orient/strip|imageView2/2/w/891/format/webp"/></p><p>image</p><ul class=" list-paddingleft-2"><li><p><strong>获取canalserver</strong>(<a href="https://link.jianshu.com?t=https://github.com/alibaba/canal/releases/download/canal-1.0.24/canal.deployer-1.0.24.tar.gz" target="_blank" rel="nofollow">https://github.com/alibaba/canal/releases/download/canal-1.0.24/canal.deployer-1.0.24.tar.gz</a>)</p></li><li><p><strong>修改canal server配置</strong></p></li><ul class=" list-paddingleft-2" style="list-style-type: square;"><li><p>进入D:\MySQL_Sync_Component\canal.deployer-1.0.24\conf\example目录</p></li><li><p>修改<strong>canal.properties</strong>文件</p></li><li><p>修改<strong>instance.properties</strong>文件</p></li></ul></ul><pre class="line-numbers language-properties">#canal.properties ##配置zookeeper地址 canal.zkServers=127.0.0.1:2181</pre><pre class="line-numbers language-properties">################################################# #instance.properties ## mysql serverId canal.instance.mysql.slaveId = 1234 # position info,需要改成自己的数据库信息 canal.instance.master.address = 127.0.0.1:3306 canal.instance.master.journal.name = canal.instance.master.position = canal.instance.master.timestamp = #canal.instance.standby.address = #canal.instance.standby.journal.name = #canal.instance.standby.position = #canal.instance.standby.timestamp = # username/password,需要改成自己的数据库信息 canal.instance.dbUsername = canal canal.instance.dbPassword = canal canal.instance.defaultDatabaseName = canal.instance.connectionCharset = UTF-8 # table regex canal.instance.filter.regex = .*\\..* # table black regex canal.instance.filter.black.regex = #################################################</pre><ul class=" list-paddingleft-2"><li><p>启动canal server</p></li><ul class=" list-paddingleft-2" style="list-style-type: square;"><li><p>进入D:\MySQL_Sync_Component\canal.deployer-1.0.24\bin目录</p></li><li><p>运行startup.bat</p></li></ul><li><p>查看canal server日志</p></li><ul class=" list-paddingleft-2" style="list-style-type: square;"><li><p>D:\MySQL_Sync_Component\canal.deployer-1.0.24\logs\canal\canal.log</p></li><li><p>D:\MySQL_Sync_Component\canal.deployer-1.0.24\logs\example\example.log</p></li></ul></ul><pre class="line-numbers language-log">canal.log 2017-11-24 17:55:32.550 [main] INFO com.alibaba.otter.canal.deployer.CanalLauncher - ## start the canal server. 2017-11-24 17:55:32.770 [main] INFO com.alibaba.otter.canal.deployer.CanalController - ## start the canal server[192.168.191.1:11111] 2017-11-24 17:55:34.503 [main] INFO com.alibaba.otter.canal.deployer.CanalLauncher - ## the canal server is running now ......</pre><pre class="line-numbers language-log">example.log 2017-11-24 17:55:33.202 [main] INFO c.a.o.c.i.spring.support.PropertyPlaceholderConfigurer - Loading properties file from class path resource [canal.properties] 2017-11-24 17:55:33.209 [main] INFO c.a.o.c.i.spring.support.PropertyPlaceholderConfigurer - Loading properties file from class path resource [example/instance.properties] 2017-11-24 17:55:33.343 [main] WARN org.springframework.beans.TypeConverterDelegate - PropertyEditor [com.sun.beans.editors.EnumEditor] found through deprecated global PropertyEditorManager fallback - consider using a more isolated form of registration, e.g. on the BeanWrapper/BeanFactory! 2017-11-24 17:55:33.471 [main] INFO c.a.otter.canal.instance.spring.CanalInstanceWithSpring - start CannalInstance for 1-example 2017-11-24 17:55:33.647 [main] INFO c.a.otter.canal.instance.core.AbstractCanalInstance - start successful.... 2017-11-24 17:55:33.896 [destination = example , address = /127.0.0.1:3306 , EventParser] WARN c.a.otter.canal.parse.inbound.mysql.MysqlEventParser - prepare to find start position just show master status</pre><h3>Zookeeper Server搭建</h3><ul class=" list-paddingleft-2"><li><p><strong>获取并配置zookeeper</strong>(<a href="https://link.jianshu.com?t=http://www.apache.org/dyn/closer.cgi/zookeeper/" target="_blank" rel="nofollow">http://www.apache.org/dyn/closer.cgi/zookeeper/</a>)</p></li><li><p>复制D:\MySQL_Sync_Component\zookeeper\zookeeper-3.4.11\conf\zoo_sample.cfg并重命名为<strong>zoo.cfg</strong>,zookeeper读取的是zoo.cfg这个配置文件</p></li><li><p><strong>启动zookeeper</strong>,进入D:\MySQL_Sync_Component\zookeeper\zookeeper-3.4.11\bin,执行</p></li></ul><pre class="line-numbers language-css">zkServer.cmd</pre><h3>Kafka Server搭建</h3><ul class=" list-paddingleft-2"><li><p><strong>获取Kafaka Server</strong>(<a href="https://link.jianshu.com?t=https://www.apache.org/dyn/closer.cgi?path=/kafka/1.0.0/kafka_2.11-1.0.0.tgz" target="_blank" rel="nofollow">https://www.apache.org/dyn/closer.cgi?path=/kafka/1.0.0/kafka_2.11-1.0.0.tgz</a>)</p></li><li><p><strong>配置Kafka Server</strong></p></li><ul class=" list-paddingleft-2" style="list-style-type: square;"><li><p>修改D:\MySQL_Sync_Component\kafka\kafka_2.12-1.0.0\config\server.properties</p></li></ul></ul><pre class="line-numbers language-properties">#server.properteis# #配置zookeeper连接地址 zookeeper.connect=localhost:2181</pre><ul class=" list-paddingleft-2"><li><p><strong>启动Kafka服务</strong>,进入D:\MySQL_Sync_Component\kafka\kafka_2.12-1.0.0\bin\windows,执行</p></li></ul><pre class="line-numbers language-css">kafka-server-start.bat D:\MySQL_Sync_Component\kafka\kafka_2.12-1.0.0\bin\conf\server.properties</pre><ul class=" list-paddingleft-2"><li><p><strong>创建topic</strong>,进入D:\MySQL_Sync_Component\kafka\kafka_2.12-1.0.0\bin\windows,执行</p></li></ul><pre class="line-numbers language-css">kafka-topics.bat --create --zookeeper localhost:2181 --replication-factor 1 --partitions 1 --topic testbinlog</pre><ul class=" list-paddingleft-2"><li><p>启动一个kafka生产者,用于测试kafka是否启动成功。执行</p></li></ul><pre class="line-numbers language-css">kafka-console-producer.bat --broker-list localhost:9092 --topic testbinlog</pre><ul class=" list-paddingleft-2"><li><p>启动一个kafka消费者,接收生产者发送的消息。测试通过,consumer可以收到producer发送的消息。执行</p></li></ul><pre class="line-numbers language-css">kafka-console-consumer.bat --bootstrap-server localhost:9092 --topic testbinlog --from-beginning</pre><h3>创建Spring Boot应用</h3><ul class=" list-paddingleft-2"><li><p>新建一个Spring Boot应用(<a href="https://link.jianshu.com?t=http://projects.spring.io/spring-boot/#quick-start" target="_blank" rel="nofollow">http://projects.spring.io/spring-boot/#quick-start</a>)</p></li><li><p><strong>pom</strong>文件增加kafka依赖</p></li></ul><pre class="line-numbers language-xml"><dependency> <groupId>org.springframework.kafka</groupId> <artifactId>spring-kafka</artifactId></dependency></pre><ul class=" list-paddingleft-2"><li><p>编写kafka生产者和消费者代码,代码在(<a href="https://link.jianshu.com?t=https://github.com/hxysea/mynote/tree/master/%E9%A1%B9%E7%9B%AE%E7%BB%8F%E9%AA%8C/Mysql%E6%95%B0%E6%8D%AE%E5%90%8C%E6%AD%A5%E8%A7%A3%E5%86%B3%E6%96%B9%E6%A1%88/DataSyncApplication" target="_blank" rel="nofollow">https://github.com/hxysea/mynote/tree/master/%E9%A1%B9%E7%9B%AE%E7%BB%8F%E9%AA%8C/Mysql%E6%95%B0%E6%8D%AE%E5%90%8C%E6%AD%A5%E8%A7%A3%E5%86%B3%E6%96%B9%E6%A1%88/DataSyncApplication</a>)</p></li><li><p>启动应用</p></li></ul><h3>总结</h3><p>如上,已经介绍了整个解决方案所需组件的配置及启动方法。文中的解决方案用于业务数据通知或者缓存刷新等场景。本文除了提供一种业务场景的解决方案以外,更多的是希望读者可以从中领会到各组件的设计思想及其优劣势。除了可以熟练配置及使用各组件,这些组件的编码思想及设计模式更是我辈学习的典范。对于各组件的使用,最好先去阅读官方文档,然后参考相关博客,再编码实践,最后阅读下源码,达到融会贯通的境界。</p><p><br/><br/><br/></p><p><br/></p>
CopyRight 2002~2023 精通2100网 联系邮箱:qqtxt@163.com
版权所有:精通2100网
湘ICP备2023018646号-1
MYSQl共执行 4 个查询,用时 0.0023579597473145 秒,PHP脚本用时 0.004968 秒,占用内存 0.585 MB,Gzip 已启用