• Home
  • Features
  • Pricing
  • Docs
  • Announcements
  • Sign In

taosdata / TDengine / #3543

29 Nov 2024 02:58AM UTC coverage: 60.842% (+0.02%) from 60.819%
#3543

push

travis-ci

web-flow
Merge pull request #28973 from taosdata/merge/mainto3.0

merge: from main to 3.0

120460 of 253224 branches covered (47.57%)

Branch coverage included in aggregate %.

706 of 908 new or added lines in 18 files covered. (77.75%)

2401 existing lines in 137 files now uncovered.

201633 of 276172 relevant lines covered (73.01%)

19045673.23 hits per line

Source File
Press 'n' to go to next uncovered line, 'b' for previous

36.2
/source/dnode/mnode/impl/src/mndDump.c
1
/*
2
 * Copyright (c) 2019 TAOS Data, Inc. <jhtao@taosdata.com>
3
 *
4
 * This program is free software: you can use, redistribute, and/or modify
5
 * it under the terms of the GNU Affero General Public License, version 3
6
 * or later ("AGPL"), as published by the Free Software Foundation.
7
 *
8
 * This program is distributed in the hope that it will be useful, but WITHOUT
9
 * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
10
 * FITNESS FOR A PARTICULAR PURPOSE.
11
 *
12
 * You should have received a copy of the GNU Affero General Public License
13
 * along with this program. If not, see <http://www.gnu.org/licenses/>.
14
 */
15

16
#define _DEFAULT_SOURCE
17
#include "mndDb.h"
18
#include "mndInt.h"
19
#include "mndShow.h"
20
#include "mndStb.h"
21
#include "sdb.h"
22
#include "tconfig.h"
23
#include "tjson.h"
24
#include "ttypes.h"
25

26
#pragma GCC diagnostic push
27
#pragma GCC diagnostic ignored "-Wunused-result"
28

29
void reportStartup(const char *name, const char *desc) {}
35✔
30
void sendRsp(SRpcMsg *pMsg) { rpcFreeCont(pMsg->pCont); }
×
31

32
int32_t sendReq(const SEpSet *pEpSet, SRpcMsg *pMsg) {
×
33
  int32_t code = 0;
×
34
  code = TSDB_CODE_INVALID_PTR;
×
35
  TAOS_RETURN(code);
×
36
}
37
int32_t sendSyncReq(const SEpSet *pEpSet, SRpcMsg *pMsg) {
×
38
  int32_t code = 0;
×
39
  code = TSDB_CODE_INVALID_PTR;
×
40
  TAOS_RETURN(code);
×
41
}
42

43
char *i642str(int64_t val) {
416✔
44
  static char str[24] = {0};
45
  (void)snprintf(str, sizeof(str), "%" PRId64, val);
416✔
46
  return str;
416✔
47
}
48

49
void dumpFunc(SSdb *pSdb, SJson *json) {
1✔
50
  int32_t code = 0;
1✔
51
  int32_t lino = 0;
1✔
52
  void   *pIter = NULL;
1✔
53
  SJson *items = tjsonAddArrayToObject(json, "funcs");
1✔
54

55
  while (1) {
×
56
    SFuncObj *pObj = NULL;
1✔
57
    pIter = sdbFetch(pSdb, SDB_FUNC, pIter, (void **)&pObj);
1✔
58
    if (pIter == NULL) break;
1!
59

60
    SJson *item = tjsonCreateObject();
×
61
    RETRIEVE_CHECK_GOTO(tjsonAddItemToArray(items, item), pObj, &lino, _OVER);
×
62
    RETRIEVE_CHECK_GOTO(tjsonAddStringToObject(item, "name", pObj->name), pObj, &lino, _OVER);
×
63
    RETRIEVE_CHECK_GOTO(tjsonAddStringToObject(item, "createdTime", i642str(pObj->createdTime)), pObj, &lino, _OVER);
×
64
    RETRIEVE_CHECK_GOTO(tjsonAddStringToObject(item, "funcType", i642str(pObj->funcType)), pObj, &lino, _OVER);
×
65
    RETRIEVE_CHECK_GOTO(tjsonAddStringToObject(item, "scriptType", i642str(pObj->scriptType)), pObj, &lino, _OVER);
×
66
    RETRIEVE_CHECK_GOTO(tjsonAddStringToObject(item, "align", i642str(pObj->align)), pObj, &lino, _OVER);
×
67
    RETRIEVE_CHECK_GOTO(tjsonAddStringToObject(item, "outputType", i642str(pObj->outputType)), pObj, &lino, _OVER);
×
68
    RETRIEVE_CHECK_GOTO(tjsonAddStringToObject(item, "outputLen", i642str(pObj->outputLen)), pObj, &lino, _OVER);
×
69
    RETRIEVE_CHECK_GOTO(tjsonAddStringToObject(item, "bufSize", i642str(pObj->bufSize)), pObj, &lino, _OVER);
×
70
    RETRIEVE_CHECK_GOTO(tjsonAddStringToObject(item, "signature", i642str(pObj->signature)), pObj, &lino, _OVER);
×
71
    RETRIEVE_CHECK_GOTO(tjsonAddStringToObject(item, "commentSize", i642str(pObj->commentSize)), pObj, &lino, _OVER);
×
72
    RETRIEVE_CHECK_GOTO(tjsonAddStringToObject(item, "codeSize", i642str(pObj->codeSize)), pObj, &lino, _OVER);
×
73
    sdbRelease(pSdb, pObj);
×
74
  }
75
_OVER:
1✔
76
  if (code != 0) mError("failed to dump func info at line:%d since %s", lino, tstrerror(code));
1!
77
}
1✔
78

