一、全部配置内容

      SqlMapConfig.xml的配置内容和顺序如下,顺序不能乱。现在来对这些属性的意思一一进行讲解。 

       

   

二、properties

     作用:引用java属性文件中的配置信息,比如,加载连接数据库的各种属性的配置文件。 

       

        

        

         db.properties

          

1     <!--
2 properties:引用java属性文件中的配置信息
3 比如加载连接数据库的帐号密码等信息的properties配置文件。
4 使用${}可以引用已经加载的java配置文件中的信息
5 使用时注意一个问题,mybatis按照下面的顺序加载属性
6 1、properties标签体内的属性
7 2、properties引用的属性会被读取,本例中也就是db.properties中的属性(key-value),
8 如果发现db.properties中有和第一步加载的属性的key相同的属性,那么将其覆盖
9 3、parameterType:接收的值最后被读取,parameterType="int" int相当于key,而实际上接收到的值
10 为value,如果parameterType的属性名与前面两步中的属性名相同,那么将其覆盖。
11 总结:加载的越快,就很有可能被覆盖,所以在properties中的key值都使用db.xxx,目的就是防止重名被覆盖
12 -->
13 <properties resource="db.properties">
14 <!-- 这里就是properties标签体内的属性
15 比如: <property name="" value=""/>
16 -->
17 </properties>
18 //使用db.properties中的配置信息
19 <dataSource type="POOLED">
20 <!-- 引用db.properties中的信息,通过${} -->
21 <property name="driver" value="${db.driver}"/>
22 <property name="url" value="${db.url}"/>
23 <property name="username" value="${db.username}"/>
24 <property name="password" value="${db.password}"/>
25 </dataSource>
 1     <!--
2 properties:引用java属性文件中的配置信息
3 比如加载连接数据库的帐号密码等信息的properties配置文件。
4 使用${}可以引用已经加载的java配置文件中的信息
5 使用时注意一个问题,mybatis按照下面的顺序加载属性
6 1、properties标签体内的属性
7 2、properties引用的属性会被读取,本例中也就是db.properties中的属性(key-value),
8 如果发现db.properties中有和第一步加载的属性的key相同的属性,那么将其覆盖
9 3、parameterType:接收的值最后被读取,parameterType="int" int相当于key,而实际上接收到的值
10 为value,如果parameterType的属性名与前面两步中的属性名相同,那么将其覆盖。
11 总结:加载的越快,就很有可能被覆盖,所以在properties中的key值都使用db.xxx,目的就是防止重名被覆盖
12 -->
13 <properties resource="db.properties">
14 <!-- 这里就是properties标签体内的属性
15 比如: <property name="" value=""/>
16 -->
17 </properties>
18 //使用db.properties中的配置信息
19 <dataSource type="POOLED">
20 <!-- 引用db.properties中的信息,通过${} -->
21 <property name="driver" value="${db.driver}"/>
22 <property name="url" value="${db.url}"/>
23 <property name="username" value="${db.username}"/>
24 <property name="password" value="${db.password}"/>
25 </dataSource>

三、settings

        <!-- setting 全局参数,比如懒加载、是否启动缓存机制-->

        这个在后面讲解懒加载时会讲解到。比如设置懒加载的全局参数

        

1     <!-- setting 全局参数,比如懒加载、是否启动缓存机制-->
2 <settings>
3 <!-- 打开延迟加载的开关,默认为true -->
4 <setting name="lazyLoadingEnabled" value="true"/>
5 <!-- 积极的懒加载,默认是true,设置为false时,懒加载生效 -->
6 <setting name="aggressiveLazyLoading" value="false"/>
7 </settings>
8
1     <!-- setting 全局参数,比如懒加载、是否启动缓存机制-->
2 <settings>
3 <!-- 打开延迟加载的开关,默认为true -->
4 <setting name="lazyLoadingEnabled" value="true"/>
5 <!-- 积极的懒加载,默认是true,设置为false时,懒加载生效 -->
6 <setting name="aggressiveLazyLoading" value="false"/>
7 </settings>
8

四、typeAliases

        别名,为了在映射文件中更方便的编写输入参数类型和输出结果类型,比如直接编写int,就是在这里设置。(使用推荐的)

        

