trpc.h 4.6 KB
Newer Older
H
hzcheng 已提交
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21
/*
 * 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_TRPC_H
#define TDENGINE_TRPC_H

#ifdef __cplusplus
extern "C" {
#endif

S
slguan 已提交
22 23
#include <stdbool.h>
#include <stdint.h>
S
slguan 已提交
24
#include "taosdef.h"
H
Hongze Cheng 已提交
25
#include "tmsg.h"
dengyihao's avatar
dengyihao 已提交
26
#include "ttrace.h"
S
slguan 已提交
27

H
Hongze Cheng 已提交
28 29
#define TAOS_CONN_SERVER 0
#define TAOS_CONN_CLIENT 1
H
Hongze Cheng 已提交
30
#define IsReq(pMsg)      (pMsg->msgType & 1U)
31

32
extern int32_t tsRpcHeadSize;
H
hzcheng 已提交
33

S
Shengliang Guan 已提交
34
typedef struct {
H
Hongze Cheng 已提交
35 36
  uint32_t clientIp;
  uint16_t clientPort;
37
  int64_t  applyIndex;
M
Minghao Li 已提交
38
  uint64_t applyTerm;
39
  char     user[TSDB_USER_LEN];
陶建辉(Jeff)'s avatar
陶建辉(Jeff) 已提交
40 41
} SRpcConnInfo;

42
typedef struct SRpcHandleInfo {
S
Shengliang Guan 已提交
43
  // rpc info
dengyihao's avatar
dengyihao 已提交
44 45 46 47 48 49
  void   *handle;         // rpc handle returned to app
  int64_t refId;          // refid, used by server
  int8_t  noResp;         // has response or not(default 0, 0: resp, 1: no resp)
  int8_t  persistHandle;  // persist handle or not
  int8_t  hasEpSet;

S
Shengliang Guan 已提交
50
  // app info
51 52 53 54
  void *ahandle;  // app handle set by client
  void *wrapper;  // wrapper handle
  void *node;     // node mgmt handle

S
Shengliang Guan 已提交
55
  // resp info
M
Minghao Li 已提交
56
  void   *rsp;
57
  int32_t rspLen;
58

dengyihao's avatar
dengyihao 已提交
59 60
  STraceId traceId;

61
  SRpcConnInfo conn;
S
Shengliang Guan 已提交
62
} SRpcHandleInfo;
dengyihao's avatar
dengyihao 已提交
63

S
Shengliang Guan 已提交
64 65
typedef struct SRpcMsg {
  tmsg_t         msgType;
M
Minghao Li 已提交
66
  void          *pCont;
S
Shengliang Guan 已提交
67 68 69
  int32_t        contLen;
  int32_t        code;
  SRpcHandleInfo info;
陶建辉(Jeff)'s avatar
陶建辉(Jeff) 已提交
70 71
} SRpcMsg;

dengyihao's avatar
dengyihao 已提交
72
typedef void (*RpcCfp)(void *parent, SRpcMsg *, SEpSet *epset);
dengyihao's avatar
dengyihao 已提交
73
typedef bool (*RpcRfp)(int32_t code, tmsg_t msgType);
dengyihao's avatar
dengyihao 已提交
74
typedef bool (*RpcTfp)(int32_t code, tmsg_t msgType);
dengyihao's avatar
dengyihao 已提交
75
typedef bool (*RpcFFfp)(tmsg_t msgType);
dengyihao's avatar
dengyihao 已提交
76
typedef void (*RpcDfp)(void *ahandle);
S
Shengliang Guan 已提交
77

78
typedef struct SRpcInit {
79
  char     localFqdn[TSDB_FQDN_LEN];
dengyihao's avatar
dengyihao 已提交
80 81 82 83 84 85
  uint16_t localPort;     // local port
  char    *label;         // for debug purpose
  int32_t  numOfThreads;  // number of threads to handle connections
  int32_t  sessions;      // number of sessions allowed
  int8_t   connType;      // TAOS_CONN_UDP, TAOS_CONN_TCPC, TAOS_CONN_TCPS
  int32_t  idleTime;      // milliseconds, 0 means idle timer is disabled
陶建辉(Jeff)'s avatar
陶建辉(Jeff) 已提交
86

dengyihao's avatar
dengyihao 已提交
87 88 89
  int32_t retryMinInterval;  // retry init interval
  int32_t retryStepFactor;   // retry interval factor
  int32_t retryMaxInterval;  // retry max interval
dengyihao's avatar
dengyihao 已提交
90
  int64_t retryMaxTimouet;
dengyihao's avatar
dengyihao 已提交
91

dengyihao's avatar
dengyihao 已提交
92 93 94
  int32_t failFastThreshold;
  int32_t failFastInterval;

dengyihao's avatar
dengyihao 已提交
95 96
  int32_t compressSize;  // -1: no compress, 0 : all data compressed, size: compress data if larger than size
  int8_t  encryption;    // encrypt or not
dengyihao's avatar
dengyihao 已提交
97

98
  // the following is for client app ecurity only
dengyihao's avatar
dengyihao 已提交
99
  char *user;  // user name
陶建辉(Jeff)'s avatar
陶建辉(Jeff) 已提交
100

dengyihao's avatar
dengyihao 已提交
101
  // call back to process incoming msg
S
Shengliang Guan 已提交
102
  RpcCfp cfp;
陶建辉(Jeff)'s avatar
陶建辉(Jeff) 已提交
103

dengyihao's avatar
dengyihao 已提交
104
  // retry not not for particular msg
dengyihao's avatar
dengyihao 已提交
105
  RpcRfp rfp;
S
Shengliang Guan 已提交
106

dengyihao's avatar
dengyihao 已提交
107 108 109
  // set up timeout for particular msg
  RpcTfp tfp;

dengyihao's avatar
dengyihao 已提交
110 111
  // destroy client ahandle;
  RpcDfp dfp;
dengyihao's avatar
dengyihao 已提交
112 113
  // fail fast fp
  RpcFFfp ffp;
dengyihao's avatar
dengyihao 已提交
114

dengyihao's avatar
dengyihao 已提交
115 116
  int32_t connLimitNum;
  int32_t connLimitLock;
dengyihao's avatar
dengyihao 已提交
117

S
Shengliang Guan 已提交
118
  void *parent;
陶建辉(Jeff)'s avatar
陶建辉(Jeff) 已提交
119 120
} SRpcInit;

dengyihao's avatar
dengyihao 已提交
121
typedef struct {
dengyihao's avatar
dengyihao 已提交
122
  void *val;
D
dapan1121 已提交
123
  int32_t (*clone)(void *src, void **dst);
dengyihao's avatar
dengyihao 已提交
124 125 126
} SRpcCtxVal;

typedef struct {
dengyihao's avatar
dengyihao 已提交
127
  int32_t msgType;
M
Minghao Li 已提交
128
  void   *val;
D
dapan1121 已提交
129
  int32_t (*clone)(void *src, void **dst);
dengyihao's avatar
dengyihao 已提交
130 131 132
} SRpcBrokenlinkVal;

typedef struct {
M
Minghao Li 已提交
133
  SHashObj         *args;
dengyihao's avatar
dengyihao 已提交
134
  SRpcBrokenlinkVal brokenVal;
dengyihao's avatar
dengyihao 已提交
135
  void (*freeFunc)(const void *arg);
dengyihao's avatar
dengyihao 已提交
136 137
} SRpcCtx;

S
Shengliang Guan 已提交
138
int32_t rpcInit();
dengyihao's avatar
dengyihao 已提交
139
void    rpcCleanup();
dengyihao's avatar
dengyihao 已提交
140 141 142 143

void *rpcOpen(const SRpcInit *pRpc);
void  rpcClose(void *);
void  rpcCloseImpl(void *);
wafwerar's avatar
wafwerar 已提交
144
void *rpcMallocCont(int64_t contLen);
dengyihao's avatar
dengyihao 已提交
145
void  rpcFreeCont(void *pCont);
wafwerar's avatar
wafwerar 已提交
146
void *rpcReallocCont(void *ptr, int64_t contLen);
dengyihao's avatar
dengyihao 已提交
147

S
shm  
Shengliang Guan 已提交
148 149 150
// Because taosd supports multi-process mode
// These functions should not be used on the server side
// Please use tmsg<xx> functions, which are defined in tmsgcb.h
dengyihao's avatar
dengyihao 已提交
151 152 153 154
int rpcSendRequest(void *thandle, const SEpSet *pEpSet, SRpcMsg *pMsg, int64_t *rid);
int rpcSendResponse(const SRpcMsg *pMsg);
int rpcRegisterBrokenLinkArg(SRpcMsg *msg);
int rpcReleaseHandle(void *handle, int8_t type);  // just release conn to rpc instance, no close sock
S
shm  
Shengliang Guan 已提交
155 156

// These functions will not be called in the child process
dengyihao's avatar
dengyihao 已提交
157 158 159 160
int   rpcSendRequestWithCtx(void *thandle, const SEpSet *pEpSet, SRpcMsg *pMsg, int64_t *rid, SRpcCtx *ctx);
int   rpcSendRecv(void *shandle, SEpSet *pEpSet, SRpcMsg *pReq, SRpcMsg *pRsp);
int   rpcSetDefaultAddr(void *thandle, const char *ip, const char *fqdn);
void *rpcAllocHandle();
dengyihao's avatar
dengyihao 已提交
161

H
hzcheng 已提交
162 163 164 165 166
#ifdef __cplusplus
}
#endif

#endif  // TDENGINE_TRPC_H