79
void dumpDb(SSdb *pSdb, SJson *json) {
1✔
80
  int32_t code = 0;
1✔
81
  int32_t lino = 0;
1✔
82
  void  *pIter = NULL;
1✔
83
  SJson *items = tjsonCreateObject();
1✔
84
  TAOS_CHECK_GOTO(tjsonAddItemToObject(json, "dbs", items), &lino, _OVER);
1!
85

86
  while (1) {
2✔
87
    SDbObj *pObj = NULL;
3✔
88
    pIter = sdbFetch(pSdb, SDB_DB, pIter, (void **)&pObj);
3✔
89
    if (pIter == NULL) break;
3✔
90

91
    SJson *item = tjsonCreateObject();
2✔
92
    RETRIEVE_CHECK_GOTO(tjsonAddItemToObject(items, "db", item), pObj, &lino, _OVER);
2!
93

94
    RETRIEVE_CHECK_GOTO(tjsonAddStringToObject(item, "name", mndGetDbStr(pObj->name)), pObj, &lino, _OVER);
2!
95
    RETRIEVE_CHECK_GOTO(tjsonAddStringToObject(item, "acct", pObj->acct), pObj, &lino, _OVER);
2!
96
    RETRIEVE_CHECK_GOTO(tjsonAddStringToObject(item, "createUser", pObj->createUser), pObj, &lino, _OVER);
2!
97
    RETRIEVE_CHECK_GOTO(tjsonAddStringToObject(item, "createdTime", i642str(pObj->createdTime)), pObj, &lino, _OVER);
2!
98
    RETRIEVE_CHECK_GOTO(tjsonAddStringToObject(item, "updateTime", i642str(pObj->updateTime)), pObj, &lino, _OVER);
2!
99
    RETRIEVE_CHECK_GOTO(tjsonAddStringToObject(item, "uid", i642str(pObj->uid)), pObj, &lino, _OVER);
2!
100
    RETRIEVE_CHECK_GOTO(tjsonAddStringToObject(item, "cfgVersion", i642str(pObj->cfgVersion)), pObj, &lino, _OVER);
2!
101
    RETRIEVE_CHECK_GOTO(tjsonAddStringToObject(item, "vgVersion", i642str(pObj->vgVersion)), pObj, &lino, _OVER);
2!
102
    RETRIEVE_CHECK_GOTO(tjsonAddStringToObject(item, "numOfVgroups", i642str(pObj->cfg.numOfVgroups)), pObj, &lino,
2!
103
                        _OVER);
104
    RETRIEVE_CHECK_GOTO(tjsonAddStringToObject(item, "numOfStables", i642str(pObj->cfg.numOfStables)), pObj, &lino,
2!
105
                        _OVER);
106
    RETRIEVE_CHECK_GOTO(tjsonAddStringToObject(item, "buffer", i642str(pObj->cfg.buffer)), pObj, &lino, _OVER);
2!
107
    RETRIEVE_CHECK_GOTO(tjsonAddStringToObject(item, "pageSize", i642str(pObj->cfg.pageSize)), pObj, &lino, _OVER);
2!
108
    RETRIEVE_CHECK_GOTO(tjsonAddStringToObject(item, "pages", i642str(pObj->cfg.pages)), pObj, &lino, _OVER);
2!
109
    RETRIEVE_CHECK_GOTO(tjsonAddStringToObject(item, "cacheLastSize", i642str(pObj->cfg.cacheLastSize)), pObj, &lino,
2!
110
                        _OVER);
111
    RETRIEVE_CHECK_GOTO(tjsonAddStringToObject(item, "daysPerFile", i642str(pObj->cfg.daysPerFile)), pObj, &lino,
2!
112
                        _OVER);
113
    RETRIEVE_CHECK_GOTO(tjsonAddStringToObject(item, "daysToKeep0", i642str(pObj->cfg.daysToKeep0)), pObj, &lino,
2!
114
                        _OVER);
115
    RETRIEVE_CHECK_GOTO(tjsonAddStringToObject(item, "daysToKeep1", i642str(pObj->cfg.daysToKeep1)), pObj, &lino,
2!
116
                        _OVER);
117
    RETRIEVE_CHECK_GOTO(tjsonAddStringToObject(item, "daysToKeep2", i642str(pObj->cfg.daysToKeep2)), pObj, &lino,
2!
118
                        _OVER);
119
    RETRIEVE_CHECK_GOTO(tjsonAddStringToObject(item, "minRows", i642str(pObj->cfg.minRows)), pObj, &lino, _OVER);
2!
120
    RETRIEVE_CHECK_GOTO(tjsonAddStringToObject(item, "maxRows", i642str(pObj->cfg.maxRows)), pObj, &lino, _OVER);
2!
121
    RETRIEVE_CHECK_GOTO(tjsonAddStringToObject(item, "precision", i642str(pObj->cfg.precision)), pObj, &lino, _OVER);
2!
122
    RETRIEVE_CHECK_GOTO(tjsonAddStringToObject(item, "compression", i642str(pObj->cfg.compression)), pObj, &lino,
2!
123
                        _OVER);
124
    RETRIEVE_CHECK_GOTO(tjsonAddStringToObject(item, "encryptAlgorithm", i642str(pObj->cfg.encryptAlgorithm)), pObj,
2!
125
                        &lino, _OVER);
126
    RETRIEVE_CHECK_GOTO(tjsonAddStringToObject(item, "replications", i642str(pObj->cfg.replications)), pObj, &lino,
2!
127
                        _OVER);
128
    RETRIEVE_CHECK_GOTO(tjsonAddStringToObject(item, "strict", i642str(pObj->cfg.strict)), pObj, &lino, _OVER);
2!
129
    RETRIEVE_CHECK_GOTO(tjsonAddStringToObject(item, "cacheLast", i642str(pObj->cfg.cacheLast)), pObj, &lino, _OVER);
2!
130
    RETRIEVE_CHECK_GOTO(tjsonAddStringToObject(item, "hashMethod", i642str(pObj->cfg.hashMethod)), pObj, &lino, _OVER);
2!
131
    RETRIEVE_CHECK_GOTO(tjsonAddStringToObject(item, "hashPrefix", i642str(pObj->cfg.hashPrefix)), pObj, &lino, _OVER);
2!
132
    RETRIEVE_CHECK_GOTO(tjsonAddStringToObject(item, "hashSuffix", i642str(pObj->cfg.hashSuffix)), pObj, &lino, _OVER);
2!
133
    RETRIEVE_CHECK_GOTO(tjsonAddStringToObject(item, "sstTrigger", i642str(pObj->cfg.sstTrigger)), pObj, &lino, _OVER);
2!
134
    RETRIEVE_CHECK_GOTO(tjsonAddStringToObject(item, "tsdbPageSize", i642str(pObj->cfg.tsdbPageSize)), pObj, &lino,
2!
135
                        _OVER);
136
    RETRIEVE_CHECK_GOTO(tjsonAddStringToObject(item, "schemaless", i642str(pObj->cfg.schemaless)), pObj, &lino, _OVER);
2!
137
    RETRIEVE_CHECK_GOTO(tjsonAddStringToObject(item, "walLevel", i642str(pObj->cfg.walLevel)), pObj, &lino, _OVER);
2!
138
    RETRIEVE_CHECK_GOTO(tjsonAddStringToObject(item, "walFsyncPeriod", i642str(pObj->cfg.walFsyncPeriod)), pObj, &lino,
2!
139
                        _OVER);
140
    RETRIEVE_CHECK_GOTO(tjsonAddStringToObject(item, "walRetentionPeriod", i642str(pObj->cfg.walRetentionPeriod)), pObj,
2!
141
                        &lino, _OVER);
142
    RETRIEVE_CHECK_GOTO(tjsonAddStringToObject(item, "walRetentionSize", i642str(pObj->cfg.walRetentionSize)), pObj,
2!
143
                        &lino, _OVER);
144
    RETRIEVE_CHECK_GOTO(tjsonAddStringToObject(item, "walRollPeriod", i642str(pObj->cfg.walRollPeriod)), pObj, &lino,
2!
145
                        _OVER);
146
    RETRIEVE_CHECK_GOTO(tjsonAddStringToObject(item, "walSegmentSize", i642str(pObj->cfg.walSegmentSize)), pObj, &lino,
2!
147
                        _OVER);
148

149
    RETRIEVE_CHECK_GOTO(tjsonAddStringToObject(item, "numOfRetensions", i642str(pObj->cfg.numOfRetensions)), pObj,
2!
150
                        &lino, _OVER);
151
    for (int32_t i = 0; i < pObj->cfg.numOfRetensions; ++i) {
2!
152
      SJson *rentensions = tjsonAddArrayToObject(item, "rentensions");
×
153
      SJson *rentension = tjsonCreateObject();
×
154
      RETRIEVE_CHECK_GOTO(tjsonAddItemToArray(rentensions, rentension), pObj, &lino, _OVER);
×
155

156
      SRetention *pRetension = taosArrayGet(pObj->cfg.pRetensions, i);
×
157
      RETRIEVE_CHECK_GOTO(tjsonAddStringToObject(item, "freq", i642str(pRetension->freq)), pObj, &lino, _OVER);
×
158
      RETRIEVE_CHECK_GOTO(tjsonAddStringToObject(item, "freqUnit", i642str(pRetension->freqUnit)), pObj, &lino, _OVER);
×
159
      RETRIEVE_CHECK_GOTO(tjsonAddStringToObject(item, "keep", i642str(pRetension->keep)), pObj, &lino, _OVER);
×
160
      RETRIEVE_CHECK_GOTO(tjsonAddStringToObject(item, "keepUnit", i642str(pRetension->keepUnit)), pObj, &lino, _OVER);
×
161
    }
162

163
    sdbRelease(pSdb, pObj);
2✔
164
  }
165
_OVER:
1✔
166
  if (code != 0) mError("failed to dump db info at line:%d since %s", lino, tstrerror(code));
1!
167
}
1✔
168