1     <!-- typeAliases:别名,为了在映射文件中更方便的编写输入参数类型和输出结果类型,比如直接编写int,
2 而不需要在编写全限定名 java.lang.Integer了。 有很多默认的别名,比如int,String,八大基本类型都是
3 我们也可以自定义别名,
4 com.wuhao.mybatis.domain.User 使用别名 user 代替
5 -->
6 <typeAliases>
7 <!-- 单个定义别名 -->
8 <typeAlias type="com.wuhao.mybatis.domain.User" alias="user"/>
9 <!-- 批量定义别名(推荐)
10 指定批量定义别名的类包,在此包下的所有类都将可以使用别名,别名就为类名(首字母大小写都可以)
11 -->
12 <!-- <package name="com.wuhao.mybatis.domain"/> -->
13 </typeAliases>
 1     <!-- typeAliases:别名,为了在映射文件中更方便的编写输入参数类型和输出结果类型,比如直接编写int,
2 而不需要在编写全限定名 java.lang.Integer了。 有很多默认的别名,比如int,String,八大基本类型都是
3 我们也可以自定义别名,
4 com.wuhao.mybatis.domain.User 使用别名 user 代替
5 -->
6 <typeAliases>
7 <!-- 单个定义别名 -->
8 <typeAlias type="com.wuhao.mybatis.domain.User" alias="user"/>
9 <!-- 批量定义别名(推荐)
10 指定批量定义别名的类包,在此包下的所有类都将可以使用别名,别名就为类名(首字母大小写都可以)
11 -->
12 <!-- <package name="com.wuhao.mybatis.domain"/> -->
13 </typeAliases>

        mybatis中有很多默认的别名,也就是帮我们写好了的,比如八大基本类型,

            

五、typeHandlers

        类型转换器,将数据库的类型转换成java的类型,mybatis会帮我们做这个事情,我们不需要自己设置,在mybatis的jar包中,有一个

                      

        其中就会将类型转换器,转换哪些java类型都会列举出来,我们去看看,用来借鉴借鉴,等用到了可以到里面查查,

              

六、objectFactory

        对象工厂不用管,因为到时候肯定和spring整合,都会由sprig来管理,到与spring整合的时候就会讲解到对象工厂的了。

七、mappers

        加载映射文件,也就是我们配置的映射文件,在这里需要显示声明加载。有四种方式加载,使用推荐的那种,其他的了解

              

        使用第四种方式加载

              

1     <!--
2 mappers:加载映射文件
3 四种方式来加载
4 1、<mapper resource="config/sqlmap/user.xml"/>
5 使用相对路径,相对于项目底下。,比如config下的sqlmap下的user.xml
6 2、<mapper url=’’/>
7 使用绝对路径,比如d盘下的xx,不会用这种
8 3、<mapper class=’’/>
9 使用mapper接口的全县定名。就不用管路径问题了,让mybatis通过全限定名自己去找映射文件
10 前提:mapper接口的名称必须与映射文件的名称相同,并且放到一个目录下,
11 比如:UserMapper.java(接口) UserMapper.xml(映射文件)
12 4、<package name=’’/>(推荐)
13 注册指定包下的所有映射文件
14 <package name="com.wuhao.mapper"/>
15 配置了com.wuhao.mapper下的所有映射文件,
16 注意:此种方法要求mapper接口和mapper映射文件要名称相同,且放到同一个目录下
17 -->
18 <mappers>
19 <!-- <mapper resource="sqlmap/User.xml"/> -->
20 <!-- 批量加载映射文件 -->
21 <package name="com.wuhao.mapper"/>
22 <package name="com.wuhao.shuru"/>
23 <package name="com.wuhao.resultMap"/>
24 <package name="com.wuhao.onetoone"/>
25 </mappers>
 1     <!--
2 mappers:加载映射文件
3 四种方式来加载
4 1、<mapper resource="config/sqlmap/user.xml"/>
5 使用相对路径,相对于项目底下。,比如config下的sqlmap下的user.xml
6 2、<mapper url=’’/>
7 使用绝对路径,比如d盘下的xx,不会用这种
8 3、<mapper class=’’/>
9 使用mapper接口的全县定名。就不用管路径问题了,让mybatis通过全限定名自己去找映射文件
10 前提:mapper接口的名称必须与映射文件的名称相同,并且放到一个目录下,
11 比如:UserMapper.java(接口) UserMapper.xml(映射文件)
12 4、<package name=’’/>(推荐)
13 注册指定包下的所有映射文件
14 <package name="com.wuhao.mapper"/>
15 配置了com.wuhao.mapper下的所有映射文件,
16 注意:此种方法要求mapper接口和mapper映射文件要名称相同,且放到同一个目录下
17 -->
18 <mappers>
19 <!-- <mapper resource="sqlmap/User.xml"/> -->
20 <!-- 批量加载映射文件 -->
21 <package name="com.wuhao.mapper"/>
22 <package name="com.wuhao.shuru"/>
23 <package name="com.wuhao.resultMap"/>
24 <package name="com.wuhao.onetoone"/>
25 </mappers>

