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

taosdata / TDengine / #3653

14 Mar 2025 08:10AM UTC coverage: 22.565% (-41.0%) from 63.596%
#3653

push

travis-ci

web-flow
feat(keep): support keep on super table level. (#30097)

* Feat: support use keep while create super table.

* Test(keep): add test for create super table with keep option.

* Feat(keep): Add tmsg for create keep.

* Feat(keep): support alter table option keep.

* Fix(keep): Add baisc test for alter table option.

* Fix(keep): memory leek.

* Feat(keep): add keep to metaEntry&metaCache and fix earliestTs with stn keep.

* Test(keep): add some cases for select with stb keep.

* Fix: fix ci core while alter stb.

* Feat(keep): delete expired data in super table level.

* Feat: remove get stb keep while query.

* Fix : build error.

* Revert "Fix : build error."

This reverts commit 0ed66e4e8.

* Revert "Feat(keep): delete expired data in super table level."

This reverts commit 36330f6b4.

* Fix : build errors.

* Feat : support restart taosd.

* Fix : alter table comment problems.

* Test : add tests for super table keep.

* Fix: change sdb stb reserve size.

* Test: add more tests.

* Feat: Disable normal tables and sub tables from setting the keep parameter

* Fix: add more checks to avoid unknown address.

* Docs: Add docs for stable keep.

* Fix: some review changes.

* Fix: review errors.

49248 of 302527 branches covered (16.28%)

Branch coverage included in aggregate %.

53 of 99 new or added lines in 12 files covered. (53.54%)

155872 existing lines in 443 files now uncovered.

87359 of 302857 relevant lines covered (28.84%)

570004.22 hits per line

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

69.11
/source/dnode/mgmt/node_mgmt/src/dmNodes.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 "dmMgmt.h"
18
#include "dmUtil.h"
19
#include "monitor.h"
20
#include "audit.h"
21

22
int32_t dmOpenNode(SMgmtWrapper *pWrapper) {
26✔
23
  int32_t code = 0;
26✔
24
  SDnode *pDnode = pWrapper->pDnode;
26✔
25

26
  if (taosMkDir(pWrapper->path) != 0) {
26!
27
    code = terrno;
×
28
    dError("node:%s, failed to create dir:%s since %s", pWrapper->name, pWrapper->path, tstrerror(code));
×
29
    return code;
×
30
  }
31

32
  SMgmtOutputOpt output = {0};
26✔
33
  SMgmtInputOpt  input = dmBuildMgmtInputOpt(pWrapper);
26✔
34

35
  dInfo("node:%s, start to open", pWrapper->name);
26!
36
  tmsgSetDefault(&input.msgCb);
26✔
37
  if ((code = (*pWrapper->func.openFp)(&input, &output)) != 0) {
26!
38
    dError("node:%s, failed to open since %s", pWrapper->name, tstrerror(code));
×
39
    return code;
×
40
  }
41
  dInfo("node:%s, has been opened", pWrapper->name);
26!
42
  pWrapper->deployed = true;
26✔
43

44
  if (output.pMgmt != NULL) {
26!
45
    pWrapper->pMgmt = output.pMgmt;
26✔
46
  }
47

48
  dmReportStartup(pWrapper->name, "opened");
26✔
49
  return 0;
26✔
50
}
51

52
int32_t dmStartNode(SMgmtWrapper *pWrapper) {
26✔
53
  int32_t code = 0;
26✔
54
  if (pWrapper->func.startFp != NULL) {
26✔
55
    dDebug("node:%s, start to start", pWrapper->name);
24!
56
    if ((code = (*pWrapper->func.startFp)(pWrapper->pMgmt)) != 0) {
24!
57
      dError("node:%s, failed to start since %s", pWrapper->name, tstrerror(code));
×
58
      return code;
×
59
    }
60
    dDebug("node:%s, has been started", pWrapper->name);
24!
61
  }
62

63
  dmReportStartup(pWrapper->name, "started");
26✔
64
  return 0;
26✔
65
}
66

67
void dmStopNode(SMgmtWrapper *pWrapper) {
41✔
68
  if (pWrapper->func.stopFp != NULL && pWrapper->pMgmt != NULL) {
41!
69
    dDebug("node:%s, start to stop", pWrapper->name);
24!
70
    (*pWrapper->func.stopFp)(pWrapper->pMgmt);
24✔
71
    dDebug("node:%s, has been stopped", pWrapper->name);
24!
72
  }
73
}
41✔
74

75
void dmCloseNode(SMgmtWrapper *pWrapper) {
41✔
76
  dInfo("node:%s, start to close", pWrapper->name);
41!
77
  pWrapper->deployed = false;
41✔
78

79
  while (pWrapper->refCount > 0) {
41!
80
    taosMsleep(10);
×
81
  }
82

83
  (void)taosThreadRwlockWrlock(&pWrapper->lock);
41✔
84
  if (pWrapper->pMgmt != NULL) {
41✔
85
    (*pWrapper->func.closeFp)(pWrapper->pMgmt);
26✔
86
    pWrapper->pMgmt = NULL;
26✔
87
  }
88
  (void)taosThreadRwlockUnlock(&pWrapper->lock);
41✔
89

90
  dInfo("node:%s, has been closed", pWrapper->name);
41!
91
}
41✔
92

93
static int32_t dmOpenNodes(SDnode *pDnode) {
8✔
94
  int32_t code = 0;
8✔
95
  for (EDndNodeType ntype = DNODE; ntype < NODE_END; ++ntype) {
48✔
96
    SMgmtWrapper *pWrapper = &pDnode->wrappers[ntype];
40✔
97
    if (!pWrapper->required) continue;
40✔
98
    if ((code = dmOpenNode(pWrapper)) != 0) {
24!
99
      dError("node:%s, failed to open since %s", pWrapper->name, tstrerror(code));
×
100
      return code;
×
101
    }
102
  }
103

104
  auditSetDnodeId(dmGetDnodeId(&pDnode->data));
8✔
105
  monSetDnodeId(dmGetDnodeId(&pDnode->data));
8✔
106

107
  dmSetStatus(pDnode, DND_STAT_RUNNING);
8✔
108
  return 0;
8✔
109
}
110

111
static int32_t dmStartNodes(SDnode *pDnode) {
8✔
112
  int32_t code = 0;
8✔
113
  for (EDndNodeType ntype = DNODE; ntype < NODE_END; ++ntype) {
48✔
114
    SMgmtWrapper *pWrapper = &pDnode->wrappers[ntype];
40✔
115
    if (!pWrapper->required) continue;
40✔
116
    if ((code = dmStartNode(pWrapper)) != 0) {
24!
117
      dError("node:%s, failed to start since %s", pWrapper->name, tstrerror(code));
×
118
      return code;
×
119
    }
120
  }
121

122
  dInfo("The daemon initialized successfully");
8!
123
  dmReportStartup("The daemon", "initialized successfully");
8✔
124
  return 0;
8✔
125
}
126

127
static void dmStopNodes(SDnode *pDnode) {
8✔
128
  for (EDndNodeType n = DNODE; n < NODE_END; ++n) {
48✔
129
    SMgmtWrapper *pWrapper = &pDnode->wrappers[n];
40✔
130
    dmStopNode(pWrapper);
40✔
131
  }
132
}
8✔
133

134
static void dmCloseNodes(SDnode *pDnode) {
8✔
135
  for (EDndNodeType n = DNODE; n < NODE_END; ++n) {
48✔
136
    SMgmtWrapper *pWrapper = &pDnode->wrappers[n];
40✔
137
    dmCloseNode(pWrapper);
40✔
138
  }
139
}
8✔
140

141
int32_t dmRunDnode(SDnode *pDnode) {
8✔
142
  int32_t code = 0;
8✔
143
  int32_t count = 0;
8✔
144
  if ((code = dmOpenNodes(pDnode)) != 0) {
8!
145
    dError("failed to open nodes since %s", tstrerror(code));
×
146
    dmCloseNodes(pDnode);
×
147
    return code;
×
148
  }
149

150
  if ((code = dmStartNodes(pDnode)) != 0) {
8!
151
    dError("failed to start nodes since %s", tstrerror(code));
×
152
    dmSetStatus(pDnode, DND_STAT_STOPPED);
×
153
    dmStopNodes(pDnode);
×
154
    dmCloseNodes(pDnode);
×
155
    return code;
×
156
  }
157
  tsDndStart = taosGetTimestampMs();
8✔
158
  if (tsDndStart == 0) ++tsDndStart;  // avoid 0
8!
159
  tsDndStartOsUptime = taosGetOsUptime();
8✔
160

161
  while (1) {
162
    if (pDnode->stop) {
242✔
163
      dInfo("The daemon is about to stop");
8!
164
      dmSetStatus(pDnode, DND_STAT_STOPPED);
8✔
165
      dmStopNodes(pDnode);
8✔
166
      dmCloseNodes(pDnode);
8✔
167
      return 0;
8✔
168
    }
169

170
    if (count == 10) {
234✔
171
      if(osUpdate() != 0) {
19!
UNCOV
172
        dError("failed to update os info");
×
173
      }
174
      count = 0;
19✔
175
    } else {
176
      count++;
215✔
177
    }
178

179
    taosMsleep(100);
234✔
180
  }
181
}
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

© 2026 Coveralls, Inc