169
void dumpStb(SSdb *pSdb, SJson *json) {
1✔
170
  int32_t code = 0;
1✔
171
  int32_t lino = 0;
1✔
172
  void  *pIter = NULL;
1✔
173
  SJson *items = tjsonAddArrayToObject(json, "stbs");
1✔
174

175
  while (1) {
3✔
176
    SStbObj *pObj = NULL;
4✔
177
    pIter = sdbFetch(pSdb, SDB_STB, pIter, (void **)&pObj);
4✔
178
    if (pIter == NULL) break;
4✔
179

180
    SJson *item = tjsonCreateObject();
3✔
181
    RETRIEVE_CHECK_GOTO(tjsonAddItemToArray(items, item), pObj, &lino, _OVER);
3!
182
    RETRIEVE_CHECK_GOTO(tjsonAddStringToObject(item, "name", mndGetStbStr(pObj->name)), pObj, &lino, _OVER);
3!
183
    RETRIEVE_CHECK_GOTO(tjsonAddStringToObject(item, "db", mndGetDbStr(pObj->db)), pObj, &lino, _OVER);
3!
184
    RETRIEVE_CHECK_GOTO(tjsonAddStringToObject(item, "createdTime", i642str(pObj->createdTime)), pObj, &lino, _OVER);
3!
185
    RETRIEVE_CHECK_GOTO(tjsonAddStringToObject(item, "updateTime", i642str(pObj->updateTime)), pObj, &lino, _OVER);
3!
186
    RETRIEVE_CHECK_GOTO(tjsonAddStringToObject(item, "uid", i642str(pObj->uid)), pObj, &lino, _OVER);
3!
187
    RETRIEVE_CHECK_GOTO(tjsonAddStringToObject(item, "dbUid", i642str(pObj->dbUid)), pObj, &lino, _OVER);
3!
188
    RETRIEVE_CHECK_GOTO(tjsonAddStringToObject(item, "tagVer", i642str(pObj->tagVer)), pObj, &lino, _OVER);
3!
189
    RETRIEVE_CHECK_GOTO(tjsonAddStringToObject(item, "colVer", i642str(pObj->colVer)), pObj, &lino, _OVER);
3!
190
    RETRIEVE_CHECK_GOTO(tjsonAddStringToObject(item, "smaVer", i642str(pObj->smaVer)), pObj, &lino, _OVER);
3!
191
    RETRIEVE_CHECK_GOTO(tjsonAddStringToObject(item, "nextColId", i642str(pObj->nextColId)), pObj, &lino, _OVER);
3!
192
    RETRIEVE_CHECK_GOTO(tjsonAddStringToObject(item, "watermark1", i642str(pObj->watermark[0])), pObj, &lino, _OVER);
3!
193
    RETRIEVE_CHECK_GOTO(tjsonAddStringToObject(item, "watermark2", i642str(pObj->watermark[1])), pObj, &lino, _OVER);
3!
194
    RETRIEVE_CHECK_GOTO(tjsonAddStringToObject(item, "maxdelay0", i642str(pObj->maxdelay[0])), pObj, &lino, _OVER);
3!
195
    RETRIEVE_CHECK_GOTO(tjsonAddStringToObject(item, "maxdelay1", i642str(pObj->maxdelay[1])), pObj, &lino, _OVER);
3!
196
    RETRIEVE_CHECK_GOTO(tjsonAddStringToObject(item, "ttl", i642str(pObj->ttl)), pObj, &lino, _OVER);
3!
197
    RETRIEVE_CHECK_GOTO(tjsonAddStringToObject(item, "numOfFuncs", i642str(pObj->numOfFuncs)), pObj, &lino, _OVER);
3!
198
    RETRIEVE_CHECK_GOTO(tjsonAddStringToObject(item, "commentLen", i642str(pObj->commentLen)), pObj, &lino, _OVER);
3!
199
    RETRIEVE_CHECK_GOTO(tjsonAddStringToObject(item, "ast1Len", i642str(pObj->ast1Len)), pObj, &lino, _OVER);
3!
200
    RETRIEVE_CHECK_GOTO(tjsonAddStringToObject(item, "ast2Len", i642str(pObj->ast2Len)), pObj, &lino, _OVER);
3!
201

202
    RETRIEVE_CHECK_GOTO(tjsonAddStringToObject(item, "numOfColumns", i642str(pObj->numOfColumns)), pObj, &lino, _OVER);
3!
203
    SJson *columns = tjsonAddArrayToObject(item, "columns");
3✔
204
    for (int32_t i = 0; i < pObj->numOfColumns; ++i) {
13✔
205
      SJson *column = tjsonCreateObject();
10✔
206
      RETRIEVE_CHECK_GOTO(tjsonAddItemToArray(columns, column), pObj, &lino, _OVER);
10!
207

208
      SSchema *pColumn = &pObj->pColumns[i];
10✔
209
      RETRIEVE_CHECK_GOTO(tjsonAddStringToObject(column, "type", i642str(pColumn->type)), pObj, &lino, _OVER);
10!
210
      RETRIEVE_CHECK_GOTO(tjsonAddStringToObject(column, "typestr", tDataTypes[pColumn->type].name), pObj, &lino,
10!
211
                          _OVER);
212
      RETRIEVE_CHECK_GOTO(tjsonAddStringToObject(column, "flags", i642str(pColumn->flags)), pObj, &lino, _OVER);
10!
213
      RETRIEVE_CHECK_GOTO(tjsonAddStringToObject(column, "colId", i642str(pColumn->colId)), pObj, &lino, _OVER);
10!
214
      RETRIEVE_CHECK_GOTO(tjsonAddStringToObject(column, "bytes", i642str(pColumn->bytes)), pObj, &lino, _OVER);
10!
215
      RETRIEVE_CHECK_GOTO(tjsonAddStringToObject(column, "name", pColumn->name), pObj, &lino, _OVER);
10!
216
    }
217

218
    RETRIEVE_CHECK_GOTO(tjsonAddStringToObject(item, "numOfTags", i642str(pObj->numOfTags)), pObj, &lino, _OVER);
3!
219
    SJson *tags = tjsonAddArrayToObject(item, "tags");
3✔
220
    for (int32_t i = 0; i < pObj->numOfTags; ++i) {
6✔
221
      SJson *tag = tjsonCreateObject();
3✔
222
      RETRIEVE_CHECK_GOTO(tjsonAddItemToArray(tags, tag), pObj, &lino, _OVER);
3!
223

224
      SSchema *pTag = &pObj->pTags[i];
3✔
225
      RETRIEVE_CHECK_GOTO(tjsonAddStringToObject(tag, "type", i642str(pTag->type)), pObj, &lino, _OVER);
3!
226
      RETRIEVE_CHECK_GOTO(tjsonAddStringToObject(tag, "typestr", tDataTypes[pTag->type].name), pObj, &lino, _OVER);
3!
227
      RETRIEVE_CHECK_GOTO(tjsonAddStringToObject(tag, "flags", i642str(pTag->flags)), pObj, &lino, _OVER);
3!
228
      RETRIEVE_CHECK_GOTO(tjsonAddStringToObject(tag, "colId", i642str(pTag->colId)), pObj, &lino, _OVER);
3!
229
      RETRIEVE_CHECK_GOTO(tjsonAddStringToObject(tag, "bytes", i642str(pTag->bytes)), pObj, &lino, _OVER);
3!
230
      RETRIEVE_CHECK_GOTO(tjsonAddStringToObject(tag, "name", pTag->name), pObj, &lino, _OVER);
3!
231
    }
232

233
    sdbRelease(pSdb, pObj);
3✔
234
  }
235
_OVER:
1✔
236
  if (code != 0) mError("failed to dump stable info at line:%d since %s", lino, tstrerror(code));
1!
237
}
1✔
238