八,总的配置文件代码        

 1 <?xml version="1.0" encoding="UTF-8" ?>
2 <!DOCTYPE configuration
3 PUBLIC "-//mybatis.org//DTD Config 3.0//EN"
4 "http://mybatis.org/dtd/mybatis-3-config.dtd">
5 <configuration>
6 <!--
7 属性
8 <properties></properties>
9 全局参数设置
10 <settings></settings>
11 类型别名
12 <typeAliases></typeAliases>
13 类型处理器
14 <typeHandles></typeHandles>
15 对象工厂
16 <objectFactory></objectFactory>
17 插件
18 <plugins></plugins>
19 以上属性在后边会详细讲解到,现在我们就只需要关注一下下面的配置即可
20 如下所配置的就是使用这点东西。
21 environments(环境信息集合)
22 environment(单个环境信息)
23 transactionManager(事物)
24 dataSource(数据源)
25 environment
26 environments
27 mappers(映射器)
28 -->
29
30 <!--
31 properties:引用java属性文件中的配置信息
32 比如加载连接数据库的帐号密码等信息的properties配置文件。
33 使用${}可以引用已经加载的java配置文件中的信息
34 使用时注意一个问题,mybatis按照下面的顺序加载属性
35 1、properties标签体内的属性
36 2、properties引用的属性会被读取,本例中也就是db.properties中的属性(key-value),
37 如果发现db.properties中有和第一步加载的属性的key相同的属性,那么将其覆盖
38 3、parameterType:接收的值最后被读取,parameterType="int" int相当于key,而实际上接收到的值
39 为value,如果parameterType的属性名与前面两步中的属性名相同,那么将其覆盖。
40 总结:加载的越快,就很有可能被覆盖,所以在properties中的key值都使用db.xxx,目的就是防止重名被覆盖
41 -->
42 <properties resource="db.properties">
43 <!-- 这里就是properties标签体内的属性
44 比如: <property name="" value=""/>
45 -->
46 </properties>
47
48 <!-- setting 全局参数,比如懒加载、是否启动缓存机制-->
49 <!-- <settings>
50 打开延迟加载的开关,默认为true
51 <setting name="lazyLoadingEnabled" value="true"/>
52 积极的懒加载,默认是true,设置为false时,懒加载生效
53 <setting name="aggressiveLazyLoading" value="false"/>
54 </settings> -->
55
56 <!-- typeAliases:别名,为了在映射文件中更方便的编写输入参数类型和输出结果类型,比如直接编写int,
57 而不需要在编写全限定名 java.lang.Integer了。 有很多默认的别名,比如int,String,八大基本类型都是
58 我们也可以自定义别名,
59 com.wuhao.mybatis.domain.User 使用别名 user 代替
60 -->
61 <typeAliases>
62 <!-- 单个定义别名 -->
63 <typeAlias type="com.wuhao.mybatis.domain.User" alias="user"/>
64 <!-- 批量定义别名(推荐)
65 指定批量定义别名的类包,在此包下的所有类都将可以使用别名,别名就为类名(首字母大小写都可以)
66 -->
67 <!-- <package name="com.wuhao.mybatis.domain"/> -->
68 </typeAliases>
69
70 <!-- 类型转换器,将数据库的类型转换成java的类型,
71 mybatis会帮我们做这个事情,我们不需要自己设置,
72 <typeHandlers></typeHandlers>
73 -->
74
75 <!--
76 对象工厂不用管,因为到时候肯定和spring整合,都会由sprig来管理。
77 <objectFactory></objectFactory>
78 -->
79
80 <!--
81 mappers:加载映射文件
82 四种方式来加载
83 1、<mapper resource="config/sqlmap/user.xml"/>
84 使用相对路径,相对于项目底下。,比如config下的sqlmap下的user.xml
85 2、<mapper url=’’/>
86 使用绝对路径,比如d盘下的xx,不会用这种
87 3、<mapper class=’’/>
88 使用mapper接口的全县定名。就不用管路径问题了,让mybatis通过全限定名自己去找映射文件
89 前提:mapper接口的名称必须与映射文件的名称相同,并且放到一个目录下,
90 比如:UserMapper.java(接口) UserMapper.xml(映射文件)
91 4、<package name=’’/>(推荐)
92 注册指定包下的所有映射文件
93 <package name="com.wuhao.mapper"/>
94 配置了com.wuhao.mapper下的所有映射文件,
95 注意:此种方法要求mapper接口和mapper映射文件要名称相同,且放到同一个目录下
96 -->
97
98
99
100 <!-- 配置mybatis的环境信息 -->
101 <environments default="development">
102 <environment id="development">
103 <!-- 配置JDBC事务控制,由mybatis进行管理 -->
104 <transactionManager type="JDBC"></transactionManager>
105 <!-- 配置数据源,采用dbcp连接池 -->
106 <dataSource type="POOLED">
107 <!-- 引用db.properties中的信息,通过${} -->
108 <property name="driver" value="${db.driver}"/>
109 <property name="url" value="${db.url}"/>
110 <property name="username" value="${db.username}"/>
111 <property name="password" value="${db.password}"/>
112 </dataSource>
113 </environment>
114 </environments>
115 <!-- 加载mapper映射文件 -->
116 <mappers>
117 <!-- <mapper resource="sqlmap/User.xml"/> -->
118 <!-- 批量加载映射文件 -->
119 <package name="com.wuhao.mapper"/>
120 <package name="com.wuhao.shuru"/>
121 <package name="com.wuhao.resultMap"/>
122 <package name="com.wuhao.onetoone"/>
123 </mappers>
124 </configuration>
  1 <?xml version="1.0" encoding="UTF-8" ?>
