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

S
shm  
Shengliang Guan 已提交
16
#define _DEFAULT_SOURCE
S
Shengliang Guan 已提交
17
#include "dmImp.h"
S
Shengliang Guan 已提交
18

S
Shengliang Guan 已提交
19
static int32_t dmInitVars(SDnode *pDnode, const SDnodeOpt *pOption) {
S
Shengliang Guan 已提交
20 21 22
  pDnode->data.dnodeId = 0;
  pDnode->data.dropped = 0;
  pDnode->data.clusterId = 0;
S
Shengliang Guan 已提交
23 24 25 26 27 28 29 30 31
  pDnode->data.supportVnodes = pOption->numOfSupportVnodes;
  pDnode->data.serverPort = pOption->serverPort;
  pDnode->data.dataDir = strdup(pOption->dataDir);
  pDnode->data.localEp = strdup(pOption->localEp);
  pDnode->data.localFqdn = strdup(pOption->localFqdn);
  pDnode->data.firstEp = strdup(pOption->firstEp);
  pDnode->data.secondEp = strdup(pOption->secondEp);
  pDnode->data.disks = pOption->disks;
  pDnode->data.numOfDisks = pOption->numOfDisks;
S
Shengliang Guan 已提交
32
  pDnode->ntype = pOption->ntype;
S
Shengliang Guan 已提交
33
  pDnode->data.rebootTime = taosGetTimestampMs();
S
shm  
Shengliang Guan 已提交
34

S
Shengliang Guan 已提交
35 36
  if (pDnode->data.dataDir == NULL || pDnode->data.localEp == NULL || pDnode->data.localFqdn == NULL ||
      pDnode->data.firstEp == NULL || pDnode->data.secondEp == NULL) {
S
shm  
Shengliang Guan 已提交
37 38 39
    terrno = TSDB_CODE_OUT_OF_MEMORY;
    return -1;
  }
S
shm  
Shengliang Guan 已提交
40

S
Shengliang Guan 已提交
41
  if (!tsMultiProcess || pDnode->ntype == NODE_BEGIN || pDnode->ntype == NODE_END) {
S
Shengliang Guan 已提交
42
    pDnode->data.lockfile = dmCheckRunning(pDnode->data.dataDir);
S
Shengliang Guan 已提交
43
    if (pDnode->data.lockfile == NULL) {
S
shm  
Shengliang Guan 已提交
44 45
      return -1;
    }
S
shm  
Shengliang Guan 已提交
46 47
  }

S
Shengliang Guan 已提交
48
  taosInitRWLatch(&pDnode->data.latch);
S
Shengliang Guan 已提交
49
  taosInitRWLatch(&pDnode->wrapperLock);
S
shm  
Shengliang Guan 已提交
50 51 52
  return 0;
}

S
Shengliang Guan 已提交
53
static void dmClearVars(SDnode *pDnode) {
S
Shengliang Guan 已提交
54
  for (EDndNodeType n = 0; n < NODE_END; ++n) {
S
shm  
Shengliang Guan 已提交
55
    SMgmtWrapper *pMgmt = &pDnode->wrappers[n];
wafwerar's avatar
wafwerar 已提交
56
    taosMemoryFreeClear(pMgmt->path);
S
shm  
Shengliang Guan 已提交
57
  }
S
Shengliang Guan 已提交
58 59 60 61
  if (pDnode->data.lockfile != NULL) {
    taosUnLockFile(pDnode->data.lockfile);
    taosCloseFile(&pDnode->data.lockfile);
    pDnode->data.lockfile = NULL;
S
shm  
Shengliang Guan 已提交
62
  }
S
Shengliang Guan 已提交
63 64 65 66 67
  taosMemoryFreeClear(pDnode->data.localEp);
  taosMemoryFreeClear(pDnode->data.localFqdn);
  taosMemoryFreeClear(pDnode->data.firstEp);
  taosMemoryFreeClear(pDnode->data.secondEp);
  taosMemoryFreeClear(pDnode->data.dataDir);
wafwerar's avatar
wafwerar 已提交
68
  taosMemoryFree(pDnode);
S
shm  
Shengliang Guan 已提交
69
  dDebug("dnode memory is cleared, data:%p", pDnode);
S
shm  
Shengliang Guan 已提交
70 71
}