239
void dumpSma(SSdb *pSdb, SJson *json) {
1✔
240
  int32_t code = 0;
1✔
241
  int32_t lino = 0;
1✔
242
  void  *pIter = NULL;
1✔
243
  SJson *items = tjsonAddArrayToObject(json, "smas");
1✔
244

245
  while (1) {
1✔
246
    SSmaObj *pObj = NULL;
2✔
247
    pIter = sdbFetch(pSdb, SDB_SMA, pIter, (void **)&pObj);
2✔
248
    if (pIter == NULL) break;
2✔
249

250
    SJson *item = tjsonCreateObject();
1✔
251
    RETRIEVE_CHECK_GOTO(tjsonAddItemToArray(items, item), pObj, &lino, _OVER);
1!
252
    RETRIEVE_CHECK_GOTO(tjsonAddStringToObject(item, "name", mndGetStbStr(pObj->name)), pObj, &lino, _OVER);
1!
253
    RETRIEVE_CHECK_GOTO(tjsonAddStringToObject(item, "stb", mndGetStbStr(pObj->stb)), pObj, &lino, _OVER);
1!
254
    RETRIEVE_CHECK_GOTO(tjsonAddStringToObject(item, "db", mndGetDbStr(pObj->db)), pObj, &lino, _OVER);
1!
255
    RETRIEVE_CHECK_GOTO(tjsonAddStringToObject(item, "dstTbName", mndGetStbStr(pObj->dstTbName)), pObj, &lino, _OVER);
1!
256
    RETRIEVE_CHECK_GOTO(tjsonAddStringToObject(item, "createdTime", i642str(pObj->createdTime)), pObj, &lino, _OVER);
1!
257
    RETRIEVE_CHECK_GOTO(tjsonAddStringToObject(item, "uid", i642str(pObj->uid)), pObj, &lino, _OVER);
1!
258
    RETRIEVE_CHECK_GOTO(tjsonAddStringToObject(item, "stbUid", i642str(pObj->stbUid)), pObj, &lino, _OVER);
1!
259
    RETRIEVE_CHECK_GOTO(tjsonAddStringToObject(item, "dbUid", i642str(pObj->dbUid)), pObj, &lino, _OVER);
1!
260
    RETRIEVE_CHECK_GOTO(tjsonAddStringToObject(item, "dstTbUid", i642str(pObj->dstTbUid)), pObj, &lino, _OVER);
1!
261
    RETRIEVE_CHECK_GOTO(tjsonAddStringToObject(item, "intervalUnit", i642str(pObj->intervalUnit)), pObj, &lino, _OVER);
1!
262
    RETRIEVE_CHECK_GOTO(tjsonAddStringToObject(item, "slidingUnit", i642str(pObj->slidingUnit)), pObj, &lino, _OVER);
1!
263
    RETRIEVE_CHECK_GOTO(tjsonAddStringToObject(item, "timezone", i642str(pObj->timezone)), pObj, &lino, _OVER);
1!
264
    RETRIEVE_CHECK_GOTO(tjsonAddStringToObject(item, "dstVgId", i642str(pObj->dstVgId)), pObj, &lino, _OVER);
1!
265
    RETRIEVE_CHECK_GOTO(tjsonAddStringToObject(item, "interval", i642str(pObj->interval)), pObj, &lino, _OVER);
1!
266
    RETRIEVE_CHECK_GOTO(tjsonAddStringToObject(item, "offset", i642str(pObj->offset)), pObj, &lino, _OVER);
1!
267
    RETRIEVE_CHECK_GOTO(tjsonAddStringToObject(item, "sliding", i642str(pObj->sliding)), pObj, &lino, _OVER);
1!
268
    RETRIEVE_CHECK_GOTO(tjsonAddStringToObject(item, "exprLen", i642str(pObj->exprLen)), pObj, &lino, _OVER);
1!
269
    RETRIEVE_CHECK_GOTO(tjsonAddStringToObject(item, "tagsFilterLen", i642str(pObj->tagsFilterLen)), pObj, &lino,
1!
270
                        _OVER);
271
    RETRIEVE_CHECK_GOTO(tjsonAddStringToObject(item, "sqlLen", i642str(pObj->sqlLen)), pObj, &lino, _OVER);
1!
272
    RETRIEVE_CHECK_GOTO(tjsonAddStringToObject(item, "astLen", i642str(pObj->astLen)), pObj, &lino, _OVER);
1!
273
    sdbRelease(pSdb, pObj);
1✔
274
  }
275
_OVER:
1✔
276
  if (code != 0) mError("failed to dump sma info at line:%d since %s", lino, tstrerror(code));
1!
277
}
1✔
278

279
void dumpVgroup(SSdb *pSdb, SJson *json) {
1✔
280
  int32_t code = 0;
1✔
281
  int32_t lino = 0;
1✔
282
  void  *pIter = NULL;
1✔
283
  SJson *items = tjsonAddArrayToObject(json, "vgroups");
1✔
284

285
  while (1) {
6✔
286
    SVgObj *pObj = NULL;
7✔
287
    pIter = sdbFetch(pSdb, SDB_VGROUP, pIter, (void **)&pObj);
7✔
288
    if (pIter == NULL) break;
7✔
289

290
    SJson *item = tjsonCreateObject();
6✔
291
    RETRIEVE_CHECK_GOTO(tjsonAddItemToArray(items, item), pObj, &lino, _OVER);
6!
292
    RETRIEVE_CHECK_GOTO(tjsonAddStringToObject(item, "vgId", i642str(pObj->vgId)), pObj, &lino, _OVER);
6!
293
    RETRIEVE_CHECK_GOTO(tjsonAddStringToObject(item, "createdTime", i642str(pObj->createdTime)), pObj, &lino, _OVER);
6!
294
    RETRIEVE_CHECK_GOTO(tjsonAddStringToObject(item, "updateTime", i642str(pObj->updateTime)), pObj, &lino, _OVER);
6!
295
    RETRIEVE_CHECK_GOTO(tjsonAddStringToObject(item, "version", i642str(pObj->version)), pObj, &lino, _OVER);
6!
296
    RETRIEVE_CHECK_GOTO(tjsonAddStringToObject(item, "hashBegin", i642str(pObj->hashBegin)), pObj, &lino, _OVER);
6!
297
    RETRIEVE_CHECK_GOTO(tjsonAddStringToObject(item, "hashEnd", i642str(pObj->hashEnd)), pObj, &lino, _OVER);
6!
298
    RETRIEVE_CHECK_GOTO(tjsonAddStringToObject(item, "db", mndGetDbStr(pObj->dbName)), pObj, &lino, _OVER);
6!
299
    RETRIEVE_CHECK_GOTO(tjsonAddStringToObject(item, "dbUid", i642str(pObj->dbUid)), pObj, &lino, _OVER);
6!
300
    RETRIEVE_CHECK_GOTO(tjsonAddStringToObject(item, "isTsma", i642str(pObj->isTsma)), pObj, &lino, _OVER);
6!
301
    RETRIEVE_CHECK_GOTO(tjsonAddStringToObject(item, "replica", i642str(pObj->replica)), pObj, &lino, _OVER);
6!
302
    for (int32_t i = 0; i < pObj->replica; ++i) {
12✔
303
      SJson *replicas = tjsonAddArrayToObject(item, "replicas");
6✔
304
      SJson *replica = tjsonCreateObject();
6✔
305
      RETRIEVE_CHECK_GOTO(tjsonAddItemToArray(replicas, replica), pObj, &lino, _OVER);
6!
306
      RETRIEVE_CHECK_GOTO(tjsonAddStringToObject(replica, "dnodeId", i642str(pObj->vnodeGid[i].dnodeId)), pObj, &lino,
6!
307
                          _OVER);
308
    }
309
    sdbRelease(pSdb, pObj);
6✔
310
  }
311
_OVER:
1✔
312
  if (code != 0) mError("failed to dump vgroup info at line:%d since %s", lino, tstrerror(code));
1!
313
}
1✔
314