2 <!DOCTYPE configuration
3 PUBLIC "-//mybatis.org//DTD Config 3.0//EN"
4 "http://mybatis.org/dtd/mybatis-3-config.dtd">
5 <configuration>
6 <!--
7 属性
8 <properties></properties>
9 全局参数设置
10 <settings></settings>
11 类型别名
12 <typeAliases></typeAliases>
13 类型处理器
14 <typeHandles></typeHandles>
15 对象工厂
16 <objectFactory></objectFactory>
17 插件
18 <plugins></plugins>
19 以上属性在后边会详细讲解到,现在我们就只需要关注一下下面的配置即可
20 如下所配置的就是使用这点东西。
21 environments(环境信息集合)
22 environment(单个环境信息)
23 transactionManager(事物)
24 dataSource(数据源)
25 environment
26 environments
27 mappers(映射器)
28 -->
29
30 <!--
31 properties:引用java属性文件中的配置信息
32 比如加载连接数据库的帐号密码等信息的properties配置文件。
33 使用${}可以引用已经加载的java配置文件中的信息
34 使用时注意一个问题,mybatis按照下面的顺序加载属性
35 1、properties标签体内的属性
36 2、properties引用的属性会被读取,本例中也就是db.properties中的属性(key-value),
37 如果发现db.properties中有和第一步加载的属性的key相同的属性,那么将其覆盖
38 3、parameterType:接收的值最后被读取,parameterType="int" int相当于key,而实际上接收到的值
39 为value,如果parameterType的属性名与前面两步中的属性名相同,那么将其覆盖。
40 总结:加载的越快,就很有可能被覆盖,所以在properties中的key值都使用db.xxx,目的就是防止重名被覆盖
41 -->
42 <properties resource="db.properties">
43 <!-- 这里就是properties标签体内的属性
44 比如: <property name="" value=""/>
45 -->
46 </properties>
47
48 <!-- setting 全局参数,比如懒加载、是否启动缓存机制-->
49 <!-- <settings>
50 打开延迟加载的开关,默认为true
51 <setting name="lazyLoadingEnabled" value="true"/>
52 积极的懒加载,默认是true,设置为false时,懒加载生效
53 <setting name="aggressiveLazyLoading" value="false"/>
54 </settings> -->
55
56 <!-- typeAliases:别名,为了在映射文件中更方便的编写输入参数类型和输出结果类型,比如直接编写int,
57 而不需要在编写全限定名 java.lang.Integer了。 有很多默认的别名,比如int,String,八大基本类型都是
58 我们也可以自定义别名,
59 com.wuhao.mybatis.domain.User 使用别名 user 代替
60 -->
61 <typeAliases>
62 <!-- 单个定义别名 -->
63 <typeAlias type="com.wuhao.mybatis.domain.User" alias="user"/>
64 <!-- 批量定义别名(推荐)
65 指定批量定义别名的类包,在此包下的所有类都将可以使用别名,别名就为类名(首字母大小写都可以)
66 -->
67 <!-- <package name="com.wuhao.mybatis.domain"/> -->
68 </typeAliases>
69
70 <!-- 类型转换器,将数据库的类型转换成java的类型,
71 mybatis会帮我们做这个事情,我们不需要自己设置,
72 <typeHandlers></typeHandlers>
73 -->
74
75 <!--
76 对象工厂不用管,因为到时候肯定和spring整合,都会由sprig来管理。
77 <objectFactory></objectFactory>
78 -->
79
80 <!--
81 mappers:加载映射文件
82 四种方式来加载
83 1、<mapper resource="config/sqlmap/user.xml"/>
84 使用相对路径,相对于项目底下。,比如config下的sqlmap下的user.xml
85 2、<mapper url=’’/>
86 使用绝对路径,比如d盘下的xx,不会用这种
87 3、<mapper class=’’/>
88 使用mapper接口的全县定名。就不用管路径问题了,让mybatis通过全限定名自己去找映射文件
89 前提:mapper接口的名称必须与映射文件的名称相同,并且放到一个目录下,
90 比如:UserMapper.java(接口) UserMapper.xml(映射文件)
91 4、<package name=’’/>(推荐)
92 注册指定包下的所有映射文件
93 <package name="com.wuhao.mapper"/>
94 配置了com.wuhao.mapper下的所有映射文件,
95 注意:此种方法要求mapper接口和mapper映射文件要名称相同,且放到同一个目录下
96 -->
97
98
99
100 <!-- 配置mybatis的环境信息 -->
101 <environments default="development">
102 <environment id="development">
103 <!-- 配置JDBC事务控制,由mybatis进行管理 -->
104 <transactionManager type="JDBC"></transactionManager>
105 <!-- 配置数据源,采用dbcp连接池 -->
106 <dataSource type="POOLED">
107 <!-- 引用db.properties中的信息,通过${} -->
108 <property name="driver" value="${db.driver}"/>
109 <property name="url" value="${db.url}"/>
110 <property name="username" value="${db.username}"/>
111 <property name="password" value="${db.password}"/>
112 </dataSource>
113 </environment>
114 </environments>
115 <!-- 加载mapper映射文件 -->
116 <mappers>
117 <!-- <mapper resource="sqlmap/User.xml"/> -->
118 <!-- 批量加载映射文件 -->
119 <package name="com.wuhao.mapper"/>
120 <package name="com.wuhao.shuru"/>
121 <package name="com.wuhao.resultMap"/>
122 <package name="com.wuhao.onetoone"/>
123 </mappers>
124 </configuration>

