mirror of
https://github.com/taosdata/TDengine
synced 2026-05-24 10:09:01 +00:00
* feat: add xnode syntax * refactor(xnode): reduce function complexity * chore: add lost xnode.h file * feat(xnode): create xnode task * chore: fix double free error * add xnoded * start xnoded as subprocess * complete xnode task feature * complete show xnode jobs feature * complete with option feature * complete alter xnode job feature * complete alter xnode task feature * complete user pass feature * clean code * modify status type as char * fix leader ep null * fix start task req null * fix pass id for status * support timeout msg * drop xnode task relative jobs * clean code * wip * chore: add test cases for xnode * chore: fix 3.0 merge changes * fix drain core dump and create task core dump * add password check * retrieve xnode status from xnoded * pass integer as double to cjson * add some debug log * add some job log * fix start task lock * do not handle http response * fix coredump drop xnode task by name * support start/stop/drop task by name * remove mock xnoded * support unix socket * kill pre-xnoded before start * support dnode close xnoded * test(xnode): add unit test cases for xnode * rebalance support where clause * fix some test issue * unformat http post content json string * add xnode zh doc * modify drain description * remove job create/stop/drop operation * support rebalance all without where condition * support alter task by name * add NULL param for mndCheckOperPrivilege * add xnode txnode module for libmnode.a * code clean * change parser len to 4096 * clean code * chore: try to fix gtest/gtest.h not found * chore: fix markdown files * chore: fix markdown in zh * chore: fix enum issue and add ci * chore: fix test case problem * chore: fix pKeyVal overflow * chore: rename to 排空节点 * chore: external cmake remove parallel * chore: add DEP_ext_gtest for xnode test * chore: fix gtest errors * chore: remove gtest pthread lib * chore: fix data type not match * chore: fix some lint errors * chore: fix void unlink * chore: fix return with null pointer check * chore: fix pointer double free and xnodeMemoryTest strncpy null * chore: fix xnode encode action invalid datelen * chore: remove TD_LINUX condition * chore: use PRIu64 denote long long * chore: fix task parser NULL and allow no with clause * fix(xnode): fix windows build error * chore: fix windows curl error * chore: fix test case ins_tables relative error * chore: fix memory leak * docs: update taosx docs * chore: update taosx docs * chore: add role priviledge table * chore: fix error code doc * chore: fix test_xnode.py * chore: fix doc typo * fix: ci error while run test_user_privilege_sysinfo.py --------- Co-authored-by: Linhe Huo <linhehuo@gmail.com> Co-authored-by: huohong <sallyhuo@taosdata.com> Co-authored-by: Simon Guan <guanshengliang@qq.com>
103 lines
3.9 KiB
C
103 lines
3.9 KiB
C
/*
|
|
* 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/>.
|
|
*/
|
|
|
|
#ifndef _TD_TXNODE_H_
|
|
#define _TD_TXNODE_H_
|
|
|
|
#undef malloc
|
|
#define malloc malloc
|
|
#undef free
|
|
#define free free
|
|
#undef realloc
|
|
#define alloc alloc
|
|
|
|
#include <stdbool.h>
|
|
#include <stdint.h>
|
|
#include "dnode/xnode/xnode.h"
|
|
#include "tcommon.h"
|
|
#include "tdatablock.h"
|
|
#include "tmsg.h"
|
|
|
|
#ifdef __cplusplus
|
|
extern "C" {
|
|
#endif
|
|
|
|
#define TAOS_UV_LIB_ERROR_RET(ret) \
|
|
do { \
|
|
if (0 != ret) { \
|
|
terrno = TSDB_CODE_BNODE_UV_EXEC_FAILURE; \
|
|
return TSDB_CODE_BNODE_UV_EXEC_FAILURE; \
|
|
} \
|
|
} while (0)
|
|
|
|
#define TAOS_UV_CHECK_ERRNO(CODE) \
|
|
do { \
|
|
if (0 != CODE) { \
|
|
terrln = __LINE__; \
|
|
terrno = (CODE); \
|
|
goto _exit; \
|
|
} \
|
|
} while (0)
|
|
|
|
#define TAOS_XNODED_MGMT_CHECK_PTR_RCODE(...) \
|
|
do { \
|
|
const void *ptrs[] = {__VA_ARGS__}; \
|
|
for (int i = 0; i < sizeof(ptrs) / sizeof(ptrs[0]); ++i) { \
|
|
if (ptrs[i] == NULL) { \
|
|
xndError("taosxnode %dth parameter invalid, NULL PTR.line:%d", i, __LINE__); \
|
|
return TSDB_CODE_INVALID_PARA; \
|
|
} \
|
|
} \
|
|
} while (0)
|
|
|
|
#define TAOS_XNODED_MGMT_CHECK_PTR_RVOID(...) \
|
|
do { \
|
|
const void *ptrs[] = {__VA_ARGS__}; \
|
|
for (int i = 0; i < sizeof(ptrs) / sizeof(ptrs[0]); ++i) { \
|
|
if (ptrs[i] == NULL) { \
|
|
xndError("taosxnode %dth parameter invalid, NULL PTR.line:%d", i, __LINE__); \
|
|
return; \
|
|
} \
|
|
} \
|
|
} while (0)
|
|
|
|
#define TAOS_XNODED_MGMT_CHECK_CONDITION(o, code) \
|
|
do { \
|
|
if ((o) == false) { \
|
|
xndError("Condition not met.line:%d", __LINE__); \
|
|
return code; \
|
|
} \
|
|
} while (0)
|
|
|
|
/**
|
|
* start taosmqtt that serves mqtt function invocation under dnode startDnodeId
|
|
* @param startDnodeId
|
|
* @return
|
|
*/
|
|
// int32_t xnodeMgmtStartXnoded(int32_t startDnodeId, int64_t clusterId, int32_t uplen, const char *userPass);
|
|
int32_t xnodeMgmtStartXnoded(SXnode *pXnode);
|
|
/**
|
|
* stop taosmqtt
|
|
* @return
|
|
*/
|
|
void xnodeMgmtStopXnoded(void);
|
|
|
|
#ifdef __cplusplus
|
|
}
|
|
#endif
|
|
|
|
void getXnodedPipeName(char *pipeName, int32_t size);
|
|
|
|
#endif // _TD_TXNODE_H_
|