315
void dumpTopic(SSdb *pSdb, SJson *json) {
1✔
316
  int32_t code = 0;
1✔
317
  int32_t lino = 0;
1✔
318
  void  *pIter = NULL;
1✔
319
  SJson *items = tjsonAddArrayToObject(json, "topics");
1✔
320

321
  while (1) {
1✔
322
    SMqTopicObj *pObj = NULL;
2✔
323
    pIter = sdbFetch(pSdb, SDB_TOPIC, pIter, (void **)&pObj);
2✔
324
    if (pIter == NULL) break;
2✔
325

326
    SJson *item = tjsonCreateObject();
1✔
327
    RETRIEVE_CHECK_GOTO(tjsonAddItemToArray(items, item), pObj, &lino, _OVER);
1!
328
    RETRIEVE_CHECK_GOTO(tjsonAddStringToObject(item, "name", mndGetDbStr(pObj->name)), pObj, &lino, _OVER);
1!
329
    RETRIEVE_CHECK_GOTO(tjsonAddStringToObject(item, "name", mndGetDbStr(pObj->db)), pObj, &lino, _OVER);
1!
330
    RETRIEVE_CHECK_GOTO(tjsonAddStringToObject(item, "createTime", i642str(pObj->createTime)), pObj, &lino, _OVER);
1!
331
    RETRIEVE_CHECK_GOTO(tjsonAddStringToObject(item, "updateTime", i642str(pObj->updateTime)), pObj, &lino, _OVER);
1!
332
    RETRIEVE_CHECK_GOTO(tjsonAddStringToObject(item, "uid", i642str(pObj->uid)), pObj, &lino, _OVER);
1!
333
    RETRIEVE_CHECK_GOTO(tjsonAddStringToObject(item, "dbUid", i642str(pObj->dbUid)), pObj, &lino, _OVER);
1!
334
    RETRIEVE_CHECK_GOTO(tjsonAddStringToObject(item, "version", i642str(pObj->version)), pObj, &lino, _OVER);
1!
335
    RETRIEVE_CHECK_GOTO(tjsonAddStringToObject(item, "subType", i642str(pObj->subType)), pObj, &lino, _OVER);
1!
336
    RETRIEVE_CHECK_GOTO(tjsonAddStringToObject(item, "withMeta", i642str(pObj->withMeta)), pObj, &lino, _OVER);
1!
337
    RETRIEVE_CHECK_GOTO(tjsonAddStringToObject(item, "stbUid", i642str(pObj->stbUid)), pObj, &lino, _OVER);
1!
338
    RETRIEVE_CHECK_GOTO(tjsonAddStringToObject(item, "stbName", mndGetStableStr(pObj->stbName)), pObj, &lino, _OVER);
1!
339
    RETRIEVE_CHECK_GOTO(tjsonAddStringToObject(item, "sqlLen", i642str(pObj->sqlLen)), pObj, &lino, _OVER);
1!
340
    RETRIEVE_CHECK_GOTO(tjsonAddStringToObject(item, "astLen", i642str(pObj->astLen)), pObj, &lino, _OVER);
1!
341
    RETRIEVE_CHECK_GOTO(tjsonAddStringToObject(item, "sqlLen", i642str(pObj->sqlLen)), pObj, &lino, _OVER);
1!
342
    RETRIEVE_CHECK_GOTO(tjsonAddStringToObject(item, "ntbUid", i642str(pObj->ntbUid)), pObj, &lino, _OVER);
1!
343
    RETRIEVE_CHECK_GOTO(tjsonAddStringToObject(item, "ctbStbUid", i642str(pObj->ctbStbUid)), pObj, &lino, _OVER);
1!
344
    sdbRelease(pSdb, pObj);
1✔
345
  }
346
_OVER:
1✔
347
  if (code != 0) mError("failed to dump topic info at line:%d since %s", lino, tstrerror(code));
1!
348
}
1✔
349

350
void dumpConsumer(SSdb *pSdb, SJson *json) {
1✔
351
  int32_t code = 0;
1✔
352
  int32_t lino = 0;
1✔
353
  void  *pIter = NULL;
1✔
354
  SJson *items = tjsonAddArrayToObject(json, "consumers");
1✔
355

356
  while (1) {
×
357
    SMqConsumerObj *pObj = NULL;
1✔
358
    pIter = sdbFetch(pSdb, SDB_CONSUMER, pIter, (void **)&pObj);
1✔
359
    if (pIter == NULL) break;
1!
360

361
    SJson *item = tjsonCreateObject();
×
362
    RETRIEVE_CHECK_GOTO(tjsonAddItemToArray(items, item), pObj, &lino, _OVER);
×
363
    RETRIEVE_CHECK_GOTO(tjsonAddStringToObject(item, "consumerId", i642str(pObj->consumerId)), pObj, &lino, _OVER);
×
364
    RETRIEVE_CHECK_GOTO(tjsonAddStringToObject(item, "cgroup", pObj->cgroup), pObj, &lino, _OVER);
×
365
    sdbRelease(pSdb, pObj);
×
366
  }
367
_OVER:
1✔
368
  if (code != 0) mError("failed to dump consumer info at line:%d since %s", lino, tstrerror(code));
1!
369
}
1✔
370

371
void dumpSubscribe(SSdb *pSdb, SJson *json) {
1✔
372
  int32_t code = 0;
1✔
373
  int32_t lino = 0;
1✔
374
  void  *pIter = NULL;
1✔
375
  SJson *items = tjsonAddArrayToObject(json, "subscribes");
1✔
376

377
  while (1) {
×
378
    SMqSubscribeObj *pObj = NULL;
1✔
379
    pIter = sdbFetch(pSdb, SDB_SUBSCRIBE, pIter, (void **)&pObj);
1✔
380
    if (pIter == NULL) break;
1!
381

382
    SJson *item = tjsonCreateObject();
×
383
    RETRIEVE_CHECK_GOTO(tjsonAddItemToArray(items, item), pObj, &lino, _OVER);
×
384
    RETRIEVE_CHECK_GOTO(tjsonAddStringToObject(item, "key", pObj->key), pObj, &lino, _OVER);
×
385
    RETRIEVE_CHECK_GOTO(tjsonAddStringToObject(item, "dbUid", i642str(pObj->dbUid)), pObj, &lino, _OVER);
×
386
    RETRIEVE_CHECK_GOTO(tjsonAddStringToObject(item, "stbUid", i642str(pObj->stbUid)), pObj, &lino, _OVER);
×
387
    sdbRelease(pSdb, pObj);
×
388
  }
389
_OVER:
1✔
390
  if (code != 0) mError("failed to dump subscribe info at line:%d since %s", lino, tstrerror(code));
1!
391
}
1✔
392

393
void dumpStream(SSdb *pSdb, SJson *json) {
1✔
394
  int32_t code = 0;
1✔
395
  int32_t lino = 0;
1✔
396
  void   *pIter = NULL;
1✔
397
  SJson *items = tjsonAddArrayToObject(json, "streams");
1✔
398

399
  while (1) {
2✔
400
    SStreamObj *pObj = NULL;
3✔
401
    pIter = sdbFetch(pSdb, SDB_STREAM, pIter, (void **)&pObj);
3✔
402
    if (pIter == NULL) break;
3✔
403

404
    SJson *item = tjsonCreateObject();
2✔
405
    RETRIEVE_CHECK_GOTO(tjsonAddItemToArray(items, item), pObj, &lino, _OVER);
2!
406
    RETRIEVE_CHECK_GOTO(tjsonAddStringToObject(item, "name", mndGetDbStr(pObj->name)), pObj, &lino, _OVER);
2!
407
    RETRIEVE_CHECK_GOTO(tjsonAddStringToObject(item, "createTime", i642str(pObj->createTime)), pObj, &lino, _OVER);
2!
408
    RETRIEVE_CHECK_GOTO(tjsonAddStringToObject(item, "updateTime", i642str(pObj->updateTime)), pObj, &lino, _OVER);
2!
409
    RETRIEVE_CHECK_GOTO(tjsonAddStringToObject(item, "version", i642str(pObj->version)), pObj, &lino, _OVER);
2!
410
    RETRIEVE_CHECK_GOTO(tjsonAddStringToObject(item, "totalLevel", i642str(pObj->totalLevel)), pObj, &lino, _OVER);
2!
411
    RETRIEVE_CHECK_GOTO(tjsonAddStringToObject(item, "smaId", i642str(pObj->smaId)), pObj, &lino, _OVER);
2!
412
    RETRIEVE_CHECK_GOTO(tjsonAddStringToObject(item, "uid", i642str(pObj->uid)), pObj, &lino, _OVER);
2!
413
    RETRIEVE_CHECK_GOTO(tjsonAddStringToObject(item, "status", i642str(pObj->status)), pObj, &lino, _OVER);
2!
414
    RETRIEVE_CHECK_GOTO(tjsonAddStringToObject(item, "igExpired", i642str(pObj->conf.igExpired)), pObj, &lino, _OVER);
2!
415
    RETRIEVE_CHECK_GOTO(tjsonAddStringToObject(item, "trigger", i642str(pObj->conf.trigger)), pObj, &lino, _OVER);
2!
416
    RETRIEVE_CHECK_GOTO(tjsonAddStringToObject(item, "triggerParam", i642str(pObj->conf.triggerParam)), pObj, &lino,
2!
417
                        _OVER);
418
    RETRIEVE_CHECK_GOTO(tjsonAddStringToObject(item, "watermark", i642str(pObj->conf.watermark)), pObj, &lino, _OVER);
2!
419
    RETRIEVE_CHECK_GOTO(tjsonAddStringToObject(item, "sourceDbUid", i642str(pObj->sourceDbUid)), pObj, &lino, _OVER);
2!
420
    RETRIEVE_CHECK_GOTO(tjsonAddStringToObject(item, "targetDbUid", i642str(pObj->targetDbUid)), pObj, &lino, _OVER);
2!
421
    RETRIEVE_CHECK_GOTO(tjsonAddStringToObject(item, "sourceDb", mndGetDbStr(pObj->sourceDb)), pObj, &lino, _OVER);
2!
422
    RETRIEVE_CHECK_GOTO(tjsonAddStringToObject(item, "targetDb", mndGetDbStr(pObj->targetDb)), pObj, &lino, _OVER);
2!
423
    RETRIEVE_CHECK_GOTO(tjsonAddStringToObject(item, "targetSTbName", mndGetStbStr(pObj->targetSTbName)), pObj, &lino,
2!
424
                        _OVER);
425
    RETRIEVE_CHECK_GOTO(tjsonAddStringToObject(item, "targetStbUid", i642str(pObj->targetStbUid)), pObj, &lino, _OVER);
2!
426
    RETRIEVE_CHECK_GOTO(tjsonAddStringToObject(item, "fixedSinkVgId", i642str(pObj->fixedSinkVgId)), pObj, &lino,
2!
427
                        _OVER);
428
    sdbRelease(pSdb, pObj);
2✔
429
  }
430
_OVER:
1✔
431
  if (code != 0) mError("failed to dump stream info at line:%d since %s", lino, tstrerror(code));
1!
432
}
1✔
433