九、总结

      以上就把全局配置文件中的内容全部给讲解了一遍,其中

          

      没有具体讲解这个,因为都是死东西,在前一章节都是使用这个,所以就不在过多分析,其他的都有讲解到是什么作用,现在应该对前面一章的东西有更加深入的理解,但是需要彻底理解,还需要等待下一章讲解映射文件之后才能够更加清晰。加油。

Mybatis学习(二)————— 全局配置文件详解的更多相关文章

  1. Mybatis(二) 全局配置文件详解

    这节来说说全局配置文件的东西,非常简单.看一遍就懂了. --WH 一.全部配置内容 SqlMapConfig.xml的配置内容和顺序如下,顺序不能乱.现在来对这些属性的意思一一进行讲解. 二.prop ...

  2. mybatis学习二 全局配置文件常用配置

    全局配置文件的详细解析可以参考mybatis的中文参考文档 1.全局配置文件中内容1.1 <transactionManager/> type 属性可取值1.1.1 JDBC,事务管理使用 ...

  3. MyBatis 全局配置文件详解(七)

    MyBatis 配置文件作用 MyBatis配置文件包含影响 MyBatis 框架正常使用的功能设置和属性信息.它的作用好比手机里的设置图标,点击这个图标就可以帮助我们查看手机的属性信息和设置功能.其 ...

  4. 2017.2.9 深入浅出MyBatis技术原理与实践-第八章 MyBatis-Spring(二)-----配置文件详解

    深入浅出MyBatis技术原理与实践-第八章 MyBatis-Spring(二) ------配置文件详解 8.2 MyBatis-Spring应用 8.2.1 概述 本文主要讲述通过注解配置MyBa ...

  5. Linux学习之用户配置文件详解(十四)

    Linux学习之用户配置文件详解 目录 用户信息文件/etc/password 影子文件/etc/shadow 组信息文件/etc/group 组密码文件/etc/gshadow 用户信息文件/etc ...

  6. Mybatis全局配置文件详解(三)

    每个基于Mybatis应用都是以一个SqlSessionFactory实例为中心.SqlSessionFactory实例可以由SqlSessionFactoryBuild获得,而SqlSessionF ...

  7. MyBatis系列:二、配置文件详解

    本文会详细介绍MyBatis的常用配置 1.properties节点 <properties resource="mybatis-config.properties"> ...

  8. Mybatis Generator生成工具配置文件详解

    <?xml version="1.0" encoding="UTF-8"?> <!DOCTYPE generatorConfiguration ...

  9. Tomcat学习(二)------Tomcat原理详解及请求过程

    Tomcat: Tomcat是一个JSP/Servlet容器.其作为Servlet容器,有三种工作模式:独立的Servlet容器.进程内的Servlet容器和进程外的Servlet容器. Tomcat ...