S
Shengliang Guan 已提交
72
SDnode *dmCreate(const SDnodeOpt *pOption) {
S
shm  
Shengliang Guan 已提交
73
  dDebug("start to create dnode object");
S
shm  
Shengliang Guan 已提交
74
  int32_t code = -1;
S
xshm  
Shengliang Guan 已提交
75
  char    path[PATH_MAX] = {0};
S
shm  
Shengliang Guan 已提交
76 77
  SDnode *pDnode = NULL;

wafwerar's avatar
wafwerar 已提交
78
  pDnode = taosMemoryCalloc(1, sizeof(SDnode));
S
shm  
Shengliang Guan 已提交
79 80 81 82 83
  if (pDnode == NULL) {
    terrno = TSDB_CODE_OUT_OF_MEMORY;
    goto _OVER;
  }

S
Shengliang Guan 已提交
84
  if (dmInitVars(pDnode, pOption) != 0) {
S
shm  
Shengliang Guan 已提交
85
    dError("failed to init variables since %s", terrstr());
S
shm  
Shengliang Guan 已提交
86 87 88
    goto _OVER;
  }

S
Shengliang Guan 已提交
89
  dmSetStatus(pDnode, DND_STAT_INIT);
S
Shengliang Guan 已提交
90
  dmSetMgmtFp(&pDnode->wrappers[NODE_BEGIN]);
S
Shengliang Guan 已提交
91
  mmSetMgmtFp(&pDnode->wrappers[MNODE]);
S
Shengliang Guan 已提交
92
  vmSetMgmtFp(&pDnode->wrappers[VNODE]);
S
Shengliang Guan 已提交
93 94 95
  qmSetMgmtFp(&pDnode->wrappers[QNODE]);
  smSetMgmtFp(&pDnode->wrappers[SNODE]);
  bmSetMgmtFp(&pDnode->wrappers[BNODE]);
S
shm  
Shengliang Guan 已提交
96

S
Shengliang Guan 已提交
97
  for (EDndNodeType n = 0; n < NODE_END; ++n) {
S
shm  
Shengliang Guan 已提交
98
    SMgmtWrapper *pWrapper = &pDnode->wrappers[n];
S
Shengliang Guan 已提交
99
    snprintf(path, sizeof(path), "%s%s%s", pDnode->data.dataDir, TD_DIRSEP, pWrapper->name);
S
shm  
Shengliang Guan 已提交
100
    pWrapper->path = strdup(path);
S
Shengliang Guan 已提交
101
    pWrapper->procShm.id = -1;
S
shm  
Shengliang Guan 已提交
102
    pWrapper->pDnode = pDnode;
S
Shengliang Guan 已提交
103
    pWrapper->ntype = n;
S
shm  
Shengliang Guan 已提交
104 105 106 107 108
    if (pWrapper->path == NULL) {
      terrno = TSDB_CODE_OUT_OF_MEMORY;
      goto _OVER;
    }

S
Shengliang Guan 已提交
109
    pWrapper->procType = DND_PROC_SINGLE;
S
shm  
Shengliang Guan 已提交
110
    taosInitRWLatch(&pWrapper->latch);
S
shm  
Shengliang Guan 已提交
111 112
  }

S
Shengliang Guan 已提交
113
  if (dmInitMsgHandle(pDnode) != 0) {
S
Shengliang Guan 已提交
114
    dError("failed to init msg handles since %s", terrstr());
S
shm  
Shengliang Guan 已提交
115 116 117
    goto _OVER;
  }

S
Shengliang Guan 已提交
118
  if (dmReadShmFile(pDnode) != 0) {
S
shm  
Shengliang Guan 已提交
119
    dError("failed to read shm file since %s", terrstr());
S
shm  
Shengliang Guan 已提交
120 121 122
    goto _OVER;
  }

S
Shengliang Guan 已提交
123
  SMsgCb msgCb = dmGetMsgcb(&pDnode->wrappers[0]);
S
shm  
Shengliang Guan 已提交
124 125
  tmsgSetDefaultMsgCb(&msgCb);

S
shm  
Shengliang Guan 已提交
126
  dInfo("dnode is created, data:%p", pDnode);
S
shm  
Shengliang Guan 已提交
127 128 129 130
  code = 0;

_OVER:
  if (code != 0 && pDnode) {
S
Shengliang Guan 已提交
131
    dmClearVars(pDnode);
132
    pDnode = NULL;
S
shm  
Shengliang Guan 已提交
133
    dError("failed to create dnode since %s", terrstr());
S
shm  
Shengliang Guan 已提交
134 135 136 137 138
  }

  return pDnode;
}

S
Shengliang Guan 已提交
139
void dmClose(SDnode *pDnode) {
S
shm  
Shengliang Guan 已提交
140 141
  if (pDnode == NULL) return;

S
Shengliang Guan 已提交
142
  for (EDndNodeType n = 0; n < NODE_END; ++n) {
S
shm  
Shengliang Guan 已提交
143
    SMgmtWrapper *pWrapper = &pDnode->wrappers[n];
S
Shengliang Guan 已提交
144
    dmCloseNode(pWrapper);
S
shm  
Shengliang Guan 已提交
145 146
  }

S
Shengliang Guan 已提交
147
  dmClearVars(pDnode);
S
shm  
Shengliang Guan 已提交
148
  dInfo("dnode is closed, data:%p", pDnode);
S
shm  
Shengliang Guan 已提交
149
}