434
void dumpAcct(SSdb *pSdb, SJson *json) {
1✔
435
  int32_t code = 0;
1✔
436
  int32_t lino = 0;
1✔
437
  void  *pIter = NULL;
1✔
438
  SJson *items = tjsonAddArrayToObject(json, "accts");
1✔
439

440
  while (1) {
1✔
441
    SAcctObj *pObj = NULL;
2✔
442
    pIter = sdbFetch(pSdb, SDB_ACCT, pIter, (void **)&pObj);
2✔
443
    if (pIter == NULL) break;
2✔
444

445
    SJson *item = tjsonCreateObject();
1✔
446
    RETRIEVE_CHECK_GOTO(tjsonAddItemToArray(items, item), pObj, &lino, _OVER);
1!
447
    RETRIEVE_CHECK_GOTO(tjsonAddStringToObject(item, "acct", pObj->acct), pObj, &lino, _OVER);
1!
448
    RETRIEVE_CHECK_GOTO(tjsonAddStringToObject(item, "createdTime", i642str(pObj->createdTime)), pObj, &lino, _OVER);
1!
449
    RETRIEVE_CHECK_GOTO(tjsonAddStringToObject(item, "updateTime", i642str(pObj->updateTime)), pObj, &lino, _OVER);
1!
450
    RETRIEVE_CHECK_GOTO(tjsonAddStringToObject(item, "acctId", i642str(pObj->acctId)), pObj, &lino, _OVER);
1!
451
    sdbRelease(pSdb, pObj);
1✔
452
  }
453
_OVER:
1✔
454
  if (code != 0) mError("failed to dump acct info at line:%d since %s", lino, tstrerror(code));
1!
455
}
1✔
456

457
void dumpAuth(SSdb *pSdb, SJson *json) {
1✔
458
  // todo
459
}
1✔
460

461
void dumpUser(SSdb *pSdb, SJson *json) {
1✔
462
  int32_t code = 0;
1✔
463
  int32_t lino = 0;
1✔
464
  void  *pIter = NULL;
1✔
465
  SJson *items = tjsonAddArrayToObject(json, "users");
1✔
466

467
  while (1) {
2✔
468
    SUserObj *pObj = NULL;
3✔
469
    pIter = sdbFetch(pSdb, SDB_USER, pIter, (void **)&pObj);
3✔
470
    if (pIter == NULL) break;
3✔
471

472
    SJson *item = tjsonCreateObject();
2✔
473
    RETRIEVE_CHECK_GOTO(tjsonAddItemToArray(items, item), pObj, &lino, _OVER);
2!
474
    RETRIEVE_CHECK_GOTO(tjsonAddStringToObject(item, "name", pObj->user), pObj, &lino, _OVER);
2!
475
    RETRIEVE_CHECK_GOTO(tjsonAddStringToObject(item, "acct", pObj->acct), pObj, &lino, _OVER);
2!
476
    RETRIEVE_CHECK_GOTO(tjsonAddStringToObject(item, "createdTime", i642str(pObj->createdTime)), pObj, &lino, _OVER);
2!
477
    RETRIEVE_CHECK_GOTO(tjsonAddStringToObject(item, "updateTime", i642str(pObj->updateTime)), pObj, &lino, _OVER);
2!
478
    RETRIEVE_CHECK_GOTO(tjsonAddStringToObject(item, "superUser", i642str(pObj->superUser)), pObj, &lino, _OVER);
2!
479
    RETRIEVE_CHECK_GOTO(tjsonAddStringToObject(item, "authVersion", i642str(pObj->authVersion)), pObj, &lino, _OVER);
2!
480
    RETRIEVE_CHECK_GOTO(tjsonAddStringToObject(item, "passVersion", i642str(pObj->passVersion)), pObj, &lino, _OVER);
2!
481
    RETRIEVE_CHECK_GOTO(tjsonAddStringToObject(item, "numOfReadDbs", i642str(taosHashGetSize(pObj->readDbs))), pObj,
2!
482
                        &lino, _OVER);
483
    RETRIEVE_CHECK_GOTO(tjsonAddStringToObject(item, "numOfWriteDbs", i642str(taosHashGetSize(pObj->writeDbs))), pObj,
2!
484
                        &lino, _OVER);
485
    sdbRelease(pSdb, pObj);
2✔
486
  }
487
_OVER:
1✔
488
  if (code != 0) mError("failed to dump user info at line:%d since %s", lino, tstrerror(code));
1!
489
}
1✔
490

491
void dumpDnode(SSdb *pSdb, SJson *json) {
1✔
492
  int32_t code = 0;
1✔
493
  int32_t lino = 0;
1✔
494
  void  *pIter = NULL;
1✔
495
  SJson *items = tjsonAddArrayToObject(json, "dnodes");
1✔
496

497
  while (1) {
5✔
498
    SDnodeObj *pObj = NULL;
6✔
499
    pIter = sdbFetch(pSdb, SDB_DNODE, pIter, (void **)&pObj);
6✔
500
    if (pIter == NULL) break;
6✔
501

502
    SJson *item = tjsonCreateObject();
5✔
503
    RETRIEVE_CHECK_GOTO(tjsonAddItemToArray(items, item), pObj, &lino, _OVER);
5!
504
    RETRIEVE_CHECK_GOTO(tjsonAddStringToObject(item, "id", i642str(pObj->id)), pObj, &lino, _OVER);
5!
505
    RETRIEVE_CHECK_GOTO(tjsonAddStringToObject(item, "createdTime", i642str(pObj->createdTime)), pObj, &lino, _OVER);
5!
506
    RETRIEVE_CHECK_GOTO(tjsonAddStringToObject(item, "updateTime", i642str(pObj->updateTime)), pObj, &lino, _OVER);
5!
507
    RETRIEVE_CHECK_GOTO(tjsonAddStringToObject(item, "port", i642str(pObj->port)), pObj, &lino, _OVER);
5!
508
    RETRIEVE_CHECK_GOTO(tjsonAddStringToObject(item, "fqdn", pObj->fqdn), pObj, &lino, _OVER);
5!
509
    sdbRelease(pSdb, pObj);
5✔
510
  }
511
_OVER:
1✔
512
  if (code != 0) mError("failed to dump dnode info at line:%d since %s", lino, tstrerror(code));
1!
513
}
1✔
514

