1 | 'use strict';
|
2 |
|
3 | const Base = require('sdk-base');
|
4 | const address = require('address');
|
5 | const MixAll = require('./mix_all');
|
6 |
|
7 | const defaultOptions = {
|
8 | instanceName: 'DEFAULT',
|
9 | pollNameServerInteval: 30 * 1000,
|
10 | heartbeatBrokerInterval: 30 * 1000,
|
11 | persistConsumerOffsetInterval: 5 * 1000,
|
12 | rebalanceInterval: 10 * 1000,
|
13 | clientIP: address.ip(),
|
14 | unitMode: false,
|
15 |
|
16 | namespace: '',
|
17 |
|
18 |
|
19 |
|
20 |
|
21 | onsAddr: 'http://onsaddr-internet.aliyun.com/rocketmq/nsaddr4client-internet',
|
22 |
|
23 |
|
24 | onsChannel: 'ALIYUN',
|
25 | };
|
26 |
|
27 | class ClientConfig extends Base {
|
28 |
|
29 | |
30 |
|
31 |
|
32 |
|
33 |
|
34 |
|
35 |
|
36 |
|
37 |
|
38 | constructor(options) {
|
39 | super(Object.assign({}, defaultOptions, options));
|
40 | this.instanceName = this.options.instanceName;
|
41 | }
|
42 |
|
43 | get clientId() {
|
44 | return `${this.options.clientIP}@${this.instanceName}`;
|
45 | }
|
46 |
|
47 | get pollNameServerInteval() {
|
48 | return this.options.pollNameServerInteval;
|
49 | }
|
50 |
|
51 | get heartbeatBrokerInterval() {
|
52 | return this.options.heartbeatBrokerInterval;
|
53 | }
|
54 |
|
55 | get persistConsumerOffsetInterval() {
|
56 | return this.options.persistConsumerOffsetInterval;
|
57 | }
|
58 |
|
59 | get rebalanceInterval() {
|
60 | return this.options.rebalanceInterval;
|
61 | }
|
62 |
|
63 | get unitMode() {
|
64 | return this.options.unitMode;
|
65 | }
|
66 |
|
67 | get namespace() {
|
68 | return this.options.namespace;
|
69 | }
|
70 |
|
71 | formatTopic(topic) {
|
72 | if (this.namespace && (!topic.startsWith(this.namespace) &&
|
73 | !topic.startsWith(MixAll.RETRY_GROUP_TOPIC_PREFIX))) {
|
74 | topic = `${this.namespace}%${topic}`;
|
75 | }
|
76 | return topic;
|
77 | }
|
78 |
|
79 | |
80 |
|
81 |
|
82 | changeInstanceNameToPID() {
|
83 | if (this.instanceName === 'DEFAULT') {
|
84 | this.instanceName = process.pid + '';
|
85 | }
|
86 | }
|
87 | }
|
88 |
|
89 | module.exports = ClientConfig;
|