vnodePeer.h
This commit is contained in:
parent
7046203557
commit
f9f0e72d1d
|
@ -684,10 +684,15 @@ typedef struct {
|
||||||
} SSecIe;
|
} SSecIe;
|
||||||
|
|
||||||
typedef struct {
|
typedef struct {
|
||||||
uint32_t ip;
|
int32_t dnode; //the ID of dnode
|
||||||
uint32_t vnode;
|
int32_t vnode; //the index of vnode
|
||||||
} SVPeerDesc;
|
} SVPeerDesc;
|
||||||
|
|
||||||
|
typedef struct {
|
||||||
|
int32_t numOfVPeers;
|
||||||
|
SVPeerDesc vpeerDesc[];
|
||||||
|
} SVpeerDescArray;
|
||||||
|
|
||||||
typedef struct {
|
typedef struct {
|
||||||
int32_t vnode;
|
int32_t vnode;
|
||||||
SVnodeCfg cfg;
|
SVnodeCfg cfg;
|
||||||
|
|
|
@ -25,7 +25,7 @@ extern "C" {
|
||||||
#include <stdint.h>
|
#include <stdint.h>
|
||||||
#include "mnode.h"
|
#include "mnode.h"
|
||||||
|
|
||||||
|
int32_t mgmtInitSTable();
|
||||||
|
|
||||||
|
|
||||||
#ifdef __cplusplus
|
#ifdef __cplusplus
|
||||||
|
|
|
@ -34,3 +34,4 @@
|
||||||
#include "tsqlfunction.h"
|
#include "tsqlfunction.h"
|
||||||
#include "ttime.h"
|
#include "ttime.h"
|
||||||
#include "tstatus.h"
|
#include "tstatus.h"
|
||||||
|
|
||||||
|
|
|
@ -97,7 +97,7 @@ int32_t mgmtMeterDropColumnByName(STabObj *pTable, const char *name);
|
||||||
static int dropMeterImp(SDbObj *pDb, STabObj * pTable, SAcctObj *pAcct);
|
static int dropMeterImp(SDbObj *pDb, STabObj * pTable, SAcctObj *pAcct);
|
||||||
static void dropAllMetersOfMetric(SDbObj *pDb, STabObj * pMetric, SAcctObj *pAcct);
|
static void dropAllMetersOfMetric(SDbObj *pDb, STabObj * pMetric, SAcctObj *pAcct);
|
||||||
|
|
||||||
void mgmtMeterActionInit() {
|
static void mgmtMeterActionInit() {
|
||||||
mgmtMeterActionFp[SDB_TYPE_INSERT] = mgmtMeterActionInsert;
|
mgmtMeterActionFp[SDB_TYPE_INSERT] = mgmtMeterActionInsert;
|
||||||
mgmtMeterActionFp[SDB_TYPE_DELETE] = mgmtMeterActionDelete;
|
mgmtMeterActionFp[SDB_TYPE_DELETE] = mgmtMeterActionDelete;
|
||||||
mgmtMeterActionFp[SDB_TYPE_UPDATE] = mgmtMeterActionUpdate;
|
mgmtMeterActionFp[SDB_TYPE_UPDATE] = mgmtMeterActionUpdate;
|
||||||
|
|
|
@ -0,0 +1,56 @@
|
||||||
|
/*
|
||||||
|
* 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_VNODE_PEER_H
|
||||||
|
#define TDENGINE_VNODEPEER_H
|
||||||
|
|
||||||
|
#ifdef __cplusplus
|
||||||
|
extern "C" {
|
||||||
|
#endif
|
||||||
|
|
||||||
|
#include <stdint.h>
|
||||||
|
#include <stdbool.h>
|
||||||
|
#include "tsdb.h"
|
||||||
|
|
||||||
|
/*
|
||||||
|
* Initialize the resources
|
||||||
|
*/
|
||||||
|
int32_t vnodeInitPeer(int numOfThreads);
|
||||||
|
|
||||||
|
/*
|
||||||
|
* Free the resources
|
||||||
|
*/
|
||||||
|
void vnodeCleanUpPeers();
|
||||||
|
|
||||||
|
/*
|
||||||
|
* Start a vnode synchronization process
|
||||||
|
*/
|
||||||
|
int32_t vnodeOpenPeer(int32_t vnode);
|
||||||
|
|
||||||
|
/*
|
||||||
|
* Update the peerinfo of vnode
|
||||||
|
*/
|
||||||
|
int32_t vnodeConfigPeer(SVpeerDescArray msg);
|
||||||
|
|
||||||
|
/*
|
||||||
|
* Close a vnode synchronization process
|
||||||
|
*/
|
||||||
|
void vnodeCleanUpPeer(int32_t vnode);
|
||||||
|
|
||||||
|
#ifdef __cplusplus
|
||||||
|
}
|
||||||
|
#endif
|
||||||
|
|
||||||
|
#endif // TDENGINE_VNODEPEER_H
|
|
@ -1,108 +0,0 @@
|
||||||
/*
|
|
||||||
* 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_VNODEPEER_H
|
|
||||||
#define TDENGINE_VNODEPEER_H
|
|
||||||
|
|
||||||
#include "os.h"
|
|
||||||
|
|
||||||
#ifdef __cplusplus
|
|
||||||
extern "C" {
|
|
||||||
#endif
|
|
||||||
|
|
||||||
#define TSDB_VMSG_SYNC_DATA 1
|
|
||||||
#define TSDB_VMSG_FORWARD 2
|
|
||||||
#define TSDB_VMSG_SYNC_REQ 3
|
|
||||||
#define TSDB_VMSG_SYNC_RSP 4
|
|
||||||
#define TSDB_VMSG_SYNC_MUST 5
|
|
||||||
#define TSDB_VMSG_STATUS 6
|
|
||||||
|
|
||||||
#pragma pack(push, 1)
|
|
||||||
|
|
||||||
typedef struct {
|
|
||||||
char type;
|
|
||||||
char version;
|
|
||||||
short sourceVid;
|
|
||||||
short destVid;
|
|
||||||
} SFirstPkt;
|
|
||||||
|
|
||||||
typedef struct {
|
|
||||||
uint64_t lastCreate;
|
|
||||||
uint64_t lastRemove;
|
|
||||||
uint32_t fileId;
|
|
||||||
uint64_t fmagic[];
|
|
||||||
} SSyncMsg;
|
|
||||||
|
|
||||||
typedef struct {
|
|
||||||
char status;
|
|
||||||
uint64_t version;
|
|
||||||
} SPeerState;
|
|
||||||
|
|
||||||
typedef struct {
|
|
||||||
char status : 6;
|
|
||||||
char ack : 2;
|
|
||||||
char commitInProcess;
|
|
||||||
int32_t fileId; // ID for corrupted file, 0 means no corrupted file
|
|
||||||
uint64_t version;
|
|
||||||
SPeerState peerStates[];
|
|
||||||
} SPeerStatus;
|
|
||||||
|
|
||||||
#pragma pack(pop)
|
|
||||||
|
|
||||||
typedef struct _thread_obj {
|
|
||||||
pthread_t thread;
|
|
||||||
int threadId;
|
|
||||||
int pollFd;
|
|
||||||
int numOfFds;
|
|
||||||
} SThreadObj;
|
|
||||||
|
|
||||||
typedef struct {
|
|
||||||
int numOfThreads;
|
|
||||||
SThreadObj **pThread;
|
|
||||||
pthread_t thread;
|
|
||||||
int threadId;
|
|
||||||
} SThreadPool;
|
|
||||||
|
|
||||||
typedef struct _vnodePeer {
|
|
||||||
void * signature;
|
|
||||||
int ownId; // own vnode ID
|
|
||||||
uint32_t ip;
|
|
||||||
char ipstr[20]; // ip string
|
|
||||||
int vid;
|
|
||||||
int status;
|
|
||||||
int syncStatus;
|
|
||||||
int32_t fileId; // 0 means no corrupted file
|
|
||||||
uint64_t version;
|
|
||||||
int commitInProcess;
|
|
||||||
int syncFd;
|
|
||||||
int peerFd; // forward FD
|
|
||||||
void * hbTimer;
|
|
||||||
void * syncTimer;
|
|
||||||
SThreadObj *pThread;
|
|
||||||
} SVnodePeer;
|
|
||||||
|
|
||||||
typedef struct {
|
|
||||||
SVnodePeer *pVPeer;
|
|
||||||
uint64_t lastCreate;
|
|
||||||
uint64_t lastRemove;
|
|
||||||
uint32_t fileId;
|
|
||||||
uint64_t fmagic[];
|
|
||||||
} SSyncCmd;
|
|
||||||
|
|
||||||
#ifdef __cplusplus
|
|
||||||
}
|
|
||||||
#endif
|
|
||||||
|
|
||||||
#endif // TDENGINE_VNODEPEER_H
|
|
Loading…
Reference in New Issue