515
void dumpSnode(SSdb *pSdb, SJson *json) {
1✔
516
  int32_t code = 0;
1✔
517
  int32_t lino = 0;
1✔
518
  void  *pIter = NULL;
1✔
519
  SJson *items = tjsonAddArrayToObject(json, "snodes");
1✔
520

521
  while (1) {
1✔
522
    SSnodeObj *pObj = NULL;
2✔
523
    pIter = sdbFetch(pSdb, SDB_QNODE, pIter, (void **)&pObj);
2✔
524
    if (pIter == NULL) break;
2✔
525

526
    SJson *item = tjsonCreateObject();
1✔
527
    RETRIEVE_CHECK_GOTO(tjsonAddItemToArray(items, item), pObj, &lino, _OVER);
1!
528
    RETRIEVE_CHECK_GOTO(tjsonAddStringToObject(item, "id", i642str(pObj->id)), pObj, &lino, _OVER);
1!
529
    RETRIEVE_CHECK_GOTO(tjsonAddStringToObject(item, "createdTime", i642str(pObj->createdTime)), pObj, &lino, _OVER);
1!
530
    RETRIEVE_CHECK_GOTO(tjsonAddStringToObject(item, "updateTime", i642str(pObj->updateTime)), pObj, &lino, _OVER);
1!
531
    sdbRelease(pSdb, pObj);
1✔
532
  }
533
_OVER:
1✔
534
  if (code != 0) mError("failed to dump snode info at line:%d since %s", lino, tstrerror(code));
1!
535
}
1✔
536

537
void dumpQnode(SSdb *pSdb, SJson *json) {
1✔
538
  int32_t code = 0;
1✔
539
  int32_t lino = 0;
1✔
540
  void  *pIter = NULL;
1✔
541
  SJson *items = tjsonAddArrayToObject(json, "qnodes");
1✔
542

543
  while (1) {
1✔
544
    SQnodeObj *pObj = NULL;
2✔
545
    pIter = sdbFetch(pSdb, SDB_QNODE, pIter, (void **)&pObj);
2✔
546
    if (pIter == NULL) break;
2✔
547

548
    SJson *item = tjsonCreateObject();
1✔
549
    RETRIEVE_CHECK_GOTO(tjsonAddItemToArray(items, item), pObj, &lino, _OVER);
1!
550
    RETRIEVE_CHECK_GOTO(tjsonAddStringToObject(item, "id", i642str(pObj->id)), pObj, &lino, _OVER);
1!
551
    RETRIEVE_CHECK_GOTO(tjsonAddStringToObject(item, "createdTime", i642str(pObj->createdTime)), pObj, &lino, _OVER);
1!
552
    RETRIEVE_CHECK_GOTO(tjsonAddStringToObject(item, "updateTime", i642str(pObj->updateTime)), pObj, &lino, _OVER);
1!
553
    sdbRelease(pSdb, pObj);
1✔
554
  }
555
_OVER:
1✔
556
  if (code != 0) mError("failed to dump qnode info at line:%d since %s", lino, tstrerror(code));
1!
557
}
1✔
558

559
void dumpMnode(SSdb *pSdb, SJson *json) {
1✔
560
  int32_t code = 0;
1✔
561
  int32_t lino = 0;
1✔
562
  void  *pIter = NULL;
1✔
563
  SJson *items = tjsonAddArrayToObject(json, "mnodes");
1✔
564

565
  while (1) {
3✔
566
    SMnodeObj *pObj = NULL;
4✔
567
    pIter = sdbFetch(pSdb, SDB_MNODE, pIter, (void **)&pObj);
4✔
568
    if (pIter == NULL) break;
4✔
569

570
    SJson *item = tjsonCreateObject();
3✔
571
    RETRIEVE_CHECK_GOTO(tjsonAddItemToArray(items, item), pObj, &lino, _OVER);
3!
572
    RETRIEVE_CHECK_GOTO(tjsonAddStringToObject(item, "id", i642str(pObj->id)), pObj, &lino, _OVER);
3!
573
    RETRIEVE_CHECK_GOTO(tjsonAddStringToObject(item, "createdTime", i642str(pObj->createdTime)), pObj, &lino, _OVER);
3!
574
    RETRIEVE_CHECK_GOTO(tjsonAddStringToObject(item, "updateTime", i642str(pObj->updateTime)), pObj, &lino, _OVER);
3!
575
    sdbRelease(pSdb, pObj);
3✔
576
  }
577
_OVER:
1✔
578
  if (code != 0) mError("failed to dump mnode info at line:%d since %s", lino, tstrerror(code));
1!
579
}
1✔
580

581
void dumpCluster(SSdb *pSdb, SJson *json) {
1✔
582
  int32_t code = 0;
1✔
583
  int32_t lino = 0;
1✔
584

585
  void  *pIter = NULL;
1✔
586
  SJson *items = tjsonAddArrayToObject(json, "clusters");
1✔
587

588
  while (1) {
1✔
589
    SClusterObj *pObj = NULL;
2✔
590
    pIter = sdbFetch(pSdb, SDB_CLUSTER, pIter, (void **)&pObj);
2✔
591
    if (pIter == NULL) break;
2✔
592

593
    SJson *item = tjsonCreateObject();
1✔
594
    RETRIEVE_CHECK_GOTO(tjsonAddItemToArray(items, item), pObj, &lino, _OVER);
1!
595
    RETRIEVE_CHECK_GOTO(tjsonAddStringToObject(item, "id", i642str(pObj->id)), pObj, &lino, _OVER);
1!
596
    RETRIEVE_CHECK_GOTO(tjsonAddStringToObject(item, "createdTime", i642str(pObj->createdTime)), pObj, &lino, _OVER);
1!
597
    RETRIEVE_CHECK_GOTO(tjsonAddStringToObject(item, "updateTime", i642str(pObj->updateTime)), pObj, &lino, _OVER);
1!
598
    RETRIEVE_CHECK_GOTO(tjsonAddStringToObject(item, "name", pObj->name), pObj, &lino, _OVER);
1!
599
    sdbRelease(pSdb, pObj);
1✔
600
  }
601

602
_OVER:
1✔
603
  if (code != 0) mError("failed to dump cluster info at line:%d since %s", lino, tstrerror(code));
1!
604
}
1✔
605

606
void dumpTrans(SSdb *pSdb, SJson *json) {
1✔
607
  int32_t code = 0;
1✔
608
  int32_t lino = 0;
1✔
609
  void  *pIter = NULL;
1✔
610
  SJson *items = tjsonAddArrayToObject(json, "transactions");
1✔
611

UNCOV
612
  while (1) {
×
613
    STrans *pObj = NULL;
1✔
614
    pIter = sdbFetch(pSdb, SDB_TRANS, pIter, (void **)&pObj);
1✔
615
    if (pIter == NULL) break;
1!
616

UNCOV
617
    SJson *item = tjsonCreateObject();
×
UNCOV
618
    RETRIEVE_CHECK_GOTO(tjsonAddItemToArray(items, item), pObj, &lino, _OVER);
×
UNCOV
619
    RETRIEVE_CHECK_GOTO(tjsonAddStringToObject(item, "id", i642str(pObj->id)), pObj, &lino, _OVER);
×
UNCOV
620
    RETRIEVE_CHECK_GOTO(tjsonAddStringToObject(item, "stage", i642str(pObj->stage)), pObj, &lino, _OVER);
×
UNCOV
621
    RETRIEVE_CHECK_GOTO(tjsonAddStringToObject(item, "policy", i642str(pObj->policy)), pObj, &lino, _OVER);
×
UNCOV
622
    RETRIEVE_CHECK_GOTO(tjsonAddStringToObject(item, "conflict", i642str(pObj->conflict)), pObj, &lino, _OVER);
×
UNCOV
623
    RETRIEVE_CHECK_GOTO(tjsonAddStringToObject(item, "exec", i642str(pObj->exec)), pObj, &lino, _OVER);
×
UNCOV
624
    RETRIEVE_CHECK_GOTO(tjsonAddStringToObject(item, "oper", i642str(pObj->oper)), pObj, &lino, _OVER);
×
UNCOV
625
    RETRIEVE_CHECK_GOTO(tjsonAddStringToObject(item, "createdTime", i642str(pObj->createdTime)), pObj, &lino, _OVER);
×
UNCOV
626
    RETRIEVE_CHECK_GOTO(tjsonAddStringToObject(item, "dbname", pObj->dbname), pObj, &lino, _OVER);
×
UNCOV
627
    RETRIEVE_CHECK_GOTO(tjsonAddStringToObject(item, "stbname", pObj->stbname), pObj, &lino, _OVER);
×
UNCOV
628
    RETRIEVE_CHECK_GOTO(tjsonAddStringToObject(item, "opername", pObj->opername), pObj, &lino, _OVER);
×
UNCOV
629
    RETRIEVE_CHECK_GOTO(tjsonAddStringToObject(item, "commitLogNum", i642str(taosArrayGetSize(pObj->commitActions))),
×
630
                        pObj, &lino, _OVER);
UNCOV
631
    RETRIEVE_CHECK_GOTO(tjsonAddStringToObject(item, "redoActionNum", i642str(taosArrayGetSize(pObj->redoActions))),
×
632
                        pObj, &lino, _OVER);
UNCOV
633
    RETRIEVE_CHECK_GOTO(tjsonAddStringToObject(item, "undoActionNum", i642str(taosArrayGetSize(pObj->undoActions))),
×
634
                        pObj, &lino, _OVER);
UNCOV
635
    sdbRelease(pSdb, pObj);
×
636
  }
637

638
_OVER:
1✔
639
  if (code != 0) mError("failed to dump trans info at line:%d since %s", lino, tstrerror(code));
1!
640
}
1✔
641

