提交 24190a8f 编写于 作者: S slguan

dnodeShell

上级 4563289f
...@@ -660,7 +660,7 @@ int taos_fetch_block(TAOS_RES *res, TAOS_ROW *rows) { ...@@ -660,7 +660,7 @@ int taos_fetch_block(TAOS_RES *res, TAOS_ROW *rows) {
} }
// projection query on metric, pipeline retrieve data from vnode list, // projection query on metric, pipeline retrieve data from vnode list,
// instead of two-stage mergevnodeProcessMsgFromShell free qhandle // instead of two-stage mergednodeProcessMsgFromShell free qhandle
nRows = taos_fetch_block_impl(res, rows); nRows = taos_fetch_block_impl(res, rows);
// current subclause is completed, try the next subclause // current subclause is completed, try the next subclause
......
...@@ -20,6 +20,8 @@ ...@@ -20,6 +20,8 @@
extern "C" { extern "C" {
#endif #endif
#include <stdint.h>
#include <stdbool.h>
#include "tsched.h" #include "tsched.h"
#include "dnode.h" #include "dnode.h"
...@@ -30,6 +32,9 @@ void dnodeDistributeMsgFromMgmt(char *content, int msgLen, int msgType, SMgmtObj ...@@ -30,6 +32,9 @@ void dnodeDistributeMsgFromMgmt(char *content, int msgLen, int msgType, SMgmtObj
extern void *dmQhandle; extern void *dmQhandle;
void dnodeSendVpeerCfgMsg(int32_t vnode);
void dnodeSendMeterCfgMsg(int32_t vnode, int32_t sid);
#ifdef __cplusplus #ifdef __cplusplus
} }
#endif #endif
......
...@@ -20,12 +20,24 @@ ...@@ -20,12 +20,24 @@
extern "C" { extern "C" {
#endif #endif
#include <stdbool.h>
#include <stdint.h>
#include "taosdef.h"
#include "taosmsg.h"
#include "dnodeShell.h"
void dnodeFreeQInfoInQueue(SShellObj *pShellObj);
/* /*
* Dnode handle read messages * Dnode handle read messages
* The processing result is returned by callback function with pShellObj parameter * The processing result is returned by callback function with pShellObj parameter
*/ */
int32_t dnodeReadData(SQueryMeterMsg *msg, void *pShellObj, void (*callback)(SQueryMeterRsp *rspMsg, void *pShellObj)); int32_t dnodeReadData(SQueryMeterMsg *msg, void *pShellObj, void (*callback)(SQueryMeterRsp *rspMsg, void *pShellObj));
typedef void (*SDnodeRetrieveCallbackFp)(int32_t code, SRetrieveMeterRsp *pRetrieveRspMsg, void *pShellObj);
void dnodeRetrieveData(SRetrieveMeterMsg *pMsg, int32_t msgLen, void *pShellObj, SDnodeRetrieveCallbackFp callback);
#ifdef __cplusplus #ifdef __cplusplus
} }
#endif #endif
......
...@@ -26,7 +26,6 @@ extern "C" { ...@@ -26,7 +26,6 @@ extern "C" {
typedef struct { typedef struct {
int sid; int sid;
int vnode;
uint32_t ip; uint32_t ip;
uint16_t port; uint16_t port;
int32_t count; // track the number of imports int32_t count; // track the number of imports
...@@ -38,6 +37,8 @@ typedef struct { ...@@ -38,6 +37,8 @@ typedef struct {
int32_t dnodeInitShell(); int32_t dnodeInitShell();
void dnodeCleanupShell();
//SDnodeStatisInfo dnodeGetStatisInfo() //SDnodeStatisInfo dnodeGetStatisInfo()
#ifdef __cplusplus #ifdef __cplusplus
......
...@@ -37,7 +37,8 @@ extern int32_t (*dnodeInitStorage)(); ...@@ -37,7 +37,8 @@ extern int32_t (*dnodeInitStorage)();
extern void (*dnodeCleanupStorage)(); extern void (*dnodeCleanupStorage)();
extern void (*dnodeParseParameterK)(); extern void (*dnodeParseParameterK)();
extern int32_t tsMaxQueues; extern int32_t tsMaxQueues;
extern void ** tsRpcQhandle;
extern void *tsQueryQhandle;
int32_t dnodeInitSystem(); int32_t dnodeInitSystem();
void dnodeCleanUpSystem(); void dnodeCleanUpSystem();
......
/*
* 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 TDENGINE_DNODE_UTIL_H
#define TDENGINE_DNODE_UTIL_H
#ifdef __cplusplus
extern "C" {
#endif
#include <stdbool.h>
#include <stdint.h>
#include "taosdef.h"
#include "taosmsg.h"
#include "tstatus.h"
EVnodeStatus dnodeGetVnodeStatus(int32_t vnode);
bool dnodeCheckVnodeExist(int32_t vnode);
void *dnodeGetVnodeObj(int32_t vnode);
#ifdef __cplusplus
}
#endif
#endif
...@@ -26,11 +26,13 @@ extern "C" { ...@@ -26,11 +26,13 @@ extern "C" {
#include "taosmsg.h" #include "taosmsg.h"
/* /*
* Write data based on dnode * Write data based on dnode, the detail result can be fetched from rsponse
* If >= 0, it is affect rows * pSubmitMsg: Data to be written
* If < 0, get error code from terrno * pShellObj: Used to pass a communication handle
* callback: Pass the write result through a callback function, possibly in a different thread space
* rsp: will not be freed by callback function
*/ */
int32_t dnodeWriteData(SShellSubmitMsg *msg); void dnodeWriteData(SShellSubmitMsg *pMsg, void *pShellObj, void (*callback)(SShellSubmitRspMsg *rsp, void *pShellObj));
/* /*
* Check if table already exists * Check if table already exists
......
...@@ -548,7 +548,7 @@ int vnodeProcessCfgDnodeRequest(char *cont, int contLen, SMgmtObj *pMgmtObj) { ...@@ -548,7 +548,7 @@ int vnodeProcessCfgDnodeRequest(char *cont, int contLen, SMgmtObj *pMgmtObj) {
return 0; return 0;
} }
void vnodeSendVpeerCfgMsg(int vnode) { void dnodeSendVpeerCfgMsg(int32_t vnode) {
char * pMsg, *pStart; char * pMsg, *pStart;
int msgLen; int msgLen;
SVpeerCfgMsg *pCfg; SVpeerCfgMsg *pCfg;
...@@ -566,7 +566,7 @@ void vnodeSendVpeerCfgMsg(int vnode) { ...@@ -566,7 +566,7 @@ void vnodeSendVpeerCfgMsg(int vnode) {
taosSendMsgToMnode(pObj, pStart, msgLen); taosSendMsgToMnode(pObj, pStart, msgLen);
} }
int vnodeSendMeterCfgMsg(int vnode, int sid) { void dnodeSendMeterCfgMsg(int32_t vnode, int32_t sid) {
char * pMsg, *pStart; char * pMsg, *pStart;
int msgLen; int msgLen;
SMeterCfgMsg *pCfg; SMeterCfgMsg *pCfg;
......
...@@ -14,4 +14,48 @@ ...@@ -14,4 +14,48 @@
*/ */
#define _DEFAULT_SOURCE #define _DEFAULT_SOURCE
#include "os.h"
#include "taoserror.h"
#include "tlog.h"
#include "dnodeWrite.h"
#include "dnode.h"
#include "dnodeRead.h"
#include "dnodeSystem.h"
void dnodeFreeQInfoInQueue(SShellObj *pShellObj) {
}
void dnodeExecuteRetrieveData(SSchedMsg *pSched) {
SRetrieveMeterMsg *pRetrieve = (SRetrieveMeterMsg *)pSched->msg;
SDnodeRetrieveCallbackFp callback = (SDnodeRetrieveCallbackFp)pSched->thandle;
SShellObj *pObj = (SShellObj *)pSched->ahandle;
SRetrieveMeterRsp result = {0};
/*
* in case of server restart, apps may hold qhandle created by server before restart,
* which is actually invalid, therefore, signature check is required.
*/
if (pRetrieve->qhandle != (uint64_t)pObj->qhandle) {
// if free flag is set, client wants to clean the resources
dError("QInfo:%p, qhandle:%p is not matched with saved:%p", pObj->qhandle, pRetrieve->qhandle, pObj->qhandle);
int32_t code = TSDB_CODE_INVALID_QHANDLE;
(*callback)(code, &result, pObj);
}
//TODO build response here
free(pSched->msg);
}
void dnodeRetrieveData(SRetrieveMeterMsg *pMsg, int32_t msgLen, void *pShellObj, SDnodeRetrieveCallbackFp callback) {
int8_t *msg = malloc(msgLen);
memcpy(msg, pMsg, msgLen);
SSchedMsg schedMsg;
schedMsg.msg = msg;
schedMsg.ahandle = pShellObj;
schedMsg.thandle = callback;
schedMsg.fp = dnodeExecuteRetrieveData;
taosScheduleTask(tsQueryQhandle, &schedMsg);
}
此差异已折叠。
...@@ -52,9 +52,9 @@ static int32_t dnodeInitTmrCtl(); ...@@ -52,9 +52,9 @@ static int32_t dnodeInitTmrCtl();
void *tsStatusTimer = NULL; void *tsStatusTimer = NULL;
void *vnodeTmrCtrl; void *vnodeTmrCtrl;
void **rpcQhandle; void **tsRpcQhandle;
void *dmQhandle; void *dmQhandle;
void *queryQhandle; void *tsQueryQhandle;
int32_t tsVnodePeers = TSDB_VNODES_SUPPORT - 1; int32_t tsVnodePeers = TSDB_VNODES_SUPPORT - 1;
int32_t tsMaxQueues; int32_t tsMaxQueues;
uint32_t tsRebootTime; uint32_t tsRebootTime;
...@@ -95,6 +95,7 @@ void dnodeCleanUpSystem() { ...@@ -95,6 +95,7 @@ void dnodeCleanUpSystem() {
tsStatusTimer = NULL; tsStatusTimer = NULL;
} }
dnodeCleanupShell();
dnodeCleanUpModules(); dnodeCleanUpModules();
dnodeCleanupVnodes(); dnodeCleanupVnodes();
taosCloseLogger(); taosCloseLogger();
...@@ -269,7 +270,7 @@ static int32_t dnodeInitQueryQHandle() { ...@@ -269,7 +270,7 @@ static int32_t dnodeInitQueryQHandle() {
int32_t maxQueueSize = tsNumOfVnodesPerCore * tsNumOfCores * tsSessionsPerVnode; int32_t maxQueueSize = tsNumOfVnodesPerCore * tsNumOfCores * tsSessionsPerVnode;
dTrace("query task queue initialized, max slot:%d, task threads:%d", maxQueueSize, numOfThreads); dTrace("query task queue initialized, max slot:%d, task threads:%d", maxQueueSize, numOfThreads);
queryQhandle = taosInitSchedulerWithInfo(maxQueueSize, numOfThreads, "query", vnodeTmrCtrl); tsQueryQhandle = taosInitSchedulerWithInfo(maxQueueSize, numOfThreads, "query", vnodeTmrCtrl);
return 0; return 0;
} }
...@@ -291,10 +292,10 @@ static int32_t dnodeInitRpcQHandle() { ...@@ -291,10 +292,10 @@ static int32_t dnodeInitRpcQHandle() {
tsMaxQueues = 1; tsMaxQueues = 1;
} }
rpcQhandle = malloc(tsMaxQueues * sizeof(void *)); tsRpcQhandle = malloc(tsMaxQueues * sizeof(void *));
for (int32_t i = 0; i < tsMaxQueues; ++i) { for (int32_t i = 0; i < tsMaxQueues; ++i) {
rpcQhandle[i] = taosInitScheduler(tsSessionsPerVnode, 1, "dnode"); tsRpcQhandle[i] = taosInitScheduler(tsSessionsPerVnode, 1, "dnode");
} }
dmQhandle = taosInitScheduler(tsSessionsPerVnode, 1, "mgmt"); dmQhandle = taosInitScheduler(tsSessionsPerVnode, 1, "mgmt");
......
/*
* 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 "dnodeUtil.h"
EVnodeStatus dnodeGetVnodeStatus(int32_t vnode) {
return TSDB_VN_STATUS_MASTER;
}
bool dnodeCheckVnodeExist(int32_t vnode) {
return true;
}
...@@ -14,15 +14,26 @@ ...@@ -14,15 +14,26 @@
*/ */
#define _DEFAULT_SOURCE #define _DEFAULT_SOURCE
#include "dnodeWrite.h" #include "os.h"
#include "taoserror.h" #include "taoserror.h"
#include "tlog.h"
#include "dnodeWrite.h"
int32_t dnodeCheckTableExist(char *tableId) { int32_t dnodeCheckTableExist(char *tableId) {
return 0; return 0;
} }
int32_t dnodeWriteData(SShellSubmitMsg *msg) { void dnodeWriteData(SShellSubmitMsg *pSubmit, void *pShellObj, void (*callback)(SShellSubmitRspMsg *, void *)) {
return 0; SShellSubmitRspMsg result = {0};
int32_t numOfSid = htonl(pSubmit->numOfSid);
if (numOfSid <= 0) {
dError("invalid num of tables:%d", numOfSid);
result.code = TSDB_CODE_INVALID_QUERY_MSG;
callback(&result, pShellObj);
}
//TODO: submit implementation
} }
int32_t dnodeCreateNormalTable(SCreateNormalTableMsg *table) { int32_t dnodeCreateNormalTable(SCreateNormalTableMsg *table) {
......
...@@ -16,6 +16,10 @@ ...@@ -16,6 +16,10 @@
#ifndef TDENGINE_HTTP_H #ifndef TDENGINE_HTTP_H
#define TDENGINE_HTTP_H #define TDENGINE_HTTP_H
#ifdef __cplusplus
extern "C" {
#endif
#include "tglobalcfg.h" #include "tglobalcfg.h"
#include "tlog.h" #include "tlog.h"
...@@ -44,4 +48,8 @@ ...@@ -44,4 +48,8 @@
int32_t httpGetReqCount(); int32_t httpGetReqCount();
#ifdef __cplusplus
}
#endif
#endif #endif
...@@ -271,6 +271,7 @@ typedef struct { ...@@ -271,6 +271,7 @@ typedef struct {
} SSubmitMsg; } SSubmitMsg;
typedef struct { typedef struct {
int32_t vnode;
int32_t sid; int32_t sid;
int32_t sversion; int32_t sversion;
uint64_t uid; uint64_t uid;
...@@ -279,12 +280,28 @@ typedef struct { ...@@ -279,12 +280,28 @@ typedef struct {
} SShellSubmitBlock; } SShellSubmitBlock;
typedef struct { typedef struct {
short import; int8_t import;
short vnode; int8_t reserved[3];
int32_t numOfSid; /* total number of sid */ int32_t numOfSid; /* total number of sid */
char blks[]; /* numOfSid blocks, each blocks for one meter */ char blks[]; /* numOfSid blocks, each blocks for one meter */
} SShellSubmitMsg; } SShellSubmitMsg;
typedef struct {
int32_t vnode; // vnode index of failed block
int32_t sid; // table index of failed block
int32_t code; // errorcode while write data to vnode, such as not created, dropped, no space, invalid table
} SShellSubmitRspBlock;
typedef struct {
int32_t code; // 0-success, 1-inprogress, > 1 error code
int32_t numOfRows; // number of records the client is trying to write
int32_t affectedRows; // number of records actually written
int32_t failedRows; // number of failed records (exclude duplicate records)
int32_t numOfFailedBlocks;
SShellSubmitRspBlock *failedBlocks;
} SShellSubmitRspMsg;
typedef struct SSchema { typedef struct SSchema {
uint8_t type; uint8_t type;
char name[TSDB_COL_NAME_LEN]; char name[TSDB_COL_NAME_LEN];
......
...@@ -40,7 +40,7 @@ void * mgmtStatisticTimer = NULL; ...@@ -40,7 +40,7 @@ void * mgmtStatisticTimer = NULL;
int mgmtShellConns = 0; int mgmtShellConns = 0;
int mgmtDnodeConns = 0; int mgmtDnodeConns = 0;
extern void * pShellConn; extern void * pShellConn;
extern void ** rpcQhandle; extern void ** tsRpcQhandle;
extern SMgmtIpList mgmtIpList; extern SMgmtIpList mgmtIpList;
extern SMgmtIpList mgmtPublicIpList; extern SMgmtIpList mgmtPublicIpList;
extern char mgmtIpStr[TSDB_MAX_MGMT_IPS][20]; extern char mgmtIpStr[TSDB_MAX_MGMT_IPS][20];
......
...@@ -40,7 +40,7 @@ enum _TSDB_DB_STATUS { ...@@ -40,7 +40,7 @@ enum _TSDB_DB_STATUS {
TSDB_DB_STATUS_DROP_FROM_SDB TSDB_DB_STATUS_DROP_FROM_SDB
}; };
enum _TSDB_VN_STATUS { typedef enum _TSDB_VN_STATUS {
TSDB_VN_STATUS_OFFLINE, TSDB_VN_STATUS_OFFLINE,
TSDB_VN_STATUS_CREATING, TSDB_VN_STATUS_CREATING,
TSDB_VN_STATUS_UNSYNCED, TSDB_VN_STATUS_UNSYNCED,
...@@ -48,7 +48,7 @@ enum _TSDB_VN_STATUS { ...@@ -48,7 +48,7 @@ enum _TSDB_VN_STATUS {
TSDB_VN_STATUS_MASTER, TSDB_VN_STATUS_MASTER,
TSDB_VN_STATUS_CLOSING, TSDB_VN_STATUS_CLOSING,
TSDB_VN_STATUS_DELETING, TSDB_VN_STATUS_DELETING,
}; } EVnodeStatus;
enum _TSDB_VN_SYNC_STATUS { enum _TSDB_VN_SYNC_STATUS {
TSDB_VN_SYNC_STATUS_INIT, TSDB_VN_SYNC_STATUS_INIT,
......
...@@ -302,9 +302,8 @@ typedef struct { ...@@ -302,9 +302,8 @@ typedef struct {
// internal globals // internal globals
extern int tsMeterSizeOnFile; extern int tsMeterSizeOnFile;
extern void ** rpcQhandle;
extern void * queryQhandle; extern void * tsQueryQhandle;
extern int tsVnodePeers; extern int tsVnodePeers;
extern int tsMaxVnode; extern int tsMaxVnode;
extern int tsMaxQueues; extern int tsMaxQueues;
......
...@@ -696,7 +696,7 @@ void *vnodeQueryOnSingleTable(SMeterObj **pMetersObj, SSqlGroupbyExpr *pGroupbyE ...@@ -696,7 +696,7 @@ void *vnodeQueryOnSingleTable(SMeterObj **pMetersObj, SSqlGroupbyExpr *pGroupbyE
dTrace("QInfo:%p set query flag and prepare runtime environment completed, ref:%d, wait for schedule", pQInfo, dTrace("QInfo:%p set query flag and prepare runtime environment completed, ref:%d, wait for schedule", pQInfo,
pQInfo->refCount); pQInfo->refCount);
taosScheduleTask(queryQhandle, &schedMsg); taosScheduleTask(tsQueryQhandle, &schedMsg);
return pQInfo; return pQInfo;
_error: _error:
...@@ -812,7 +812,7 @@ void *vnodeQueryOnMultiMeters(SMeterObj **pMetersObj, SSqlGroupbyExpr *pGroupbyE ...@@ -812,7 +812,7 @@ void *vnodeQueryOnMultiMeters(SMeterObj **pMetersObj, SSqlGroupbyExpr *pGroupbyE
dTrace("QInfo:%p set query flag and prepare runtime environment completed, wait for schedule", pQInfo); dTrace("QInfo:%p set query flag and prepare runtime environment completed, wait for schedule", pQInfo);
taosScheduleTask(queryQhandle, &schedMsg); taosScheduleTask(tsQueryQhandle, &schedMsg);
return pQInfo; return pQInfo;
_error: _error:
...@@ -912,7 +912,7 @@ int vnodeSaveQueryResult(void *handle, char *data, int32_t *size) { ...@@ -912,7 +912,7 @@ int vnodeSaveQueryResult(void *handle, char *data, int32_t *size) {
schedMsg.msg = NULL; schedMsg.msg = NULL;
schedMsg.thandle = (void *)1; schedMsg.thandle = (void *)1;
schedMsg.ahandle = pQInfo; schedMsg.ahandle = pQInfo;
taosScheduleTask(queryQhandle, &schedMsg); taosScheduleTask(tsQueryQhandle, &schedMsg);
} }
} }
......
Markdown is supported
0% .
You are about to add 0 people to the discussion. Proceed with caution.
先完成此消息的编辑!
想要评论请 注册