dnodeModule.c 4.6 KB
Newer Older
S
#1177  
slguan 已提交
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17
/*
 * 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/>.
 */

#define _DEFAULT_SOURCE
#include "os.h"
S
slguan 已提交
18
#include "taosdef.h"
S
slguan 已提交
19
#include "tglobal.h"
J
jtao1735 已提交
20
#include "trpc.h"
S
dnode  
slguan 已提交
21 22
#include "mnode.h"
#include "http.h"
23
#include "mqtt.h"
S
dnode  
slguan 已提交
24
#include "monitor.h"
25
#include "dnodeInt.h"
S
#1177  
slguan 已提交
26 27
#include "dnodeModule.h"

S
slguan 已提交
28 29 30 31 32 33 34 35 36
typedef struct {
  bool      enable;
  char *    name;
  int32_t (*initFp)();
  int32_t (*startFp)();
  void    (*cleanUpFp)();
  void    (*stopFp)();
} SModule;

S
Shuduo Sang 已提交
37
static SModule  tsModule[TSDB_MOD_MAX] = {{0}};
S
slguan 已提交
38
static uint32_t tsModuleStatus = 0;
S
#1177  
slguan 已提交
39

S
slguan 已提交
40 41 42 43 44 45 46
static void dnodeSetModuleStatus(int32_t module) {
  tsModuleStatus |= (1 << module);
}

static void dnodeUnSetModuleStatus(int32_t module) {
  tsModuleStatus &= ~(1 << module);
}
S
#1177  
slguan 已提交
47

S
slguan 已提交
48
static void dnodeAllocModules() {
49
  tsModule[TSDB_MOD_MGMT].enable       = false;
S
slguan 已提交
50 51 52 53 54
  tsModule[TSDB_MOD_MGMT].name         = "mgmt";
  tsModule[TSDB_MOD_MGMT].initFp       = mgmtInitSystem;
  tsModule[TSDB_MOD_MGMT].cleanUpFp    = mgmtCleanUpSystem;
  tsModule[TSDB_MOD_MGMT].startFp      = mgmtStartSystem;
  tsModule[TSDB_MOD_MGMT].stopFp       = mgmtStopSystem;
55

S
slguan 已提交
56 57 58 59 60 61 62 63 64
  tsModule[TSDB_MOD_HTTP].enable       = (tsEnableHttpModule == 1);
  tsModule[TSDB_MOD_HTTP].name         = "http";
  tsModule[TSDB_MOD_HTTP].initFp       = httpInitSystem;
  tsModule[TSDB_MOD_HTTP].cleanUpFp    = httpCleanUpSystem;
  tsModule[TSDB_MOD_HTTP].startFp      = httpStartSystem;
  tsModule[TSDB_MOD_HTTP].stopFp       = httpStopSystem;
  if (tsEnableHttpModule) {
    dnodeSetModuleStatus(TSDB_MOD_HTTP);
  }
65

66 67 68 69 70 71 72 73 74 75
  tsModule[TSDB_MOD_MQTT].enable = (tsEnableMqttModule == 1);
  tsModule[TSDB_MOD_MQTT].name = "mqtt";
  tsModule[TSDB_MOD_MQTT].initFp = mqttInitSystem;
  tsModule[TSDB_MOD_MQTT].cleanUpFp = mqttCleanUpSystem;
  tsModule[TSDB_MOD_MQTT].startFp = mqttStartSystem;
  tsModule[TSDB_MOD_MQTT].stopFp = mqttStopSystem;
  if (tsEnableMqttModule) {
    dnodeSetModuleStatus(TSDB_MOD_MQTT);
  }

S
slguan 已提交
76 77 78 79 80 81 82 83 84
  tsModule[TSDB_MOD_MONITOR].enable    = (tsEnableMonitorModule == 1);
  tsModule[TSDB_MOD_MONITOR].name      = "monitor";
  tsModule[TSDB_MOD_MONITOR].initFp    = monitorInitSystem;
  tsModule[TSDB_MOD_MONITOR].cleanUpFp = monitorCleanUpSystem;
  tsModule[TSDB_MOD_MONITOR].startFp   = monitorStartSystem;
  tsModule[TSDB_MOD_MONITOR].stopFp    = monitorStopSystem;
  if (tsEnableMonitorModule) {
    dnodeSetModuleStatus(TSDB_MOD_MONITOR);
  }
S
#1177  
slguan 已提交
85 86 87
}

void dnodeCleanUpModules() {
S
slguan 已提交
88 89 90
  for (int32_t module = 1; module < TSDB_MOD_MAX; ++module) {
    if (tsModule[module].enable && tsModule[module].stopFp) {
      (*tsModule[module].stopFp)();
S
#1177  
slguan 已提交
91
    }
S
slguan 已提交
92 93
    if (tsModule[module].cleanUpFp) {
      (*tsModule[module].cleanUpFp)();
S
#1177  
slguan 已提交
94 95 96
    }
  }

S
slguan 已提交
97
  if (tsModule[TSDB_MOD_MGMT].enable && tsModule[TSDB_MOD_MGMT].cleanUpFp) {
S
#1177  
slguan 已提交
98 99 100 101 102
    (*tsModule[TSDB_MOD_MGMT].cleanUpFp)();
  }
}

int32_t dnodeInitModules() {
S
slguan 已提交
103 104
  dnodeAllocModules();

S
slguan 已提交
105
  for (EModuleType module = 0; module < TSDB_MOD_MAX; ++module) {
S
slguan 已提交
106 107 108
    if (tsModule[module].initFp) {
      if ((*tsModule[module].initFp)() != 0) {
        dError("failed to init module:%s", tsModule[module].name);
S
#1177  
slguan 已提交
109 110 111 112 113
        return -1;
      }
    }
  }

S
slguan 已提交
114
  return 0;
S
#1177  
slguan 已提交
115 116
}

S
slguan 已提交
117
void dnodeStartModules() {
S
slguan 已提交
118
  for (EModuleType module = 1; module < TSDB_MOD_MAX; ++module) {
S
slguan 已提交
119 120 121 122 123 124
    if (tsModule[module].enable && tsModule[module].startFp) {
      if ((*tsModule[module].startFp)() != 0) {
        dError("failed to start module:%s", tsModule[module].name);
      }
    }
  }
S
#1177  
slguan 已提交
125
}
S
slguan 已提交
126 127

void dnodeProcessModuleStatus(uint32_t moduleStatus) {
S
Shengliang Guan 已提交
128
  for (int32_t module = TSDB_MOD_MGMT; module < TSDB_MOD_HTTP; ++module) {
129 130 131 132 133 134 135
    bool enableModule = moduleStatus & (1 << module);
    if (!tsModule[module].enable && enableModule) {
      dPrint("module status:%u is received, start %s module", tsModuleStatus, tsModule[module].name);
      tsModule[module].enable = true;
      dnodeSetModuleStatus(module);
      (*tsModule[module].startFp)();
    }
S
slguan 已提交
136

137 138 139 140 141 142
    if (tsModule[module].enable && !enableModule) {
      dPrint("module status:%u is received, stop %s module", tsModuleStatus, tsModule[module].name);
      tsModule[module].enable = false;
      dnodeUnSetModuleStatus(module);
      (*tsModule[module].stopFp)();
    }
S
slguan 已提交
143
  }
S
slguan 已提交
144
}