server.cpp 2.1 KB
Newer Older
S
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
Shengliang Guan 已提交
16
#include "sut.h"
S
Shengliang Guan 已提交
17 18

void* serverLoop(void* param) {
S
shm  
Shengliang Guan 已提交
19
  SDnode* pDnode = (SDnode*)param;
S
Shengliang Guan 已提交
20
  dmRun(pDnode);
S
shm  
Shengliang Guan 已提交
21
  return NULL;
S
Shengliang Guan 已提交
22 23
}

S
shm  
Shengliang Guan 已提交
24 25 26 27 28 29 30 31 32
SDnodeOpt TestServer::BuildOption(const char* path, const char* fqdn, uint16_t port, const char* firstEp) {
  SDnodeOpt option = {0};
  option.numOfSupportVnodes = 16;
  option.serverPort = port;
  strcpy(option.dataDir, path);
  snprintf(option.localEp, TSDB_EP_LEN, "%s:%u", fqdn, port);
  snprintf(option.localFqdn, TSDB_FQDN_LEN, "%s", fqdn);
  snprintf(option.firstEp, TSDB_EP_LEN, "%s", firstEp);
  return option;
S
Shengliang Guan 已提交
33 34
}

S
Shengliang Guan 已提交
35
bool TestServer::DoStart() {
S
shm  
Shengliang Guan 已提交
36
  SDnodeOpt option = BuildOption(path, fqdn, port, firstEp);
S
Shengliang Guan 已提交
37 38
  taosMkDir(path);

S
Shengliang Guan 已提交
39
  pDnode = dmCreate(&option);
S
shm  
Shengliang Guan 已提交
40
  if (pDnode == NULL) {
S
Shengliang Guan 已提交
41 42 43
    return false;
  }

S
Shengliang Guan 已提交
44 45 46 47 48
  TdThreadAttr thAttr;
  taosThreadAttrInit(&thAttr);
  taosThreadAttrSetDetachState(&thAttr, PTHREAD_CREATE_JOINABLE);
  taosThreadCreate(&threadId, &thAttr, serverLoop, pDnode);
  taosThreadAttrDestroy(&thAttr);
S
shm  
Shengliang Guan 已提交
49
  taosMsleep(2100);
S
Shengliang Guan 已提交
50 51 52
  return true;
}

S
Shengliang Guan 已提交
53 54 55 56 57 58 59 60 61 62 63 64 65 66 67 68 69
void TestServer::Restart() {
  uInfo("start all server");
  Stop();
  DoStart();
  uInfo("all server is running");
}

bool TestServer::Start(const char* path, const char* fqdn, uint16_t port, const char* firstEp) {
  strcpy(this->path, path);
  strcpy(this->fqdn, fqdn);
  this->port = port;
  strcpy(this->firstEp, firstEp);

  taosRemoveDir(path);
  return DoStart();
}

S
Shengliang Guan 已提交
70
void TestServer::Stop() {
S
Shengliang Guan 已提交
71
  dmSetEvent(pDnode, DND_EVENT_STOP);
S
Shengliang Guan 已提交
72
  taosThreadJoin(threadId, NULL);
S
Shengliang Guan 已提交
73 74

  if (pDnode != NULL) {
S
Shengliang Guan 已提交
75
    dmClose(pDnode);
S
Shengliang Guan 已提交
76 77 78
    pDnode = NULL;
  }
}