642
void dumpHeader(SSdb *pSdb, SJson *json) {
1✔
643
  int32_t code = 0;
1✔
644
  int32_t lino = 0;
1✔
645
  TAOS_CHECK_GOTO(tjsonAddStringToObject(json, "sver", i642str(1)), &lino, _OVER);
1!
646
  TAOS_CHECK_GOTO(tjsonAddStringToObject(json, "applyIndex", i642str(pSdb->applyIndex)), &lino, _OVER);
1!
647
  TAOS_CHECK_GOTO(tjsonAddStringToObject(json, "applyTerm", i642str(pSdb->applyTerm)), &lino, _OVER);
1!
648
  TAOS_CHECK_GOTO(tjsonAddStringToObject(json, "applyConfig", i642str(pSdb->applyConfig)), &lino, _OVER);
1!
649

650
  SJson *maxIdsJson = tjsonCreateObject();
1✔
651
  TAOS_CHECK_GOTO(tjsonAddItemToObject(json, "maxIds", maxIdsJson), &lino, _OVER);
1!
652
  for (int32_t i = 0; i < SDB_MAX; ++i) {
30✔
653
    if(i == 5) continue;
29✔
654
    int64_t maxId = 0;
28✔
655
    if (i < SDB_MAX) {
28!
656
      maxId = pSdb->maxId[i];
28✔
657
    }
658
    TAOS_CHECK_GOTO(tjsonAddStringToObject(maxIdsJson, sdbTableName(i), i642str(maxId)), &lino, _OVER);
28!
659
  }
660

661
  SJson *tableVersJson = tjsonCreateObject();
1✔
662
  TAOS_CHECK_GOTO(tjsonAddItemToObject(json, "tableVers", tableVersJson), &lino, _OVER);
1!
663
  for (int32_t i = 0; i < SDB_MAX; ++i) {
30✔
664
    int64_t tableVer = 0;
29✔
665
    if (i < SDB_MAX) {
29!
666
      tableVer = pSdb->tableVer[i];
29✔
667
    }
668
    TAOS_CHECK_GOTO(tjsonAddStringToObject(tableVersJson, sdbTableName(i), i642str(tableVer)), &lino, _OVER);
29!
669
  }
670

671
_OVER:
1✔
672
  if (code != 0) mError("failed to dump sdb info at line:%d since %s", lino, tstrerror(code));
1!
673
}
1✔
674

675
int32_t mndDumpSdb() {
1✔
676
  mInfo("start to dump sdb info to sdb.json");
1!
677

678
  char path[PATH_MAX * 2] = {0};
1✔
679
  (void)snprintf(path, sizeof(path), "%s%smnode", tsDataDir, TD_DIRSEP);
1✔
680

681
  SMsgCb msgCb = {0};
1✔
682
  msgCb.reportStartupFp = reportStartup;
1✔
683
  msgCb.sendReqFp = sendReq;
1✔
684
  msgCb.sendSyncReqFp = sendSyncReq;
1✔
685
  msgCb.sendRspFp = sendRsp;
1✔
686
  msgCb.mgmt = (SMgmtWrapper *)(&msgCb);  // hack
1✔
687
  tmsgSetDefault(&msgCb);
1✔
688

689
  TAOS_CHECK_RETURN(walInit(NULL));
1!
690
  TAOS_CHECK_RETURN(syncInit());
1!
691

692
  SMnodeOpt opt = {.msgCb = msgCb};
1✔
693
  SMnode   *pMnode = mndOpen(path, &opt);
1✔
694
  if (pMnode == NULL) return -1;
1!
695

696
  SSdb  *pSdb = pMnode->pSdb;
1✔
697
  SJson *json = tjsonCreateObject();
1✔
698
  dumpHeader(pSdb, json);
1✔
699
  dumpFunc(pSdb, json);
1✔
700
  dumpDb(pSdb, json);
1✔
701
  dumpStb(pSdb, json);
1✔
702
  dumpSma(pSdb, json);
1✔
703
  dumpVgroup(pSdb, json);
1✔
704
  dumpTopic(pSdb, json);
1✔
705
  dumpConsumer(pSdb, json);
1✔
706
  dumpSubscribe(pSdb, json);
1✔
707
  //  dumpOffset(pSdb, json);
708
  dumpStream(pSdb, json);
1✔
709
  dumpAcct(pSdb, json);
1✔
710
  dumpAuth(pSdb, json);
1✔
711
  dumpUser(pSdb, json);
1✔
712
  dumpDnode(pSdb, json);
1✔
713
  dumpSnode(pSdb, json);
1✔
714
  dumpQnode(pSdb, json);
1✔
715
  dumpMnode(pSdb, json);
1✔
716
  dumpCluster(pSdb, json);
1✔
717
  dumpTrans(pSdb, json);
1✔
718

719
  char     *pCont = tjsonToString(json);
1✔
720
  int32_t   contLen = strlen(pCont);
1✔
721
  char      file[] = "sdb.json";
1✔
722
  TdFilePtr pFile = taosOpenFile(file, TD_FILE_CREATE | TD_FILE_WRITE | TD_FILE_TRUNC | TD_FILE_WRITE_THROUGH);
1✔
723
  if (pFile == NULL) {
1!
724
    mError("failed to write %s since %s", file, terrstr());
×
725
    return terrno;
×
726
  }
727
  TAOS_CHECK_RETURN(taosWriteFile(pFile, pCont, contLen));
1!
728
  TAOS_CHECK_RETURN(taosWriteFile(pFile, "\n", 1));
×
729
  TAOS_CHECK_RETURN(taosFsyncFile(pFile));
×
730
  TAOS_CHECK_RETURN(taosCloseFile(&pFile));
×
731
  tjsonDelete(json);
×
732
  taosMemoryFree(pCont);
×
733

734
  mInfo("dump sdb info success");
×
735
  return 0;
×
736
}
737

738
int32_t mndDeleteTrans() {
×
739
  mInfo("start to dump sdb info to sdb.json");
×
740

741
  char path[PATH_MAX * 2] = {0};
×
742
  (void)snprintf(path, sizeof(path), "%s%smnode", tsDataDir, TD_DIRSEP);
×
743

744
  SMsgCb msgCb = {0};
×
745
  msgCb.reportStartupFp = reportStartup;
×
746
  msgCb.sendReqFp = sendReq;
×
747
  msgCb.sendSyncReqFp = sendSyncReq;
×
748
  msgCb.sendRspFp = sendRsp;
×
749
  msgCb.mgmt = (SMgmtWrapper *)(&msgCb);  // hack
×
750
  tmsgSetDefault(&msgCb);
×
751

752
  TAOS_CHECK_RETURN(walInit(NULL));
×
753
  TAOS_CHECK_RETURN(syncInit());
×
754

755
  SMnodeOpt opt = {.msgCb = msgCb};
×
756
  SMnode   *pMnode = mndOpen(path, &opt);
×
757
  if (pMnode == NULL) return terrno;
×
758

759
  TAOS_CHECK_RETURN(sdbWriteFileForDump(pMnode->pSdb));
×
760

761
  mInfo("dump sdb info success");
×
762

763
  return 0;
×
764
}
765

766
#pragma GCC diagnostic pop
STATUS · Troubleshooting · Open an Issue · Sales · Support · CAREERS · ENTERPRISE · START FREE · SCHEDULE DEMO
ANNOUNCEMENTS · TWITTER · TOS & SLA · Supported CI Services · What's a CI service? · Automated Testing

© 2025 Coveralls, Inc