duxinglangzi
2022-04-22 de8c2b2a4654893dc2c80f1fe095c165485bee5f
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
155
156
157
158
159
160
161
162
163
164
165
166
167
168
169
170
171
172
173
174
175
176
177
package com.duxinglangzi.canal.starter.configuration;
 
import org.springframework.boot.context.properties.ConfigurationProperties;
import org.springframework.core.Ordered;
import org.springframework.core.annotation.Order;
 
import java.util.LinkedHashMap;
import java.util.Map;
 
/**
 * @author wuqiong 2022/4/11
 * @description
 */
@Order(Ordered.HIGHEST_PRECEDENCE)
@ConfigurationProperties(prefix = "spring.canal")
public class CanalAutoConfigurationProperties {
 
    private Map<String, EndpointInstance> instances = new LinkedHashMap<>();
 
    public static class EndpointInstance {
 
        /**
         * 是否开启 cluster
         */
        private boolean clusterEnabled;
 
        /**
         * zookeeper 地址, 例: 192.168.0.1:2181,192.168.0.2:2181,192.168.0.3:2181
         */
        private String zookeeperAddress;
 
        /**
         * 默认 127.0.0.1
         */
        private String host = "127.0.0.1";
 
        /**
         * 端口 , 默认: 11111
         */
        private int port = 11111;
 
        /**
         * 用户名
         */
        private String userName = "";
 
        /**
         * 密码
         */
        private String password = "";
 
        /**
         * 每次获取数据条数 , 默认: 200
         */
        private int batchSize = 200;
 
        /**
         * 发生错误时重试次数 , 默认: 5
         */
        private int retryCount = 5;
 
        /**
         *
         * mysql 数据解析关注的表,Perl正则表达式.
         * <p>
         *
         * 多个正则之间以逗号(,)分隔,转义符需要双斜杠(\\)
         * <p>
         *
         * 常见例子: <p>
         * 1.  所有库表:.*   or  .*\\..* <p>
         * 2.  canal_db 下所有表:    canal_db\\..* <p>
         * 3.  canal_db 下的以canal打头的表:   canal_db\\.canal.* <p>
         * 4.  canal_db 下的一张表:  canal_db\\.test1 <p>
         * 5.  多个规则组合使用:canal_db\\..*,mysql_db.test1,mysql.test2 (逗号分隔) <p>
         *
         * 默认: 全库全表(.*\\..*)
         */
        private String subscribe = ".*\\..*";
 
        /**
         * 未拉取到消息情况下,获取消息的时间间隔毫秒值 , 默认: 1000
         */
        private long acquireInterval = 1000;
 
        public EndpointInstance() {
        }
 
        public boolean isClusterEnabled() {
            return clusterEnabled;
        }
 
        public void setClusterEnabled(boolean clusterEnabled) {
            this.clusterEnabled = clusterEnabled;
        }
 
        public String getZookeeperAddress() {
            return zookeeperAddress;
        }
 
        public void setZookeeperAddress(String zookeeperAddress) {
            this.zookeeperAddress = zookeeperAddress;
        }
 
        public String getHost() {
            return host;
        }
 
        public void setHost(String host) {
            this.host = host;
        }
 
        public int getPort() {
            return port;
        }
 
        public void setPort(int port) {
            this.port = port;
        }
 
        public String getUserName() {
            return userName;
        }
 
        public void setUserName(String userName) {
            this.userName = userName;
        }
 
        public String getPassword() {
            return password;
        }
 
        public void setPassword(String password) {
            this.password = password;
        }
 
        public int getBatchSize() {
            return batchSize;
        }
 
        public void setBatchSize(int batchSize) {
            this.batchSize = batchSize;
        }
 
        public int getRetryCount() {
            return retryCount;
        }
 
        public void setRetryCount(int retryCount) {
            this.retryCount = retryCount;
        }
 
        public long getAcquireInterval() {
            return acquireInterval;
        }
 
        public void setAcquireInterval(long acquireInterval) {
            this.acquireInterval = acquireInterval;
        }
 
        public String getSubscribe() {
            return subscribe;
        }
 
        public void setSubscribe(String subscribe) {
            this.subscribe = subscribe;
        }
    }
 
    public Map<String, EndpointInstance> getInstances() {
        return instances;
    }
 
    public void setInstances(Map<String, EndpointInstance> instances) {
        this.instances = instances;
    }
}