随机推荐

  1. Codeforces Round #548 (Div. 2) F splay(新坑) + 思维

    https://codeforces.com/contest/1139/problem/F 题意 有m个人,n道菜,每道菜有\(p_i\),\(s_i\),\(b_i\),每个人有\(inc_j\), ...

  2. PC装MAC(VM虚拟机)想体验苹果系统的福利

    Windows下 VM12虚拟机安装OS X 10.11(详细教程) 工具/原料 Mac OS X 10.11 镜像文件 unlocker208文件 VMware Workstation12(版本不一 ...

  3. SecureCRT两步验证自动登录脚本

    简介 用于解决 Google Authenticator 的两步验证登录.涉及到密码,不建议脚本保存到公共环境. 安装oathtool Mac $ brew install oath-toolkit ...

  4. 关于select的使用感受~大坑~select不能添加点击事件触发~

    这是一个坑,把我摔惨了! select+option是浏览器自带的下拉选项框,样式及其丑,还好现在有很多框架都相应做了些美化,select 元素是一种表单控件,可用于在表单中接受用户输入. 还有一个重 ...

  5. python 类成员知识点学习的一个坑(初学者,大神请绕行)

    先来段小程序class Foo: name = "abc" def __init__(self,age): self.age = age print(Foo.name)Foo.na ...

  6. can't open the mysql.plugin table. please run mysql_upgrade to create it.

    To initialize a fresh data directory, you basically (after setting your config file) just have to ru ...

  7. 可遇不可求的Question之Sqlserver2005文件组的迁移篇

    Sqlserver2005 文件组的折腾 问题:由于数据庞大,我在数据库里面使用了分区表,建了很多文件组,一个分区对应一个文件组,一个文件组只有一个文件.我在建分区表的时候,在数据库属性里面“文件”选 ...

  8. 基于jmeter的性能测试平台(二) 一个构想

    之前基于jmeter搭好了分布式测试平台,但是感觉还是很粗糙,打算给它穿点衣服. 整个架构差不多就像下面这个图. (1)基于python django做一个web页面,友好地管理测试过程 (2)con ...

  9. 手工检测SQL注入漏洞

    SQL注入,就是通过把SQL命令插入到Web表单提交或输入域名或页面请求的查询字符串,最终达到欺骗服务器执行恶意的SQL命令,具体来说,它是利用现有应用程序将(恶意的)SQL命令注入到后台数据库引擎执 ...

  10. Canal学习笔记(客户端)

    前言 最近公司用到Canal来做从MySQL到Tidb的数据同步,用到HA模式Canal,记录一下HA模式的工作原理. Canal的架构模式 Canal是利用binlog日志来做数据同步,canal伪 ...