Merge pull request #21247 from taosdata/feat/restore-dnode
Feat/restore dnode
This commit is contained in:
commit
72ebd9955c
|
@ -1625,6 +1625,21 @@ typedef struct {
|
||||||
int32_t tSerializeSDropDnodeReq(void* buf, int32_t bufLen, SDropDnodeReq* pReq);
|
int32_t tSerializeSDropDnodeReq(void* buf, int32_t bufLen, SDropDnodeReq* pReq);
|
||||||
int32_t tDeserializeSDropDnodeReq(void* buf, int32_t bufLen, SDropDnodeReq* pReq);
|
int32_t tDeserializeSDropDnodeReq(void* buf, int32_t bufLen, SDropDnodeReq* pReq);
|
||||||
|
|
||||||
|
enum {
|
||||||
|
RESTORE_TYPE__ALL = 1,
|
||||||
|
RESTORE_TYPE__MNODE,
|
||||||
|
RESTORE_TYPE__VNODE,
|
||||||
|
RESTORE_TYPE__QNODE,
|
||||||
|
};
|
||||||
|
|
||||||
|
typedef struct {
|
||||||
|
int32_t dnodeId;
|
||||||
|
int8_t restoreType;
|
||||||
|
} SRestoreDnodeReq;
|
||||||
|
|
||||||
|
int32_t tSerializeSRestoreDnodeReq(void* buf, int32_t bufLen, SRestoreDnodeReq* pReq);
|
||||||
|
int32_t tDeserializeSRestoreDnodeReq(void* buf, int32_t bufLen, SRestoreDnodeReq* pReq);
|
||||||
|
|
||||||
typedef struct {
|
typedef struct {
|
||||||
int32_t dnodeId;
|
int32_t dnodeId;
|
||||||
char config[TSDB_DNODE_CONFIG_LEN];
|
char config[TSDB_DNODE_CONFIG_LEN];
|
||||||
|
|
|
@ -178,6 +178,7 @@ enum {
|
||||||
// TD_DEF_MSG_TYPE(TDMT_MND_STREAM_BEGIN_CHECKPOINT, "stream-begin-checkpoint", NULL, NULL)
|
// TD_DEF_MSG_TYPE(TDMT_MND_STREAM_BEGIN_CHECKPOINT, "stream-begin-checkpoint", NULL, NULL)
|
||||||
TD_DEF_MSG_TYPE(TDMT_MND_MAX_MSG, "mnd-max", NULL, NULL)
|
TD_DEF_MSG_TYPE(TDMT_MND_MAX_MSG, "mnd-max", NULL, NULL)
|
||||||
TD_DEF_MSG_TYPE(TDMT_MND_BALANCE_VGROUP_LEADER, "balance-vgroup-leader", NULL, NULL)
|
TD_DEF_MSG_TYPE(TDMT_MND_BALANCE_VGROUP_LEADER, "balance-vgroup-leader", NULL, NULL)
|
||||||
|
TD_DEF_MSG_TYPE(TDMT_MND_RESTORE_DNODE, "restore-dnode", NULL, NULL)
|
||||||
|
|
||||||
TD_NEW_MSG_SEG(TDMT_VND_MSG)
|
TD_NEW_MSG_SEG(TDMT_VND_MSG)
|
||||||
TD_DEF_MSG_TYPE(TDMT_VND_SUBMIT, "submit", SSubmitReq, SSubmitRsp)
|
TD_DEF_MSG_TYPE(TDMT_VND_SUBMIT, "submit", SSubmitReq, SSubmitRsp)
|
||||||
|
|
|
@ -67,284 +67,287 @@
|
||||||
#define TK_DNODE 49
|
#define TK_DNODE 49
|
||||||
#define TK_PORT 50
|
#define TK_PORT 50
|
||||||
#define TK_DNODES 51
|
#define TK_DNODES 51
|
||||||
#define TK_NK_IPTOKEN 52
|
#define TK_RESTORE 52
|
||||||
#define TK_FORCE 53
|
#define TK_NK_IPTOKEN 53
|
||||||
#define TK_LOCAL 54
|
#define TK_FORCE 54
|
||||||
#define TK_QNODE 55
|
#define TK_LOCAL 55
|
||||||
#define TK_BNODE 56
|
#define TK_QNODE 56
|
||||||
#define TK_SNODE 57
|
#define TK_BNODE 57
|
||||||
#define TK_MNODE 58
|
#define TK_SNODE 58
|
||||||
#define TK_DATABASE 59
|
#define TK_MNODE 59
|
||||||
#define TK_USE 60
|
#define TK_VNODE 60
|
||||||
#define TK_FLUSH 61
|
#define TK_DATABASE 61
|
||||||
#define TK_TRIM 62
|
#define TK_USE 62
|
||||||
#define TK_COMPACT 63
|
#define TK_FLUSH 63
|
||||||
#define TK_IF 64
|
#define TK_TRIM 64
|
||||||
#define TK_NOT 65
|
#define TK_COMPACT 65
|
||||||
#define TK_EXISTS 66
|
#define TK_IF 66
|
||||||
#define TK_BUFFER 67
|
#define TK_NOT 67
|
||||||
#define TK_CACHEMODEL 68
|
#define TK_EXISTS 68
|
||||||
#define TK_CACHESIZE 69
|
#define TK_BUFFER 69
|
||||||
#define TK_COMP 70
|
#define TK_CACHEMODEL 70
|
||||||
#define TK_DURATION 71
|
#define TK_CACHESIZE 71
|
||||||
#define TK_NK_VARIABLE 72
|
#define TK_COMP 72
|
||||||
#define TK_MAXROWS 73
|
#define TK_DURATION 73
|
||||||
#define TK_MINROWS 74
|
#define TK_NK_VARIABLE 74
|
||||||
#define TK_KEEP 75
|
#define TK_MAXROWS 75
|
||||||
#define TK_PAGES 76
|
#define TK_MINROWS 76
|
||||||
#define TK_PAGESIZE 77
|
#define TK_KEEP 77
|
||||||
#define TK_TSDB_PAGESIZE 78
|
#define TK_PAGES 78
|
||||||
#define TK_PRECISION 79
|
#define TK_PAGESIZE 79
|
||||||
#define TK_REPLICA 80
|
#define TK_TSDB_PAGESIZE 80
|
||||||
#define TK_VGROUPS 81
|
#define TK_PRECISION 81
|
||||||
#define TK_SINGLE_STABLE 82
|
#define TK_REPLICA 82
|
||||||
#define TK_RETENTIONS 83
|
#define TK_VGROUPS 83
|
||||||
#define TK_SCHEMALESS 84
|
#define TK_SINGLE_STABLE 84
|
||||||
#define TK_WAL_LEVEL 85
|
#define TK_RETENTIONS 85
|
||||||
#define TK_WAL_FSYNC_PERIOD 86
|
#define TK_SCHEMALESS 86
|
||||||
#define TK_WAL_RETENTION_PERIOD 87
|
#define TK_WAL_LEVEL 87
|
||||||
#define TK_WAL_RETENTION_SIZE 88
|
#define TK_WAL_FSYNC_PERIOD 88
|
||||||
#define TK_WAL_ROLL_PERIOD 89
|
#define TK_WAL_RETENTION_PERIOD 89
|
||||||
#define TK_WAL_SEGMENT_SIZE 90
|
#define TK_WAL_RETENTION_SIZE 90
|
||||||
#define TK_STT_TRIGGER 91
|
#define TK_WAL_ROLL_PERIOD 91
|
||||||
#define TK_TABLE_PREFIX 92
|
#define TK_WAL_SEGMENT_SIZE 92
|
||||||
#define TK_TABLE_SUFFIX 93
|
#define TK_STT_TRIGGER 93
|
||||||
#define TK_NK_COLON 94
|
#define TK_TABLE_PREFIX 94
|
||||||
#define TK_MAX_SPEED 95
|
#define TK_TABLE_SUFFIX 95
|
||||||
#define TK_START 96
|
#define TK_NK_COLON 96
|
||||||
#define TK_TIMESTAMP 97
|
#define TK_MAX_SPEED 97
|
||||||
#define TK_END 98
|
#define TK_START 98
|
||||||
#define TK_TABLE 99
|
#define TK_TIMESTAMP 99
|
||||||
#define TK_NK_LP 100
|
#define TK_END 100
|
||||||
#define TK_NK_RP 101
|
#define TK_TABLE 101
|
||||||
#define TK_STABLE 102
|
#define TK_NK_LP 102
|
||||||
#define TK_ADD 103
|
#define TK_NK_RP 103
|
||||||
#define TK_COLUMN 104
|
#define TK_STABLE 104
|
||||||
#define TK_MODIFY 105
|
#define TK_ADD 105
|
||||||
#define TK_RENAME 106
|
#define TK_COLUMN 106
|
||||||
#define TK_TAG 107
|
#define TK_MODIFY 107
|
||||||
#define TK_SET 108
|
#define TK_RENAME 108
|
||||||
#define TK_NK_EQ 109
|
#define TK_TAG 109
|
||||||
#define TK_USING 110
|
#define TK_SET 110
|
||||||
#define TK_TAGS 111
|
#define TK_NK_EQ 111
|
||||||
#define TK_BOOL 112
|
#define TK_USING 112
|
||||||
#define TK_TINYINT 113
|
#define TK_TAGS 113
|
||||||
#define TK_SMALLINT 114
|
#define TK_BOOL 114
|
||||||
#define TK_INT 115
|
#define TK_TINYINT 115
|
||||||
#define TK_INTEGER 116
|
#define TK_SMALLINT 116
|
||||||
#define TK_BIGINT 117
|
#define TK_INT 117
|
||||||
#define TK_FLOAT 118
|
#define TK_INTEGER 118
|
||||||
#define TK_DOUBLE 119
|
#define TK_BIGINT 119
|
||||||
#define TK_BINARY 120
|
#define TK_FLOAT 120
|
||||||
#define TK_NCHAR 121
|
#define TK_DOUBLE 121
|
||||||
#define TK_UNSIGNED 122
|
#define TK_BINARY 122
|
||||||
#define TK_JSON 123
|
#define TK_NCHAR 123
|
||||||
#define TK_VARCHAR 124
|
#define TK_UNSIGNED 124
|
||||||
#define TK_MEDIUMBLOB 125
|
#define TK_JSON 125
|
||||||
#define TK_BLOB 126
|
#define TK_VARCHAR 126
|
||||||
#define TK_VARBINARY 127
|
#define TK_MEDIUMBLOB 127
|
||||||
#define TK_DECIMAL 128
|
#define TK_BLOB 128
|
||||||
#define TK_COMMENT 129
|
#define TK_VARBINARY 129
|
||||||
#define TK_MAX_DELAY 130
|
#define TK_DECIMAL 130
|
||||||
#define TK_WATERMARK 131
|
#define TK_COMMENT 131
|
||||||
#define TK_ROLLUP 132
|
#define TK_MAX_DELAY 132
|
||||||
#define TK_TTL 133
|
#define TK_WATERMARK 133
|
||||||
#define TK_SMA 134
|
#define TK_ROLLUP 134
|
||||||
#define TK_DELETE_MARK 135
|
#define TK_TTL 135
|
||||||
#define TK_FIRST 136
|
#define TK_SMA 136
|
||||||
#define TK_LAST 137
|
#define TK_DELETE_MARK 137
|
||||||
#define TK_SHOW 138
|
#define TK_FIRST 138
|
||||||
#define TK_PRIVILEGES 139
|
#define TK_LAST 139
|
||||||
#define TK_DATABASES 140
|
#define TK_SHOW 140
|
||||||
#define TK_TABLES 141
|
#define TK_PRIVILEGES 141
|
||||||
#define TK_STABLES 142
|
#define TK_DATABASES 142
|
||||||
#define TK_MNODES 143
|
#define TK_TABLES 143
|
||||||
#define TK_QNODES 144
|
#define TK_STABLES 144
|
||||||
#define TK_FUNCTIONS 145
|
#define TK_MNODES 145
|
||||||
#define TK_INDEXES 146
|
#define TK_QNODES 146
|
||||||
#define TK_ACCOUNTS 147
|
#define TK_FUNCTIONS 147
|
||||||
#define TK_APPS 148
|
#define TK_INDEXES 148
|
||||||
#define TK_CONNECTIONS 149
|
#define TK_ACCOUNTS 149
|
||||||
#define TK_LICENCES 150
|
#define TK_APPS 150
|
||||||
#define TK_GRANTS 151
|
#define TK_CONNECTIONS 151
|
||||||
#define TK_QUERIES 152
|
#define TK_LICENCES 152
|
||||||
#define TK_SCORES 153
|
#define TK_GRANTS 153
|
||||||
#define TK_TOPICS 154
|
#define TK_QUERIES 154
|
||||||
#define TK_VARIABLES 155
|
#define TK_SCORES 155
|
||||||
#define TK_CLUSTER 156
|
#define TK_TOPICS 156
|
||||||
#define TK_BNODES 157
|
#define TK_VARIABLES 157
|
||||||
#define TK_SNODES 158
|
#define TK_CLUSTER 158
|
||||||
#define TK_TRANSACTIONS 159
|
#define TK_BNODES 159
|
||||||
#define TK_DISTRIBUTED 160
|
#define TK_SNODES 160
|
||||||
#define TK_CONSUMERS 161
|
#define TK_TRANSACTIONS 161
|
||||||
#define TK_SUBSCRIPTIONS 162
|
#define TK_DISTRIBUTED 162
|
||||||
#define TK_VNODES 163
|
#define TK_CONSUMERS 163
|
||||||
#define TK_ALIVE 164
|
#define TK_SUBSCRIPTIONS 164
|
||||||
#define TK_LIKE 165
|
#define TK_VNODES 165
|
||||||
#define TK_TBNAME 166
|
#define TK_ALIVE 166
|
||||||
#define TK_QTAGS 167
|
#define TK_LIKE 167
|
||||||
#define TK_AS 168
|
#define TK_TBNAME 168
|
||||||
#define TK_INDEX 169
|
#define TK_QTAGS 169
|
||||||
#define TK_FUNCTION 170
|
#define TK_AS 170
|
||||||
#define TK_INTERVAL 171
|
#define TK_INDEX 171
|
||||||
#define TK_COUNT 172
|
#define TK_FUNCTION 172
|
||||||
#define TK_LAST_ROW 173
|
#define TK_INTERVAL 173
|
||||||
#define TK_TOPIC 174
|
#define TK_COUNT 174
|
||||||
#define TK_META 175
|
#define TK_LAST_ROW 175
|
||||||
#define TK_CONSUMER 176
|
#define TK_TOPIC 176
|
||||||
#define TK_GROUP 177
|
#define TK_META 177
|
||||||
#define TK_DESC 178
|
#define TK_CONSUMER 178
|
||||||
#define TK_DESCRIBE 179
|
#define TK_GROUP 179
|
||||||
#define TK_RESET 180
|
#define TK_DESC 180
|
||||||
#define TK_QUERY 181
|
#define TK_DESCRIBE 181
|
||||||
#define TK_CACHE 182
|
#define TK_RESET 182
|
||||||
#define TK_EXPLAIN 183
|
#define TK_QUERY 183
|
||||||
#define TK_ANALYZE 184
|
#define TK_CACHE 184
|
||||||
#define TK_VERBOSE 185
|
#define TK_EXPLAIN 185
|
||||||
#define TK_NK_BOOL 186
|
#define TK_ANALYZE 186
|
||||||
#define TK_RATIO 187
|
#define TK_VERBOSE 187
|
||||||
#define TK_NK_FLOAT 188
|
#define TK_NK_BOOL 188
|
||||||
#define TK_OUTPUTTYPE 189
|
#define TK_RATIO 189
|
||||||
#define TK_AGGREGATE 190
|
#define TK_NK_FLOAT 190
|
||||||
#define TK_BUFSIZE 191
|
#define TK_OUTPUTTYPE 191
|
||||||
#define TK_LANGUAGE 192
|
#define TK_AGGREGATE 192
|
||||||
#define TK_REPLACE 193
|
#define TK_BUFSIZE 193
|
||||||
#define TK_STREAM 194
|
#define TK_LANGUAGE 194
|
||||||
#define TK_INTO 195
|
#define TK_REPLACE 195
|
||||||
#define TK_TRIGGER 196
|
#define TK_STREAM 196
|
||||||
#define TK_AT_ONCE 197
|
#define TK_INTO 197
|
||||||
#define TK_WINDOW_CLOSE 198
|
#define TK_TRIGGER 198
|
||||||
#define TK_IGNORE 199
|
#define TK_AT_ONCE 199
|
||||||
#define TK_EXPIRED 200
|
#define TK_WINDOW_CLOSE 200
|
||||||
#define TK_FILL_HISTORY 201
|
#define TK_IGNORE 201
|
||||||
#define TK_UPDATE 202
|
#define TK_EXPIRED 202
|
||||||
#define TK_SUBTABLE 203
|
#define TK_FILL_HISTORY 203
|
||||||
#define TK_KILL 204
|
#define TK_UPDATE 204
|
||||||
#define TK_CONNECTION 205
|
#define TK_SUBTABLE 205
|
||||||
#define TK_TRANSACTION 206
|
#define TK_KILL 206
|
||||||
#define TK_BALANCE 207
|
#define TK_CONNECTION 207
|
||||||
#define TK_VGROUP 208
|
#define TK_TRANSACTION 208
|
||||||
#define TK_LEADER 209
|
#define TK_BALANCE 209
|
||||||
#define TK_MERGE 210
|
#define TK_VGROUP 210
|
||||||
#define TK_REDISTRIBUTE 211
|
#define TK_LEADER 211
|
||||||
#define TK_SPLIT 212
|
#define TK_MERGE 212
|
||||||
#define TK_DELETE 213
|
#define TK_REDISTRIBUTE 213
|
||||||
#define TK_INSERT 214
|
#define TK_SPLIT 214
|
||||||
#define TK_NULL 215
|
#define TK_DELETE 215
|
||||||
#define TK_NK_QUESTION 216
|
#define TK_INSERT 216
|
||||||
#define TK_NK_ARROW 217
|
#define TK_NULL 217
|
||||||
#define TK_ROWTS 218
|
#define TK_NK_QUESTION 218
|
||||||
#define TK_QSTART 219
|
#define TK_NK_ARROW 219
|
||||||
#define TK_QEND 220
|
#define TK_ROWTS 220
|
||||||
#define TK_QDURATION 221
|
#define TK_QSTART 221
|
||||||
#define TK_WSTART 222
|
#define TK_QEND 222
|
||||||
#define TK_WEND 223
|
#define TK_QDURATION 223
|
||||||
#define TK_WDURATION 224
|
#define TK_WSTART 224
|
||||||
#define TK_IROWTS 225
|
#define TK_WEND 225
|
||||||
#define TK_ISFILLED 226
|
#define TK_WDURATION 226
|
||||||
#define TK_CAST 227
|
#define TK_IROWTS 227
|
||||||
#define TK_NOW 228
|
#define TK_ISFILLED 228
|
||||||
#define TK_TODAY 229
|
#define TK_CAST 229
|
||||||
#define TK_TIMEZONE 230
|
#define TK_NOW 230
|
||||||
#define TK_CLIENT_VERSION 231
|
#define TK_TODAY 231
|
||||||
#define TK_SERVER_VERSION 232
|
#define TK_TIMEZONE 232
|
||||||
#define TK_SERVER_STATUS 233
|
#define TK_CLIENT_VERSION 233
|
||||||
#define TK_CURRENT_USER 234
|
#define TK_SERVER_VERSION 234
|
||||||
#define TK_CASE 235
|
#define TK_SERVER_STATUS 235
|
||||||
#define TK_WHEN 236
|
#define TK_CURRENT_USER 236
|
||||||
#define TK_THEN 237
|
#define TK_CASE 237
|
||||||
#define TK_ELSE 238
|
#define TK_WHEN 238
|
||||||
#define TK_BETWEEN 239
|
#define TK_THEN 239
|
||||||
#define TK_IS 240
|
#define TK_ELSE 240
|
||||||
#define TK_NK_LT 241
|
#define TK_BETWEEN 241
|
||||||
#define TK_NK_GT 242
|
#define TK_IS 242
|
||||||
#define TK_NK_LE 243
|
#define TK_NK_LT 243
|
||||||
#define TK_NK_GE 244
|
#define TK_NK_GT 244
|
||||||
#define TK_NK_NE 245
|
#define TK_NK_LE 245
|
||||||
#define TK_MATCH 246
|
#define TK_NK_GE 246
|
||||||
#define TK_NMATCH 247
|
#define TK_NK_NE 247
|
||||||
#define TK_CONTAINS 248
|
#define TK_MATCH 248
|
||||||
#define TK_IN 249
|
#define TK_NMATCH 249
|
||||||
#define TK_JOIN 250
|
#define TK_CONTAINS 250
|
||||||
#define TK_INNER 251
|
#define TK_IN 251
|
||||||
#define TK_SELECT 252
|
#define TK_JOIN 252
|
||||||
#define TK_DISTINCT 253
|
#define TK_INNER 253
|
||||||
#define TK_WHERE 254
|
#define TK_SELECT 254
|
||||||
#define TK_PARTITION 255
|
#define TK_DISTINCT 255
|
||||||
#define TK_BY 256
|
#define TK_WHERE 256
|
||||||
#define TK_SESSION 257
|
#define TK_PARTITION 257
|
||||||
#define TK_STATE_WINDOW 258
|
#define TK_BY 258
|
||||||
#define TK_EVENT_WINDOW 259
|
#define TK_SESSION 259
|
||||||
#define TK_SLIDING 260
|
#define TK_STATE_WINDOW 260
|
||||||
#define TK_FILL 261
|
#define TK_EVENT_WINDOW 261
|
||||||
#define TK_VALUE 262
|
#define TK_SLIDING 262
|
||||||
#define TK_VALUE_F 263
|
#define TK_FILL 263
|
||||||
#define TK_NONE 264
|
#define TK_VALUE 264
|
||||||
#define TK_PREV 265
|
#define TK_VALUE_F 265
|
||||||
#define TK_NULL_F 266
|
#define TK_NONE 266
|
||||||
#define TK_LINEAR 267
|
#define TK_PREV 267
|
||||||
#define TK_NEXT 268
|
#define TK_NULL_F 268
|
||||||
#define TK_HAVING 269
|
#define TK_LINEAR 269
|
||||||
#define TK_RANGE 270
|
#define TK_NEXT 270
|
||||||
#define TK_EVERY 271
|
#define TK_HAVING 271
|
||||||
#define TK_ORDER 272
|
#define TK_RANGE 272
|
||||||
#define TK_SLIMIT 273
|
#define TK_EVERY 273
|
||||||
#define TK_SOFFSET 274
|
#define TK_ORDER 274
|
||||||
#define TK_LIMIT 275
|
#define TK_SLIMIT 275
|
||||||
#define TK_OFFSET 276
|
#define TK_SOFFSET 276
|
||||||
#define TK_ASC 277
|
#define TK_LIMIT 277
|
||||||
#define TK_NULLS 278
|
#define TK_OFFSET 278
|
||||||
#define TK_ABORT 279
|
#define TK_ASC 279
|
||||||
#define TK_AFTER 280
|
#define TK_NULLS 280
|
||||||
#define TK_ATTACH 281
|
#define TK_ABORT 281
|
||||||
#define TK_BEFORE 282
|
#define TK_AFTER 282
|
||||||
#define TK_BEGIN 283
|
#define TK_ATTACH 283
|
||||||
#define TK_BITAND 284
|
#define TK_BEFORE 284
|
||||||
#define TK_BITNOT 285
|
#define TK_BEGIN 285
|
||||||
#define TK_BITOR 286
|
#define TK_BITAND 286
|
||||||
#define TK_BLOCKS 287
|
#define TK_BITNOT 287
|
||||||
#define TK_CHANGE 288
|
#define TK_BITOR 288
|
||||||
#define TK_COMMA 289
|
#define TK_BLOCKS 289
|
||||||
#define TK_CONCAT 290
|
#define TK_CHANGE 290
|
||||||
#define TK_CONFLICT 291
|
#define TK_COMMA 291
|
||||||
#define TK_COPY 292
|
#define TK_CONCAT 292
|
||||||
#define TK_DEFERRED 293
|
#define TK_CONFLICT 293
|
||||||
#define TK_DELIMITERS 294
|
#define TK_COPY 294
|
||||||
#define TK_DETACH 295
|
#define TK_DEFERRED 295
|
||||||
#define TK_DIVIDE 296
|
#define TK_DELIMITERS 296
|
||||||
#define TK_DOT 297
|
#define TK_DETACH 297
|
||||||
#define TK_EACH 298
|
#define TK_DIVIDE 298
|
||||||
#define TK_FAIL 299
|
#define TK_DOT 299
|
||||||
#define TK_FILE 300
|
#define TK_EACH 300
|
||||||
#define TK_FOR 301
|
#define TK_FAIL 301
|
||||||
#define TK_GLOB 302
|
#define TK_FILE 302
|
||||||
#define TK_ID 303
|
#define TK_FOR 303
|
||||||
#define TK_IMMEDIATE 304
|
#define TK_GLOB 304
|
||||||
#define TK_IMPORT 305
|
#define TK_ID 305
|
||||||
#define TK_INITIALLY 306
|
#define TK_IMMEDIATE 306
|
||||||
#define TK_INSTEAD 307
|
#define TK_IMPORT 307
|
||||||
#define TK_ISNULL 308
|
#define TK_INITIALLY 308
|
||||||
#define TK_KEY 309
|
#define TK_INSTEAD 309
|
||||||
#define TK_MODULES 310
|
#define TK_ISNULL 310
|
||||||
#define TK_NK_BITNOT 311
|
#define TK_KEY 311
|
||||||
#define TK_NK_SEMI 312
|
#define TK_MODULES 312
|
||||||
#define TK_NOTNULL 313
|
#define TK_NK_BITNOT 313
|
||||||
#define TK_OF 314
|
#define TK_NK_SEMI 314
|
||||||
#define TK_PLUS 315
|
#define TK_NOTNULL 315
|
||||||
#define TK_PRIVILEGE 316
|
#define TK_OF 316
|
||||||
#define TK_RAISE 317
|
#define TK_PLUS 317
|
||||||
#define TK_RESTRICT 318
|
#define TK_PRIVILEGE 318
|
||||||
#define TK_ROW 319
|
#define TK_RAISE 319
|
||||||
#define TK_SEMI 320
|
#define TK_RESTRICT 320
|
||||||
#define TK_STAR 321
|
#define TK_ROW 321
|
||||||
#define TK_STATEMENT 322
|
#define TK_SEMI 322
|
||||||
#define TK_STRICT 323
|
#define TK_STAR 323
|
||||||
#define TK_STRING 324
|
#define TK_STATEMENT 324
|
||||||
#define TK_TIMES 325
|
#define TK_STRICT 325
|
||||||
#define TK_VALUES 326
|
#define TK_STRING 326
|
||||||
#define TK_VARIABLE 327
|
#define TK_TIMES 327
|
||||||
#define TK_VIEW 328
|
#define TK_VALUES 328
|
||||||
#define TK_WAL 329
|
#define TK_VARIABLE 329
|
||||||
|
#define TK_VIEW 330
|
||||||
|
#define TK_WAL 331
|
||||||
|
|
||||||
|
|
||||||
#define TK_NK_SPACE 600
|
#define TK_NK_SPACE 600
|
||||||
#define TK_NK_COMMENT 601
|
#define TK_NK_COMMENT 601
|
||||||
|
|
|
@ -350,6 +350,11 @@ typedef struct SDropComponentNodeStmt {
|
||||||
int32_t dnodeId;
|
int32_t dnodeId;
|
||||||
} SDropComponentNodeStmt;
|
} SDropComponentNodeStmt;
|
||||||
|
|
||||||
|
typedef struct SRestoreComponentNodeStmt {
|
||||||
|
ENodeType type;
|
||||||
|
int32_t dnodeId;
|
||||||
|
} SRestoreComponentNodeStmt;
|
||||||
|
|
||||||
typedef struct SCreateTopicStmt {
|
typedef struct SCreateTopicStmt {
|
||||||
ENodeType type;
|
ENodeType type;
|
||||||
char topicName[TSDB_TABLE_NAME_LEN];
|
char topicName[TSDB_TABLE_NAME_LEN];
|
||||||
|
|
|
@ -211,6 +211,10 @@ typedef enum ENodeType {
|
||||||
QUERY_NODE_SHOW_DB_ALIVE_STMT,
|
QUERY_NODE_SHOW_DB_ALIVE_STMT,
|
||||||
QUERY_NODE_SHOW_CLUSTER_ALIVE_STMT,
|
QUERY_NODE_SHOW_CLUSTER_ALIVE_STMT,
|
||||||
QUERY_NODE_BALANCE_VGROUP_LEADER_STMT,
|
QUERY_NODE_BALANCE_VGROUP_LEADER_STMT,
|
||||||
|
QUERY_NODE_RESTORE_DNODE_STMT,
|
||||||
|
QUERY_NODE_RESTORE_QNODE_STMT,
|
||||||
|
QUERY_NODE_RESTORE_MNODE_STMT,
|
||||||
|
QUERY_NODE_RESTORE_VNODE_STMT,
|
||||||
|
|
||||||
// logic plan node
|
// logic plan node
|
||||||
QUERY_NODE_LOGIC_PLAN_SCAN = 1000,
|
QUERY_NODE_LOGIC_PLAN_SCAN = 1000,
|
||||||
|
|
|
@ -133,6 +133,16 @@ int32_t tfsMkdirAt(STfs *pTfs, const char *rname, SDiskID diskId);
|
||||||
*/
|
*/
|
||||||
int32_t tfsMkdirRecurAt(STfs *pTfs, const char *rname, SDiskID diskId);
|
int32_t tfsMkdirRecurAt(STfs *pTfs, const char *rname, SDiskID diskId);
|
||||||
|
|
||||||
|
/**
|
||||||
|
* @brief check directories exist in tfs.
|
||||||
|
*
|
||||||
|
* @param pTfs The fs object.
|
||||||
|
* @param rname The rel name of directory.
|
||||||
|
* @param diskId The disk ID.
|
||||||
|
* @return true for exist, false for not exist.
|
||||||
|
*/
|
||||||
|
bool tfsDirExistAt(STfs *pTfs, const char *rname, SDiskID diskId);
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* @brief Remove directory at all levels in tfs.
|
* @brief Remove directory at all levels in tfs.
|
||||||
*
|
*
|
||||||
|
|
|
@ -406,6 +406,7 @@ int32_t* taosGetErrno();
|
||||||
#define TSDB_CODE_SNODE_NOT_DEPLOYED TAOS_DEF_ERROR_CODE(0, 0x0411)
|
#define TSDB_CODE_SNODE_NOT_DEPLOYED TAOS_DEF_ERROR_CODE(0, 0x0411)
|
||||||
#define TSDB_CODE_MNODE_NOT_CATCH_UP TAOS_DEF_ERROR_CODE(0, 0x0412) // internal
|
#define TSDB_CODE_MNODE_NOT_CATCH_UP TAOS_DEF_ERROR_CODE(0, 0x0412) // internal
|
||||||
#define TSDB_CODE_MNODE_ALREADY_IS_VOTER TAOS_DEF_ERROR_CODE(0, 0x0413) // internal
|
#define TSDB_CODE_MNODE_ALREADY_IS_VOTER TAOS_DEF_ERROR_CODE(0, 0x0413) // internal
|
||||||
|
#define TSDB_CODE_MNODE_ONLY_TWO_MNODE TAOS_DEF_ERROR_CODE(0, 0x0414) // internal
|
||||||
|
|
||||||
// vnode
|
// vnode
|
||||||
// #define TSDB_CODE_VND_ACTION_IN_PROGRESS TAOS_DEF_ERROR_CODE(0, 0x0500) // 2.x
|
// #define TSDB_CODE_VND_ACTION_IN_PROGRESS TAOS_DEF_ERROR_CODE(0, 0x0500) // 2.x
|
||||||
|
@ -442,6 +443,7 @@ int32_t* taosGetErrno();
|
||||||
#define TSDB_CODE_VND_QUERY_BUSY TAOS_DEF_ERROR_CODE(0, 0x0531)
|
#define TSDB_CODE_VND_QUERY_BUSY TAOS_DEF_ERROR_CODE(0, 0x0531)
|
||||||
#define TSDB_CODE_VND_NOT_CATCH_UP TAOS_DEF_ERROR_CODE(0, 0x0532) // internal
|
#define TSDB_CODE_VND_NOT_CATCH_UP TAOS_DEF_ERROR_CODE(0, 0x0532) // internal
|
||||||
#define TSDB_CODE_VND_ALREADY_IS_VOTER TAOS_DEF_ERROR_CODE(0, 0x0533) // internal
|
#define TSDB_CODE_VND_ALREADY_IS_VOTER TAOS_DEF_ERROR_CODE(0, 0x0533) // internal
|
||||||
|
#define TSDB_CODE_VND_DIR_ALREADY_EXIST TAOS_DEF_ERROR_CODE(0, 0x0534)
|
||||||
|
|
||||||
// tsdb
|
// tsdb
|
||||||
#define TSDB_CODE_TDB_INVALID_TABLE_ID TAOS_DEF_ERROR_CODE(0, 0x0600)
|
#define TSDB_CODE_TDB_INVALID_TABLE_ID TAOS_DEF_ERROR_CODE(0, 0x0600)
|
||||||
|
|
|
@ -1720,6 +1720,33 @@ int32_t tDeserializeSDropDnodeReq(void *buf, int32_t bufLen, SDropDnodeReq *pReq
|
||||||
return 0;
|
return 0;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
int32_t tSerializeSRestoreDnodeReq(void *buf, int32_t bufLen, SRestoreDnodeReq *pReq) {
|
||||||
|
SEncoder encoder = {0};
|
||||||
|
tEncoderInit(&encoder, buf, bufLen);
|
||||||
|
|
||||||
|
if (tStartEncode(&encoder) < 0) return -1;
|
||||||
|
if (tEncodeI32(&encoder, pReq->dnodeId) < 0) return -1;
|
||||||
|
if (tEncodeI8(&encoder, pReq->restoreType) < 0) return -1;
|
||||||
|
tEndEncode(&encoder);
|
||||||
|
|
||||||
|
int32_t tlen = encoder.pos;
|
||||||
|
tEncoderClear(&encoder);
|
||||||
|
return tlen;
|
||||||
|
}
|
||||||
|
|
||||||
|
int32_t tDeserializeSRestoreDnodeReq(void *buf, int32_t bufLen, SRestoreDnodeReq *pReq) {
|
||||||
|
SDecoder decoder = {0};
|
||||||
|
tDecoderInit(&decoder, buf, bufLen);
|
||||||
|
|
||||||
|
if (tStartDecode(&decoder) < 0) return -1;
|
||||||
|
if (tDecodeI32(&decoder, &pReq->dnodeId) < 0) return -1;
|
||||||
|
if (tDecodeI8(&decoder, &pReq->restoreType) < 0) return -1;
|
||||||
|
tEndDecode(&decoder);
|
||||||
|
|
||||||
|
tDecoderClear(&decoder);
|
||||||
|
return 0;
|
||||||
|
}
|
||||||
|
|
||||||
int32_t tSerializeSMCfgDnodeReq(void *buf, int32_t bufLen, SMCfgDnodeReq *pReq) {
|
int32_t tSerializeSMCfgDnodeReq(void *buf, int32_t bufLen, SMCfgDnodeReq *pReq) {
|
||||||
SEncoder encoder = {0};
|
SEncoder encoder = {0};
|
||||||
tEncoderInit(&encoder, buf, bufLen);
|
tEncoderInit(&encoder, buf, bufLen);
|
||||||
|
|
|
@ -174,6 +174,7 @@ SArray *mmGetMsgHandles() {
|
||||||
if (dmSetMgmtHandle(pArray, TDMT_MND_SERVER_VERSION, mmPutMsgToReadQueue, 0) == NULL) goto _OVER;
|
if (dmSetMgmtHandle(pArray, TDMT_MND_SERVER_VERSION, mmPutMsgToReadQueue, 0) == NULL) goto _OVER;
|
||||||
if (dmSetMgmtHandle(pArray, TDMT_MND_CREATE_INDEX, mmPutMsgToWriteQueue, 0) == NULL) goto _OVER;
|
if (dmSetMgmtHandle(pArray, TDMT_MND_CREATE_INDEX, mmPutMsgToWriteQueue, 0) == NULL) goto _OVER;
|
||||||
if (dmSetMgmtHandle(pArray, TDMT_MND_DROP_INDEX, mmPutMsgToWriteQueue, 0) == NULL) goto _OVER;
|
if (dmSetMgmtHandle(pArray, TDMT_MND_DROP_INDEX, mmPutMsgToWriteQueue, 0) == NULL) goto _OVER;
|
||||||
|
if (dmSetMgmtHandle(pArray, TDMT_MND_RESTORE_DNODE, mmPutMsgToWriteQueue, 0) == NULL) goto _OVER;
|
||||||
|
|
||||||
if (dmSetMgmtHandle(pArray, TDMT_SCH_QUERY, mmPutMsgToQueryQueue, 1) == NULL) goto _OVER;
|
if (dmSetMgmtHandle(pArray, TDMT_SCH_QUERY, mmPutMsgToQueryQueue, 1) == NULL) goto _OVER;
|
||||||
if (dmSetMgmtHandle(pArray, TDMT_SCH_MERGE_QUERY, mmPutMsgToQueryQueue, 1) == NULL) goto _OVER;
|
if (dmSetMgmtHandle(pArray, TDMT_SCH_MERGE_QUERY, mmPutMsgToQueryQueue, 1) == NULL) goto _OVER;
|
||||||
|
|
|
@ -255,7 +255,7 @@ int32_t vmProcessCreateVnodeReq(SVnodeMgmt *pMgmt, SRpcMsg *pMsg) {
|
||||||
|
|
||||||
SVnodeObj *pVnode = vmAcquireVnode(pMgmt, req.vgId);
|
SVnodeObj *pVnode = vmAcquireVnode(pMgmt, req.vgId);
|
||||||
if (pVnode != NULL) {
|
if (pVnode != NULL) {
|
||||||
dInfo("vgId:%d, already exist", req.vgId);
|
dError("vgId:%d, already exist", req.vgId);
|
||||||
tFreeSCreateVnodeReq(&req);
|
tFreeSCreateVnodeReq(&req);
|
||||||
vmReleaseVnode(pMgmt, pVnode);
|
vmReleaseVnode(pMgmt, pVnode);
|
||||||
terrno = TSDB_CODE_VND_ALREADY_EXIST;
|
terrno = TSDB_CODE_VND_ALREADY_EXIST;
|
||||||
|
@ -264,6 +264,21 @@ int32_t vmProcessCreateVnodeReq(SVnodeMgmt *pMgmt, SRpcMsg *pMsg) {
|
||||||
}
|
}
|
||||||
|
|
||||||
snprintf(path, TSDB_FILENAME_LEN, "vnode%svnode%d", TD_DIRSEP, vnodeCfg.vgId);
|
snprintf(path, TSDB_FILENAME_LEN, "vnode%svnode%d", TD_DIRSEP, vnodeCfg.vgId);
|
||||||
|
|
||||||
|
if (pMgmt->pTfs) {
|
||||||
|
if (tfsDirExistAt(pMgmt->pTfs, path, (SDiskID){0})) {
|
||||||
|
terrno = TSDB_CODE_VND_DIR_ALREADY_EXIST;
|
||||||
|
dError("vgId:%d, failed to restore vnode since %s", req.vgId, terrstr());
|
||||||
|
return -1;
|
||||||
|
}
|
||||||
|
} else {
|
||||||
|
if (taosDirExist(path)) {
|
||||||
|
terrno = TSDB_CODE_VND_DIR_ALREADY_EXIST;
|
||||||
|
dError("vgId:%d, failed to restore vnode since %s", req.vgId, terrstr());
|
||||||
|
return -1;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
if (vnodeCreate(path, &vnodeCfg, pMgmt->pTfs) < 0) {
|
if (vnodeCreate(path, &vnodeCfg, pMgmt->pTfs) < 0) {
|
||||||
tFreeSCreateVnodeReq(&req);
|
tFreeSCreateVnodeReq(&req);
|
||||||
dError("vgId:%d, failed to create vnode since %s", req.vgId, terrstr());
|
dError("vgId:%d, failed to create vnode since %s", req.vgId, terrstr());
|
||||||
|
@ -344,6 +359,7 @@ int32_t vmProcessAlterVnodeTypeReq(SVnodeMgmt *pMgmt, SRpcMsg *pMsg) {
|
||||||
ESyncRole role = vnodeGetRole(pVnode->pImpl);
|
ESyncRole role = vnodeGetRole(pVnode->pImpl);
|
||||||
dInfo("vgId:%d, checking node role:%d", req.vgId, role);
|
dInfo("vgId:%d, checking node role:%d", req.vgId, role);
|
||||||
if(role == TAOS_SYNC_ROLE_VOTER){
|
if(role == TAOS_SYNC_ROLE_VOTER){
|
||||||
|
dError("vgId:%d, failed to alter vnode type since node already is role:%d", req.vgId, role);
|
||||||
terrno = TSDB_CODE_VND_ALREADY_IS_VOTER;
|
terrno = TSDB_CODE_VND_ALREADY_IS_VOTER;
|
||||||
vmReleaseVnode(pMgmt, pVnode);
|
vmReleaseVnode(pMgmt, pVnode);
|
||||||
return -1;
|
return -1;
|
||||||
|
|
|
@ -218,6 +218,7 @@ static int32_t dmProcessAlterNodeTypeReq(EDndNodeType ntype, SRpcMsg *pMsg) {
|
||||||
ESyncRole role = (*pWrapper->func.nodeRoleFp)(pWrapper->pMgmt);
|
ESyncRole role = (*pWrapper->func.nodeRoleFp)(pWrapper->pMgmt);
|
||||||
dInfo("node:%s, checking node role:%d", pWrapper->name, role);
|
dInfo("node:%s, checking node role:%d", pWrapper->name, role);
|
||||||
if(role == TAOS_SYNC_ROLE_VOTER){
|
if(role == TAOS_SYNC_ROLE_VOTER){
|
||||||
|
dError("node:%s, failed to alter node type since node already is role:%d", pWrapper->name, role);
|
||||||
terrno = TSDB_CODE_MNODE_ALREADY_IS_VOTER;
|
terrno = TSDB_CODE_MNODE_ALREADY_IS_VOTER;
|
||||||
return -1;
|
return -1;
|
||||||
}
|
}
|
||||||
|
|
|
@ -6,6 +6,7 @@ IF (TD_ENTERPRISE)
|
||||||
LIST(APPEND MNODE_SRC ${TD_ENTERPRISE_DIR}/src/plugins/privilege/src/privilege.c)
|
LIST(APPEND MNODE_SRC ${TD_ENTERPRISE_DIR}/src/plugins/privilege/src/privilege.c)
|
||||||
LIST(APPEND MNODE_SRC ${TD_ENTERPRISE_DIR}/src/plugins/mnode/src/mndDb.c)
|
LIST(APPEND MNODE_SRC ${TD_ENTERPRISE_DIR}/src/plugins/mnode/src/mndDb.c)
|
||||||
LIST(APPEND MNODE_SRC ${TD_ENTERPRISE_DIR}/src/plugins/mnode/src/mndVgroup.c)
|
LIST(APPEND MNODE_SRC ${TD_ENTERPRISE_DIR}/src/plugins/mnode/src/mndVgroup.c)
|
||||||
|
LIST(APPEND MNODE_SRC ${TD_ENTERPRISE_DIR}/src/plugins/mnode/src/mndDnode.c)
|
||||||
ENDIF ()
|
ENDIF ()
|
||||||
|
|
||||||
add_library(mnode STATIC ${MNODE_SRC})
|
add_library(mnode STATIC ${MNODE_SRC})
|
||||||
|
|
|
@ -29,6 +29,10 @@ void mndReleaseMnode(SMnode *pMnode, SMnodeObj *pObj);
|
||||||
bool mndIsMnode(SMnode *pMnode, int32_t dnodeId);
|
bool mndIsMnode(SMnode *pMnode, int32_t dnodeId);
|
||||||
void mndGetMnodeEpSet(SMnode *pMnode, SEpSet *pEpSet);
|
void mndGetMnodeEpSet(SMnode *pMnode, SEpSet *pEpSet);
|
||||||
int32_t mndSetDropMnodeInfoToTrans(SMnode *pMnode, STrans *pTrans, SMnodeObj *pObj, bool force);
|
int32_t mndSetDropMnodeInfoToTrans(SMnode *pMnode, STrans *pTrans, SMnodeObj *pObj, bool force);
|
||||||
|
int32_t mndSetRestoreCreateMnodeRedoActions(SMnode *pMnode, STrans *pTrans, SDnodeObj *pDnode, SMnodeObj *pObj);
|
||||||
|
int32_t mndSetCreateMnodeCommitLogs(SMnode *pMnode, STrans *pTrans, SMnodeObj *pObj);
|
||||||
|
int32_t mndSetRestoreAlterMnodeTypeRedoActions(SMnode *pMnode, STrans *pTrans, SDnodeObj *pDnode, SMnodeObj *pObj);
|
||||||
|
int32_t mndSetRestoreCreateMnodeRedoLogs(SMnode *pMnode, STrans *pTrans, SMnodeObj *pObj);
|
||||||
|
|
||||||
#ifdef __cplusplus
|
#ifdef __cplusplus
|
||||||
}
|
}
|
||||||
|
|
|
@ -30,6 +30,9 @@ SQnodeObj *mndAcquireQnode(SMnode *pMnode, int32_t qnodeId);
|
||||||
void mndReleaseQnode(SMnode *pMnode, SQnodeObj *pObj);
|
void mndReleaseQnode(SMnode *pMnode, SQnodeObj *pObj);
|
||||||
int32_t mndCreateQnodeList(SMnode *pMnode, SArray **pList, int32_t limit);
|
int32_t mndCreateQnodeList(SMnode *pMnode, SArray **pList, int32_t limit);
|
||||||
int32_t mndSetDropQnodeInfoToTrans(SMnode *pMnode, STrans *pTrans, SQnodeObj *pObj, bool force);
|
int32_t mndSetDropQnodeInfoToTrans(SMnode *pMnode, STrans *pTrans, SQnodeObj *pObj, bool force);
|
||||||
|
bool mndQnodeInDnode(SQnodeObj *pQnode, int32_t dnodeId);
|
||||||
|
int32_t mndSetCreateQnodeCommitLogs(STrans *pTrans, SQnodeObj *pObj);
|
||||||
|
int32_t mndSetCreateQnodeRedoActions(STrans *pTrans, SDnodeObj *pDnode, SQnodeObj *pObj);
|
||||||
|
|
||||||
#ifdef __cplusplus
|
#ifdef __cplusplus
|
||||||
}
|
}
|
||||||
|
|
|
@ -49,6 +49,9 @@ int32_t mndBuildCompactVgroupAction(SMnode *pMnode, STrans *pTrans, SDbObj *pDb,
|
||||||
void *mndBuildCreateVnodeReq(SMnode *, SDnodeObj *pDnode, SDbObj *pDb, SVgObj *pVgroup, int32_t *pContLen);
|
void *mndBuildCreateVnodeReq(SMnode *, SDnodeObj *pDnode, SDbObj *pDb, SVgObj *pVgroup, int32_t *pContLen);
|
||||||
void *mndBuildDropVnodeReq(SMnode *, SDnodeObj *pDnode, SDbObj *pDb, SVgObj *pVgroup, int32_t *pContLen);
|
void *mndBuildDropVnodeReq(SMnode *, SDnodeObj *pDnode, SDbObj *pDb, SVgObj *pVgroup, int32_t *pContLen);
|
||||||
bool mndVgroupInDb(SVgObj *pVgroup, int64_t dbUid);
|
bool mndVgroupInDb(SVgObj *pVgroup, int64_t dbUid);
|
||||||
|
bool mndVgroupInDnode(SVgObj *pVgroup, int32_t dnodeId);
|
||||||
|
int32_t mndBuildRestoreAlterVgroupAction(SMnode *pMnode, STrans *pTrans, SDbObj *db, SVgObj *pVgroup,
|
||||||
|
SDnodeObj *pDnode);
|
||||||
|
|
||||||
int32_t mndSplitVgroup(SMnode *pMnode, SRpcMsg *pReq, SDbObj *pDb, SVgObj *pVgroup);
|
int32_t mndSplitVgroup(SMnode *pMnode, SRpcMsg *pReq, SDbObj *pDb, SVgObj *pVgroup);
|
||||||
|
|
||||||
|
|
|
@ -58,6 +58,7 @@ static int32_t mndProcessDropDnodeReq(SRpcMsg *pReq);
|
||||||
static int32_t mndProcessConfigDnodeReq(SRpcMsg *pReq);
|
static int32_t mndProcessConfigDnodeReq(SRpcMsg *pReq);
|
||||||
static int32_t mndProcessConfigDnodeRsp(SRpcMsg *pRsp);
|
static int32_t mndProcessConfigDnodeRsp(SRpcMsg *pRsp);
|
||||||
static int32_t mndProcessStatusReq(SRpcMsg *pReq);
|
static int32_t mndProcessStatusReq(SRpcMsg *pReq);
|
||||||
|
static int32_t mndProcessRestoreDnodeReq(SRpcMsg *pReq);
|
||||||
|
|
||||||
static int32_t mndRetrieveConfigs(SRpcMsg *pReq, SShowObj *pShow, SSDataBlock *pBlock, int32_t rows);
|
static int32_t mndRetrieveConfigs(SRpcMsg *pReq, SShowObj *pShow, SSDataBlock *pBlock, int32_t rows);
|
||||||
static void mndCancelGetNextConfig(SMnode *pMnode, void *pIter);
|
static void mndCancelGetNextConfig(SMnode *pMnode, void *pIter);
|
||||||
|
@ -83,6 +84,7 @@ int32_t mndInitDnode(SMnode *pMnode) {
|
||||||
mndSetMsgHandle(pMnode, TDMT_MND_STATUS, mndProcessStatusReq);
|
mndSetMsgHandle(pMnode, TDMT_MND_STATUS, mndProcessStatusReq);
|
||||||
mndSetMsgHandle(pMnode, TDMT_MND_DNODE_LIST, mndProcessDnodeListReq);
|
mndSetMsgHandle(pMnode, TDMT_MND_DNODE_LIST, mndProcessDnodeListReq);
|
||||||
mndSetMsgHandle(pMnode, TDMT_MND_SHOW_VARIABLES, mndProcessShowVariablesReq);
|
mndSetMsgHandle(pMnode, TDMT_MND_SHOW_VARIABLES, mndProcessShowVariablesReq);
|
||||||
|
mndSetMsgHandle(pMnode, TDMT_MND_RESTORE_DNODE, mndProcessRestoreDnodeReq);
|
||||||
|
|
||||||
mndAddShowRetrieveHandle(pMnode, TSDB_MGMT_TABLE_CONFIGS, mndRetrieveConfigs);
|
mndAddShowRetrieveHandle(pMnode, TSDB_MGMT_TABLE_CONFIGS, mndRetrieveConfigs);
|
||||||
mndAddShowFreeIterHandle(pMnode, TSDB_MGMT_TABLE_CONFIGS, mndCancelGetNextConfig);
|
mndAddShowFreeIterHandle(pMnode, TSDB_MGMT_TABLE_CONFIGS, mndCancelGetNextConfig);
|
||||||
|
@ -294,6 +296,11 @@ int32_t mndGetDnodeSize(SMnode *pMnode) {
|
||||||
return sdbGetSize(pSdb, SDB_DNODE);
|
return sdbGetSize(pSdb, SDB_DNODE);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
int32_t mndGetDbSize(SMnode *pMnode) {
|
||||||
|
SSdb *pSdb = pMnode->pSdb;
|
||||||
|
return sdbGetSize(pSdb, SDB_DB);
|
||||||
|
}
|
||||||
|
|
||||||
bool mndIsDnodeOnline(SDnodeObj *pDnode, int64_t curMs) {
|
bool mndIsDnodeOnline(SDnodeObj *pDnode, int64_t curMs) {
|
||||||
int64_t interval = TABS(pDnode->lastAccessTime - curMs);
|
int64_t interval = TABS(pDnode->lastAccessTime - curMs);
|
||||||
if (interval > 5000 * (int64_t)tsStatusInterval) {
|
if (interval > 5000 * (int64_t)tsStatusInterval) {
|
||||||
|
@ -745,6 +752,18 @@ _OVER:
|
||||||
return code;
|
return code;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
extern int32_t mndProcessRestoreDnodeReqImpl(SRpcMsg *pReq);
|
||||||
|
|
||||||
|
int32_t mndProcessRestoreDnodeReq(SRpcMsg *pReq){
|
||||||
|
return mndProcessRestoreDnodeReqImpl(pReq);
|
||||||
|
}
|
||||||
|
|
||||||
|
#ifndef TD_ENTERPRISE
|
||||||
|
int32_t mndProcessRestoreDnodeReqImpl(SRpcMsg *pReq){
|
||||||
|
return 0;
|
||||||
|
}
|
||||||
|
#endif
|
||||||
|
|
||||||
static int32_t mndDropDnode(SMnode *pMnode, SRpcMsg *pReq, SDnodeObj *pDnode, SMnodeObj *pMObj, SQnodeObj *pQObj,
|
static int32_t mndDropDnode(SMnode *pMnode, SRpcMsg *pReq, SDnodeObj *pDnode, SMnodeObj *pMObj, SQnodeObj *pQObj,
|
||||||
SSnodeObj *pSObj, int32_t numOfVnodes, bool force) {
|
SSnodeObj *pSObj, int32_t numOfVnodes, bool force) {
|
||||||
int32_t code = -1;
|
int32_t code = -1;
|
||||||
|
|
|
@ -275,6 +275,14 @@ static int32_t mndSetCreateMnodeRedoLogs(SMnode *pMnode, STrans *pTrans, SMnodeO
|
||||||
return 0;
|
return 0;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
int32_t mndSetRestoreCreateMnodeRedoLogs(SMnode *pMnode, STrans *pTrans, SMnodeObj *pObj) {
|
||||||
|
SSdbRaw *pRedoRaw = mndMnodeActionEncode(pObj);
|
||||||
|
if (pRedoRaw == NULL) return -1;
|
||||||
|
if (mndTransAppendRedolog(pTrans, pRedoRaw) != 0) return -1;
|
||||||
|
if (sdbSetRawStatus(pRedoRaw, SDB_STATUS_READY) != 0) return -1;
|
||||||
|
return 0;
|
||||||
|
}
|
||||||
|
|
||||||
static int32_t mndSetCreateMnodeUndoLogs(SMnode *pMnode, STrans *pTrans, SMnodeObj *pObj) {
|
static int32_t mndSetCreateMnodeUndoLogs(SMnode *pMnode, STrans *pTrans, SMnodeObj *pObj) {
|
||||||
SSdbRaw *pUndoRaw = mndMnodeActionEncode(pObj);
|
SSdbRaw *pUndoRaw = mndMnodeActionEncode(pObj);
|
||||||
if (pUndoRaw == NULL) return -1;
|
if (pUndoRaw == NULL) return -1;
|
||||||
|
@ -283,7 +291,7 @@ static int32_t mndSetCreateMnodeUndoLogs(SMnode *pMnode, STrans *pTrans, SMnodeO
|
||||||
return 0;
|
return 0;
|
||||||
}
|
}
|
||||||
|
|
||||||
static int32_t mndSetCreateMnodeCommitLogs(SMnode *pMnode, STrans *pTrans, SMnodeObj *pObj) {
|
int32_t mndSetCreateMnodeCommitLogs(SMnode *pMnode, STrans *pTrans, SMnodeObj *pObj) {
|
||||||
SSdbRaw *pCommitRaw = mndMnodeActionEncode(pObj);
|
SSdbRaw *pCommitRaw = mndMnodeActionEncode(pObj);
|
||||||
if (pCommitRaw == NULL) return -1;
|
if (pCommitRaw == NULL) return -1;
|
||||||
if (mndTransAppendCommitlog(pTrans, pCommitRaw) != 0) return -1;
|
if (mndTransAppendCommitlog(pTrans, pCommitRaw) != 0) return -1;
|
||||||
|
@ -421,6 +429,55 @@ static int32_t mndSetCreateMnodeRedoActions(SMnode *pMnode, STrans *pTrans, SDno
|
||||||
return 0;
|
return 0;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
int32_t mndSetRestoreCreateMnodeRedoActions(SMnode *pMnode, STrans *pTrans, SDnodeObj *pDnode, SMnodeObj *pObj) {
|
||||||
|
SSdb *pSdb = pMnode->pSdb;
|
||||||
|
void *pIter = NULL;
|
||||||
|
SDCreateMnodeReq createReq = {0};
|
||||||
|
SEpSet createEpset = {0};
|
||||||
|
|
||||||
|
while (1) {
|
||||||
|
SMnodeObj *pMObj = NULL;
|
||||||
|
pIter = sdbFetch(pSdb, SDB_MNODE, pIter, (void **)&pMObj);
|
||||||
|
if (pIter == NULL) break;
|
||||||
|
|
||||||
|
if(pMObj->id == pDnode->id) {
|
||||||
|
sdbRelease(pSdb, pMObj);
|
||||||
|
continue;
|
||||||
|
}
|
||||||
|
|
||||||
|
if(pMObj->role == TAOS_SYNC_ROLE_VOTER){
|
||||||
|
createReq.replicas[createReq.replica].id = pMObj->id;
|
||||||
|
createReq.replicas[createReq.replica].port = pMObj->pDnode->port;
|
||||||
|
memcpy(createReq.replicas[createReq.replica].fqdn, pMObj->pDnode->fqdn, TSDB_FQDN_LEN);
|
||||||
|
createReq.replica++;
|
||||||
|
}
|
||||||
|
else{
|
||||||
|
createReq.learnerReplicas[createReq.learnerReplica].id = pMObj->id;
|
||||||
|
createReq.learnerReplicas[createReq.learnerReplica].port = pMObj->pDnode->port;
|
||||||
|
memcpy(createReq.learnerReplicas[createReq.learnerReplica].fqdn, pMObj->pDnode->fqdn, TSDB_FQDN_LEN);
|
||||||
|
createReq.learnerReplica++;
|
||||||
|
}
|
||||||
|
|
||||||
|
sdbRelease(pSdb, pMObj);
|
||||||
|
}
|
||||||
|
|
||||||
|
createReq.learnerReplicas[createReq.learnerReplica].id = pDnode->id;
|
||||||
|
createReq.learnerReplicas[createReq.learnerReplica].port = pDnode->port;
|
||||||
|
memcpy(createReq.learnerReplicas[createReq.learnerReplica].fqdn, pDnode->fqdn, TSDB_FQDN_LEN);
|
||||||
|
createReq.learnerReplica++;
|
||||||
|
|
||||||
|
createReq.lastIndex = pObj->lastIndex;
|
||||||
|
|
||||||
|
createEpset.inUse = 0;
|
||||||
|
createEpset.numOfEps = 1;
|
||||||
|
createEpset.eps[0].port = pDnode->port;
|
||||||
|
memcpy(createEpset.eps[0].fqdn, pDnode->fqdn, TSDB_FQDN_LEN);
|
||||||
|
|
||||||
|
if (mndBuildCreateMnodeRedoAction(pTrans, &createReq, &createEpset) != 0) return -1;
|
||||||
|
|
||||||
|
return 0;
|
||||||
|
}
|
||||||
|
|
||||||
static int32_t mndSetAlterMnodeTypeRedoActions(SMnode *pMnode, STrans *pTrans, SDnodeObj *pDnode, SMnodeObj *pObj) {
|
static int32_t mndSetAlterMnodeTypeRedoActions(SMnode *pMnode, STrans *pTrans, SDnodeObj *pDnode, SMnodeObj *pObj) {
|
||||||
SSdb *pSdb = pMnode->pSdb;
|
SSdb *pSdb = pMnode->pSdb;
|
||||||
void *pIter = NULL;
|
void *pIter = NULL;
|
||||||
|
@ -465,6 +522,55 @@ static int32_t mndSetAlterMnodeTypeRedoActions(SMnode *pMnode, STrans *pTrans, S
|
||||||
return 0;
|
return 0;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
int32_t mndSetRestoreAlterMnodeTypeRedoActions(SMnode *pMnode, STrans *pTrans, SDnodeObj *pDnode, SMnodeObj *pObj) {
|
||||||
|
SSdb *pSdb = pMnode->pSdb;
|
||||||
|
void *pIter = NULL;
|
||||||
|
SDAlterMnodeTypeReq alterReq = {0};
|
||||||
|
SEpSet createEpset = {0};
|
||||||
|
|
||||||
|
while (1) {
|
||||||
|
SMnodeObj *pMObj = NULL;
|
||||||
|
pIter = sdbFetch(pSdb, SDB_MNODE, pIter, (void **)&pMObj);
|
||||||
|
if (pIter == NULL) break;
|
||||||
|
|
||||||
|
if(pMObj->id == pDnode->id) {
|
||||||
|
sdbRelease(pSdb, pMObj);
|
||||||
|
continue;
|
||||||
|
}
|
||||||
|
|
||||||
|
if(pMObj->role == TAOS_SYNC_ROLE_VOTER){
|
||||||
|
alterReq.replicas[alterReq.replica].id = pMObj->id;
|
||||||
|
alterReq.replicas[alterReq.replica].port = pMObj->pDnode->port;
|
||||||
|
memcpy(alterReq.replicas[alterReq.replica].fqdn, pMObj->pDnode->fqdn, TSDB_FQDN_LEN);
|
||||||
|
alterReq.replica++;
|
||||||
|
}
|
||||||
|
else{
|
||||||
|
alterReq.learnerReplicas[alterReq.learnerReplica].id = pMObj->id;
|
||||||
|
alterReq.learnerReplicas[alterReq.learnerReplica].port = pMObj->pDnode->port;
|
||||||
|
memcpy(alterReq.learnerReplicas[alterReq.learnerReplica].fqdn, pMObj->pDnode->fqdn, TSDB_FQDN_LEN);
|
||||||
|
alterReq.learnerReplica++;
|
||||||
|
}
|
||||||
|
|
||||||
|
sdbRelease(pSdb, pMObj);
|
||||||
|
}
|
||||||
|
|
||||||
|
alterReq.replicas[alterReq.replica].id = pDnode->id;
|
||||||
|
alterReq.replicas[alterReq.replica].port = pDnode->port;
|
||||||
|
memcpy(alterReq.replicas[alterReq.replica].fqdn, pDnode->fqdn, TSDB_FQDN_LEN);
|
||||||
|
alterReq.replica++;
|
||||||
|
|
||||||
|
alterReq.lastIndex = pObj->lastIndex;
|
||||||
|
|
||||||
|
createEpset.inUse = 0;
|
||||||
|
createEpset.numOfEps = 1;
|
||||||
|
createEpset.eps[0].port = pDnode->port;
|
||||||
|
memcpy(createEpset.eps[0].fqdn, pDnode->fqdn, TSDB_FQDN_LEN);
|
||||||
|
|
||||||
|
if (mndBuildAlterMnodeTypeRedoAction(pTrans, &alterReq, &createEpset) != 0) return -1;
|
||||||
|
|
||||||
|
return 0;
|
||||||
|
}
|
||||||
|
|
||||||
static int32_t mndCreateMnode(SMnode *pMnode, SRpcMsg *pReq, SDnodeObj *pDnode, SMCreateMnodeReq *pCreate) {
|
static int32_t mndCreateMnode(SMnode *pMnode, SRpcMsg *pReq, SDnodeObj *pDnode, SMCreateMnodeReq *pCreate) {
|
||||||
int32_t code = -1;
|
int32_t code = -1;
|
||||||
|
|
||||||
|
|
|
@ -180,7 +180,7 @@ static int32_t mndSetCreateQnodeUndoLogs(STrans *pTrans, SQnodeObj *pObj) {
|
||||||
return 0;
|
return 0;
|
||||||
}
|
}
|
||||||
|
|
||||||
static int32_t mndSetCreateQnodeCommitLogs(STrans *pTrans, SQnodeObj *pObj) {
|
int32_t mndSetCreateQnodeCommitLogs(STrans *pTrans, SQnodeObj *pObj) {
|
||||||
SSdbRaw *pCommitRaw = mndQnodeActionEncode(pObj);
|
SSdbRaw *pCommitRaw = mndQnodeActionEncode(pObj);
|
||||||
if (pCommitRaw == NULL) return -1;
|
if (pCommitRaw == NULL) return -1;
|
||||||
if (mndTransAppendCommitlog(pTrans, pCommitRaw) != 0) return -1;
|
if (mndTransAppendCommitlog(pTrans, pCommitRaw) != 0) return -1;
|
||||||
|
@ -188,7 +188,11 @@ static int32_t mndSetCreateQnodeCommitLogs(STrans *pTrans, SQnodeObj *pObj) {
|
||||||
return 0;
|
return 0;
|
||||||
}
|
}
|
||||||
|
|
||||||
static int32_t mndSetCreateQnodeRedoActions(STrans *pTrans, SDnodeObj *pDnode, SQnodeObj *pObj) {
|
bool mndQnodeInDnode(SQnodeObj *pQnode, int32_t dnodeId) {
|
||||||
|
return pQnode->pDnode->id == dnodeId;
|
||||||
|
}
|
||||||
|
|
||||||
|
int32_t mndSetCreateQnodeRedoActions(STrans *pTrans, SDnodeObj *pDnode, SQnodeObj *pObj) {
|
||||||
SDCreateQnodeReq createReq = {0};
|
SDCreateQnodeReq createReq = {0};
|
||||||
createReq.dnodeId = pDnode->id;
|
createReq.dnodeId = pDnode->id;
|
||||||
|
|
||||||
|
|
|
@ -1155,6 +1155,28 @@ int32_t mndAddCreateVnodeAction(SMnode *pMnode, STrans *pTrans, SDbObj *pDb, SVg
|
||||||
return 0;
|
return 0;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
int32_t mndRestoreAddCreateVnodeAction(SMnode *pMnode, STrans *pTrans, SDbObj *pDb, SVgObj *pVgroup, SDnodeObj *pDnode) {
|
||||||
|
STransAction action = {0};
|
||||||
|
|
||||||
|
action.epSet = mndGetDnodeEpset(pDnode);
|
||||||
|
|
||||||
|
int32_t contLen = 0;
|
||||||
|
void *pReq = mndBuildCreateVnodeReq(pMnode, pDnode, pDb, pVgroup, &contLen);
|
||||||
|
if (pReq == NULL) return -1;
|
||||||
|
|
||||||
|
action.pCont = pReq;
|
||||||
|
action.contLen = contLen;
|
||||||
|
action.msgType = TDMT_DND_CREATE_VNODE;
|
||||||
|
action.acceptableCode = TSDB_CODE_VND_ALREADY_EXIST;
|
||||||
|
|
||||||
|
if (mndTransAppendRedoAction(pTrans, &action) != 0) {
|
||||||
|
taosMemoryFree(pReq);
|
||||||
|
return -1;
|
||||||
|
}
|
||||||
|
|
||||||
|
return 0;
|
||||||
|
}
|
||||||
|
|
||||||
int32_t mndAddAlterVnodeConfirmAction(SMnode *pMnode, STrans *pTrans, SDbObj *pDb, SVgObj *pVgroup) {
|
int32_t mndAddAlterVnodeConfirmAction(SMnode *pMnode, STrans *pTrans, SDbObj *pDb, SVgObj *pVgroup) {
|
||||||
STransAction action = {0};
|
STransAction action = {0};
|
||||||
action.epSet = mndGetVgroupEpset(pMnode, pVgroup);
|
action.epSet = mndGetVgroupEpset(pMnode, pVgroup);
|
||||||
|
@ -1274,6 +1296,29 @@ int32_t mndAddAlterVnodeTypeAction(SMnode *pMnode, STrans *pTrans, SDbObj *pDb,
|
||||||
return 0;
|
return 0;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
int32_t mndRestoreAddAlterVnodeTypeAction(SMnode *pMnode, STrans *pTrans, SDbObj *pDb, SVgObj *pVgroup,
|
||||||
|
SDnodeObj *pDnode) {
|
||||||
|
STransAction action = {0};
|
||||||
|
action.epSet = mndGetDnodeEpset(pDnode);
|
||||||
|
|
||||||
|
int32_t contLen = 0;
|
||||||
|
void *pReq = mndBuildAlterVnodeReplicaReq(pMnode, pDb, pVgroup, pDnode->id, &contLen);
|
||||||
|
if (pReq == NULL) return -1;
|
||||||
|
|
||||||
|
action.pCont = pReq;
|
||||||
|
action.contLen = contLen;
|
||||||
|
action.msgType = TDMT_DND_ALTER_VNODE_TYPE;
|
||||||
|
action.acceptableCode = TSDB_CODE_VND_ALREADY_IS_VOTER;
|
||||||
|
action.retryCode = TSDB_CODE_VND_NOT_CATCH_UP;
|
||||||
|
|
||||||
|
if (mndTransAppendRedoAction(pTrans, &action) != 0) {
|
||||||
|
taosMemoryFree(pReq);
|
||||||
|
return -1;
|
||||||
|
}
|
||||||
|
|
||||||
|
return 0;
|
||||||
|
}
|
||||||
|
|
||||||
static int32_t mndAddDisableVnodeWriteAction(SMnode *pMnode, STrans *pTrans, SDbObj *pDb, SVgObj *pVgroup,
|
static int32_t mndAddDisableVnodeWriteAction(SMnode *pMnode, STrans *pTrans, SDbObj *pDb, SVgObj *pVgroup,
|
||||||
int32_t dnodeId) {
|
int32_t dnodeId) {
|
||||||
SDnodeObj *pDnode = mndAcquireDnode(pMnode, dnodeId);
|
SDnodeObj *pDnode = mndAcquireDnode(pMnode, dnodeId);
|
||||||
|
@ -2113,6 +2158,55 @@ int32_t mndBuildAlterVgroupAction(SMnode *pMnode, STrans *pTrans, SDbObj *pOldDb
|
||||||
return 0;
|
return 0;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
int32_t mndBuildRestoreAlterVgroupAction(SMnode *pMnode, STrans *pTrans, SDbObj *db, SVgObj *pVgroup,
|
||||||
|
SDnodeObj *pDnode) {
|
||||||
|
SVgObj newVgroup = {0};
|
||||||
|
memcpy(&newVgroup, pVgroup, sizeof(SVgObj));
|
||||||
|
|
||||||
|
mInfo("db:%s, vgId:%d, restore vnodes, vn:0 dnode:%d", pVgroup->dbName, pVgroup->vgId,
|
||||||
|
pVgroup->vnodeGid[0].dnodeId);
|
||||||
|
|
||||||
|
if(newVgroup.replica == 1){
|
||||||
|
int selected = 0;
|
||||||
|
for(int i = 0; i < newVgroup.replica; i++){
|
||||||
|
newVgroup.vnodeGid[i].nodeRole = TAOS_SYNC_ROLE_VOTER;
|
||||||
|
if(newVgroup.vnodeGid[i].dnodeId == pDnode->id){
|
||||||
|
selected = i;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
if (mndAddCreateVnodeAction(pMnode, pTrans, db, &newVgroup, &newVgroup.vnodeGid[selected]) != 0) return -1;
|
||||||
|
}
|
||||||
|
else if(newVgroup.replica == 3){
|
||||||
|
for(int i = 0; i < newVgroup.replica; i++){
|
||||||
|
if(newVgroup.vnodeGid[i].dnodeId == pDnode->id){
|
||||||
|
newVgroup.vnodeGid[i].nodeRole = TAOS_SYNC_ROLE_LEARNER;
|
||||||
|
}
|
||||||
|
else{
|
||||||
|
newVgroup.vnodeGid[i].nodeRole = TAOS_SYNC_ROLE_VOTER;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
if (mndRestoreAddCreateVnodeAction(pMnode, pTrans, db, &newVgroup, pDnode) != 0) return -1;
|
||||||
|
|
||||||
|
for(int i = 0; i < newVgroup.replica; i++){
|
||||||
|
newVgroup.vnodeGid[i].nodeRole = TAOS_SYNC_ROLE_VOTER;
|
||||||
|
if(newVgroup.vnodeGid[i].dnodeId == pDnode->id){
|
||||||
|
}
|
||||||
|
}
|
||||||
|
if (mndRestoreAddAlterVnodeTypeAction(pMnode, pTrans, db, &newVgroup, pDnode) != 0)
|
||||||
|
return -1;
|
||||||
|
}
|
||||||
|
|
||||||
|
SSdbRaw *pVgRaw = mndVgroupActionEncode(&newVgroup);
|
||||||
|
if (pVgRaw == NULL) return -1;
|
||||||
|
if (mndTransAppendCommitlog(pTrans, pVgRaw) != 0) {
|
||||||
|
sdbFreeRaw(pVgRaw);
|
||||||
|
return -1;
|
||||||
|
}
|
||||||
|
(void)sdbSetRawStatus(pVgRaw, SDB_STATUS_READY);
|
||||||
|
|
||||||
|
return 0;
|
||||||
|
}
|
||||||
|
|
||||||
static int32_t mndAddAdjustVnodeHashRangeAction(SMnode *pMnode, STrans *pTrans, SDbObj *pDb, SVgObj *pVgroup) {
|
static int32_t mndAddAdjustVnodeHashRangeAction(SMnode *pMnode, STrans *pTrans, SDbObj *pDb, SVgObj *pVgroup) {
|
||||||
return 0;
|
return 0;
|
||||||
}
|
}
|
||||||
|
@ -2437,6 +2531,13 @@ _OVER:
|
||||||
|
|
||||||
bool mndVgroupInDb(SVgObj *pVgroup, int64_t dbUid) { return !pVgroup->isTsma && pVgroup->dbUid == dbUid; }
|
bool mndVgroupInDb(SVgObj *pVgroup, int64_t dbUid) { return !pVgroup->isTsma && pVgroup->dbUid == dbUid; }
|
||||||
|
|
||||||
|
bool mndVgroupInDnode(SVgObj *pVgroup, int32_t dnodeId) {
|
||||||
|
for(int i = 0; i < pVgroup->replica; i++){
|
||||||
|
if(pVgroup->vnodeGid[i].dnodeId == dnodeId) return true;
|
||||||
|
}
|
||||||
|
return false;
|
||||||
|
}
|
||||||
|
|
||||||
static void *mndBuildCompactVnodeReq(SMnode *pMnode, SDbObj *pDb, SVgObj *pVgroup, int32_t *pContLen, int64_t compactTs,
|
static void *mndBuildCompactVnodeReq(SMnode *pMnode, SDbObj *pDb, SVgObj *pVgroup, int32_t *pContLen, int64_t compactTs,
|
||||||
STimeWindow tw) {
|
STimeWindow tw) {
|
||||||
SCompactVnodeReq compactReq = {0};
|
SCompactVnodeReq compactReq = {0};
|
||||||
|
|
|
@ -257,6 +257,14 @@ const char* nodesNodeName(ENodeType type) {
|
||||||
return "DeleteStmt";
|
return "DeleteStmt";
|
||||||
case QUERY_NODE_INSERT_STMT:
|
case QUERY_NODE_INSERT_STMT:
|
||||||
return "InsertStmt";
|
return "InsertStmt";
|
||||||
|
case QUERY_NODE_RESTORE_DNODE_STMT:
|
||||||
|
return "RestoreDnodeStmt";
|
||||||
|
case QUERY_NODE_RESTORE_QNODE_STMT:
|
||||||
|
return "RestoreQnodeStmt";
|
||||||
|
case QUERY_NODE_RESTORE_MNODE_STMT:
|
||||||
|
return "RestoreMnodeStmt";
|
||||||
|
case QUERY_NODE_RESTORE_VNODE_STMT:
|
||||||
|
return "RestoreVnodeStmt";
|
||||||
case QUERY_NODE_LOGIC_PLAN_SCAN:
|
case QUERY_NODE_LOGIC_PLAN_SCAN:
|
||||||
return "LogicScan";
|
return "LogicScan";
|
||||||
case QUERY_NODE_LOGIC_PLAN_JOIN:
|
case QUERY_NODE_LOGIC_PLAN_JOIN:
|
||||||
|
@ -5533,6 +5541,35 @@ static int32_t jsonToDropDnodeStmt(const SJson* pJson, void* pObj) {
|
||||||
return code;
|
return code;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
static const char* jkRestoreComponentNodeStmtDnodeId = "DnodeId";
|
||||||
|
|
||||||
|
static int32_t restoreComponentNodeStmtToJson(const void* pObj, SJson* pJson) {
|
||||||
|
const SRestoreComponentNodeStmt* pNode = (const SRestoreComponentNodeStmt*)pObj;
|
||||||
|
return tjsonAddIntegerToObject(pJson, jkRestoreComponentNodeStmtDnodeId, pNode->dnodeId);
|
||||||
|
}
|
||||||
|
|
||||||
|
static int32_t jsonToRestoreComponentNodeStmt(const SJson* pJson, void* pObj) {
|
||||||
|
SRestoreComponentNodeStmt* pNode = (SRestoreComponentNodeStmt*)pObj;
|
||||||
|
return tjsonGetIntValue(pJson, jkRestoreComponentNodeStmtDnodeId, &pNode->dnodeId);
|
||||||
|
}
|
||||||
|
|
||||||
|
static int32_t jsonToRestoreDnodeStmt(const SJson* pJson, void* pObj) {
|
||||||
|
return jsonToRestoreComponentNodeStmt(pJson, pObj);
|
||||||
|
}
|
||||||
|
static int32_t jsonToRestoreQnodeStmt(const SJson* pJson, void* pObj) {
|
||||||
|
return jsonToRestoreComponentNodeStmt(pJson, pObj);
|
||||||
|
}
|
||||||
|
static int32_t jsonToRestoreMnodeStmt(const SJson* pJson, void* pObj) {
|
||||||
|
return jsonToRestoreComponentNodeStmt(pJson, pObj);
|
||||||
|
}
|
||||||
|
static int32_t jsonToRestoreVnodeStmt(const SJson* pJson, void* pObj) {
|
||||||
|
return jsonToRestoreComponentNodeStmt(pJson, pObj);
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
static const char* jkCreateTopicStmtTopicName = "TopicName";
|
static const char* jkCreateTopicStmtTopicName = "TopicName";
|
||||||
static const char* jkCreateTopicStmtSubscribeDbName = "SubscribeDbName";
|
static const char* jkCreateTopicStmtSubscribeDbName = "SubscribeDbName";
|
||||||
static const char* jkCreateTopicStmtIgnoreExists = "IgnoreExists";
|
static const char* jkCreateTopicStmtIgnoreExists = "IgnoreExists";
|
||||||
|
@ -6820,6 +6857,14 @@ static int32_t jsonToSpecificNode(const SJson* pJson, void* pObj) {
|
||||||
return jsonToDeleteStmt(pJson, pObj);
|
return jsonToDeleteStmt(pJson, pObj);
|
||||||
case QUERY_NODE_INSERT_STMT:
|
case QUERY_NODE_INSERT_STMT:
|
||||||
return jsonToInsertStmt(pJson, pObj);
|
return jsonToInsertStmt(pJson, pObj);
|
||||||
|
case QUERY_NODE_RESTORE_DNODE_STMT:
|
||||||
|
return jsonToRestoreDnodeStmt(pJson, pObj);
|
||||||
|
case QUERY_NODE_RESTORE_QNODE_STMT:
|
||||||
|
return jsonToRestoreQnodeStmt(pJson, pObj);
|
||||||
|
case QUERY_NODE_RESTORE_MNODE_STMT:
|
||||||
|
return jsonToRestoreMnodeStmt(pJson, pObj);
|
||||||
|
case QUERY_NODE_RESTORE_VNODE_STMT:
|
||||||
|
return jsonToRestoreVnodeStmt(pJson, pObj);
|
||||||
case QUERY_NODE_LOGIC_PLAN_SCAN:
|
case QUERY_NODE_LOGIC_PLAN_SCAN:
|
||||||
return jsonToLogicScanNode(pJson, pObj);
|
return jsonToLogicScanNode(pJson, pObj);
|
||||||
case QUERY_NODE_LOGIC_PLAN_JOIN:
|
case QUERY_NODE_LOGIC_PLAN_JOIN:
|
||||||
|
|
|
@ -455,6 +455,11 @@ SNode* nodesMakeNode(ENodeType type) {
|
||||||
return makeNode(type, sizeof(SInsertStmt));
|
return makeNode(type, sizeof(SInsertStmt));
|
||||||
case QUERY_NODE_QUERY:
|
case QUERY_NODE_QUERY:
|
||||||
return makeNode(type, sizeof(SQuery));
|
return makeNode(type, sizeof(SQuery));
|
||||||
|
case QUERY_NODE_RESTORE_DNODE_STMT:
|
||||||
|
case QUERY_NODE_RESTORE_QNODE_STMT:
|
||||||
|
case QUERY_NODE_RESTORE_MNODE_STMT:
|
||||||
|
case QUERY_NODE_RESTORE_VNODE_STMT:
|
||||||
|
return makeNode(type, sizeof(SRestoreComponentNodeStmt));
|
||||||
case QUERY_NODE_LOGIC_PLAN_SCAN:
|
case QUERY_NODE_LOGIC_PLAN_SCAN:
|
||||||
return makeNode(type, sizeof(SScanLogicNode));
|
return makeNode(type, sizeof(SScanLogicNode));
|
||||||
case QUERY_NODE_LOGIC_PLAN_JOIN:
|
case QUERY_NODE_LOGIC_PLAN_JOIN:
|
||||||
|
@ -1046,6 +1051,11 @@ void nodesDestroyNode(SNode* pNode) {
|
||||||
nodesDestroyNode(pQuery->pPrepareRoot);
|
nodesDestroyNode(pQuery->pPrepareRoot);
|
||||||
break;
|
break;
|
||||||
}
|
}
|
||||||
|
case QUERY_NODE_RESTORE_DNODE_STMT: // no pointer field
|
||||||
|
case QUERY_NODE_RESTORE_QNODE_STMT: // no pointer field
|
||||||
|
case QUERY_NODE_RESTORE_MNODE_STMT: // no pointer field
|
||||||
|
case QUERY_NODE_RESTORE_VNODE_STMT: // no pointer field
|
||||||
|
break;
|
||||||
case QUERY_NODE_LOGIC_PLAN_SCAN: {
|
case QUERY_NODE_LOGIC_PLAN_SCAN: {
|
||||||
SScanLogicNode* pLogicNode = (SScanLogicNode*)pNode;
|
SScanLogicNode* pLogicNode = (SScanLogicNode*)pNode;
|
||||||
destroyLogicNode((SLogicNode*)pLogicNode);
|
destroyLogicNode((SLogicNode*)pLogicNode);
|
||||||
|
|
|
@ -202,6 +202,7 @@ SNode* createIndexOption(SAstCreateContext* pCxt, SNodeList* pFuncs, SNode* pInt
|
||||||
SNode* createDropIndexStmt(SAstCreateContext* pCxt, bool ignoreNotExists, SNode* pIndexName);
|
SNode* createDropIndexStmt(SAstCreateContext* pCxt, bool ignoreNotExists, SNode* pIndexName);
|
||||||
SNode* createCreateComponentNodeStmt(SAstCreateContext* pCxt, ENodeType type, const SToken* pDnodeId);
|
SNode* createCreateComponentNodeStmt(SAstCreateContext* pCxt, ENodeType type, const SToken* pDnodeId);
|
||||||
SNode* createDropComponentNodeStmt(SAstCreateContext* pCxt, ENodeType type, const SToken* pDnodeId);
|
SNode* createDropComponentNodeStmt(SAstCreateContext* pCxt, ENodeType type, const SToken* pDnodeId);
|
||||||
|
SNode* createRestoreComponentNodeStmt(SAstCreateContext* pCxt, ENodeType type, const SToken* pDnodeId);
|
||||||
SNode* createCreateTopicStmtUseQuery(SAstCreateContext* pCxt, bool ignoreExists, SToken* pTopicName, SNode* pQuery);
|
SNode* createCreateTopicStmtUseQuery(SAstCreateContext* pCxt, bool ignoreExists, SToken* pTopicName, SNode* pQuery);
|
||||||
SNode* createCreateTopicStmtUseDb(SAstCreateContext* pCxt, bool ignoreExists, SToken* pTopicName, SToken* pSubDbName,
|
SNode* createCreateTopicStmtUseDb(SAstCreateContext* pCxt, bool ignoreExists, SToken* pTopicName, SToken* pSubDbName,
|
||||||
bool withMeta);
|
bool withMeta);
|
||||||
|
|
|
@ -123,7 +123,7 @@ priv_level(A) ::= topic_name(B).
|
||||||
with_opt(A) ::= . { A = NULL; }
|
with_opt(A) ::= . { A = NULL; }
|
||||||
with_opt(A) ::= WITH search_condition(B). { A = B; }
|
with_opt(A) ::= WITH search_condition(B). { A = B; }
|
||||||
|
|
||||||
/************************************************ create/drop/alter dnode *********************************************/
|
/************************************************ create/drop/alter/restore dnode *********************************************/
|
||||||
cmd ::= CREATE DNODE dnode_endpoint(A). { pCxt->pRootNode = createCreateDnodeStmt(pCxt, &A, NULL); }
|
cmd ::= CREATE DNODE dnode_endpoint(A). { pCxt->pRootNode = createCreateDnodeStmt(pCxt, &A, NULL); }
|
||||||
cmd ::= CREATE DNODE dnode_endpoint(A) PORT NK_INTEGER(B). { pCxt->pRootNode = createCreateDnodeStmt(pCxt, &A, &B); }
|
cmd ::= CREATE DNODE dnode_endpoint(A) PORT NK_INTEGER(B). { pCxt->pRootNode = createCreateDnodeStmt(pCxt, &A, &B); }
|
||||||
cmd ::= DROP DNODE NK_INTEGER(A) force_opt(B). { pCxt->pRootNode = createDropDnodeStmt(pCxt, &A, B); }
|
cmd ::= DROP DNODE NK_INTEGER(A) force_opt(B). { pCxt->pRootNode = createDropDnodeStmt(pCxt, &A, B); }
|
||||||
|
@ -132,6 +132,7 @@ cmd ::= ALTER DNODE NK_INTEGER(A) NK_STRING(B).
|
||||||
cmd ::= ALTER DNODE NK_INTEGER(A) NK_STRING(B) NK_STRING(C). { pCxt->pRootNode = createAlterDnodeStmt(pCxt, &A, &B, &C); }
|
cmd ::= ALTER DNODE NK_INTEGER(A) NK_STRING(B) NK_STRING(C). { pCxt->pRootNode = createAlterDnodeStmt(pCxt, &A, &B, &C); }
|
||||||
cmd ::= ALTER ALL DNODES NK_STRING(A). { pCxt->pRootNode = createAlterDnodeStmt(pCxt, NULL, &A, NULL); }
|
cmd ::= ALTER ALL DNODES NK_STRING(A). { pCxt->pRootNode = createAlterDnodeStmt(pCxt, NULL, &A, NULL); }
|
||||||
cmd ::= ALTER ALL DNODES NK_STRING(A) NK_STRING(B). { pCxt->pRootNode = createAlterDnodeStmt(pCxt, NULL, &A, &B); }
|
cmd ::= ALTER ALL DNODES NK_STRING(A) NK_STRING(B). { pCxt->pRootNode = createAlterDnodeStmt(pCxt, NULL, &A, &B); }
|
||||||
|
cmd ::= RESTORE DNODE NK_INTEGER(A). { pCxt->pRootNode = createRestoreComponentNodeStmt(pCxt, QUERY_NODE_RESTORE_DNODE_STMT, &A); }
|
||||||
|
|
||||||
%type dnode_endpoint { SToken }
|
%type dnode_endpoint { SToken }
|
||||||
%destructor dnode_endpoint { }
|
%destructor dnode_endpoint { }
|
||||||
|
@ -148,9 +149,10 @@ force_opt(A) ::= FORCE.
|
||||||
cmd ::= ALTER LOCAL NK_STRING(A). { pCxt->pRootNode = createAlterLocalStmt(pCxt, &A, NULL); }
|
cmd ::= ALTER LOCAL NK_STRING(A). { pCxt->pRootNode = createAlterLocalStmt(pCxt, &A, NULL); }
|
||||||
cmd ::= ALTER LOCAL NK_STRING(A) NK_STRING(B). { pCxt->pRootNode = createAlterLocalStmt(pCxt, &A, &B); }
|
cmd ::= ALTER LOCAL NK_STRING(A) NK_STRING(B). { pCxt->pRootNode = createAlterLocalStmt(pCxt, &A, &B); }
|
||||||
|
|
||||||
/************************************************ create/drop qnode ***************************************************/
|
/************************************************ create/drop/restore qnode ***************************************************/
|
||||||
cmd ::= CREATE QNODE ON DNODE NK_INTEGER(A). { pCxt->pRootNode = createCreateComponentNodeStmt(pCxt, QUERY_NODE_CREATE_QNODE_STMT, &A); }
|
cmd ::= CREATE QNODE ON DNODE NK_INTEGER(A). { pCxt->pRootNode = createCreateComponentNodeStmt(pCxt, QUERY_NODE_CREATE_QNODE_STMT, &A); }
|
||||||
cmd ::= DROP QNODE ON DNODE NK_INTEGER(A). { pCxt->pRootNode = createDropComponentNodeStmt(pCxt, QUERY_NODE_DROP_QNODE_STMT, &A); }
|
cmd ::= DROP QNODE ON DNODE NK_INTEGER(A). { pCxt->pRootNode = createDropComponentNodeStmt(pCxt, QUERY_NODE_DROP_QNODE_STMT, &A); }
|
||||||
|
cmd ::= RESTORE QNODE ON DNODE NK_INTEGER(A). { pCxt->pRootNode = createRestoreComponentNodeStmt(pCxt, QUERY_NODE_RESTORE_QNODE_STMT, &A); }
|
||||||
|
|
||||||
/************************************************ create/drop bnode ***************************************************/
|
/************************************************ create/drop bnode ***************************************************/
|
||||||
cmd ::= CREATE BNODE ON DNODE NK_INTEGER(A). { pCxt->pRootNode = createCreateComponentNodeStmt(pCxt, QUERY_NODE_CREATE_BNODE_STMT, &A); }
|
cmd ::= CREATE BNODE ON DNODE NK_INTEGER(A). { pCxt->pRootNode = createCreateComponentNodeStmt(pCxt, QUERY_NODE_CREATE_BNODE_STMT, &A); }
|
||||||
|
@ -160,9 +162,13 @@ cmd ::= DROP BNODE ON DNODE NK_INTEGER(A).
|
||||||
cmd ::= CREATE SNODE ON DNODE NK_INTEGER(A). { pCxt->pRootNode = createCreateComponentNodeStmt(pCxt, QUERY_NODE_CREATE_SNODE_STMT, &A); }
|
cmd ::= CREATE SNODE ON DNODE NK_INTEGER(A). { pCxt->pRootNode = createCreateComponentNodeStmt(pCxt, QUERY_NODE_CREATE_SNODE_STMT, &A); }
|
||||||
cmd ::= DROP SNODE ON DNODE NK_INTEGER(A). { pCxt->pRootNode = createDropComponentNodeStmt(pCxt, QUERY_NODE_DROP_SNODE_STMT, &A); }
|
cmd ::= DROP SNODE ON DNODE NK_INTEGER(A). { pCxt->pRootNode = createDropComponentNodeStmt(pCxt, QUERY_NODE_DROP_SNODE_STMT, &A); }
|
||||||
|
|
||||||
/************************************************ create/drop mnode ***************************************************/
|
/************************************************ create/drop/restore mnode ***************************************************/
|
||||||
cmd ::= CREATE MNODE ON DNODE NK_INTEGER(A). { pCxt->pRootNode = createCreateComponentNodeStmt(pCxt, QUERY_NODE_CREATE_MNODE_STMT, &A); }
|
cmd ::= CREATE MNODE ON DNODE NK_INTEGER(A). { pCxt->pRootNode = createCreateComponentNodeStmt(pCxt, QUERY_NODE_CREATE_MNODE_STMT, &A); }
|
||||||
cmd ::= DROP MNODE ON DNODE NK_INTEGER(A). { pCxt->pRootNode = createDropComponentNodeStmt(pCxt, QUERY_NODE_DROP_MNODE_STMT, &A); }
|
cmd ::= DROP MNODE ON DNODE NK_INTEGER(A). { pCxt->pRootNode = createDropComponentNodeStmt(pCxt, QUERY_NODE_DROP_MNODE_STMT, &A); }
|
||||||
|
cmd ::= RESTORE MNODE ON DNODE NK_INTEGER(A). { pCxt->pRootNode = createRestoreComponentNodeStmt(pCxt, QUERY_NODE_RESTORE_MNODE_STMT, &A); }
|
||||||
|
|
||||||
|
/************************************************ restore vnode ***************************************************/
|
||||||
|
cmd ::= RESTORE VNODE ON DNODE NK_INTEGER(A). { pCxt->pRootNode = createRestoreComponentNodeStmt(pCxt, QUERY_NODE_RESTORE_VNODE_STMT, &A); }
|
||||||
|
|
||||||
/************************************************ create/drop/use database ********************************************/
|
/************************************************ create/drop/use database ********************************************/
|
||||||
cmd ::= CREATE DATABASE not_exists_opt(A) db_name(B) db_options(C). { pCxt->pRootNode = createCreateDatabaseStmt(pCxt, A, &B, C); }
|
cmd ::= CREATE DATABASE not_exists_opt(A) db_name(B) db_options(C). { pCxt->pRootNode = createCreateDatabaseStmt(pCxt, A, &B, C); }
|
||||||
|
|
|
@ -1658,6 +1658,14 @@ SNode* createDropComponentNodeStmt(SAstCreateContext* pCxt, ENodeType type, cons
|
||||||
return (SNode*)pStmt;
|
return (SNode*)pStmt;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
SNode* createRestoreComponentNodeStmt(SAstCreateContext* pCxt, ENodeType type, const SToken* pDnodeId) {
|
||||||
|
CHECK_PARSER_STATUS(pCxt);
|
||||||
|
SRestoreComponentNodeStmt* pStmt = (SRestoreComponentNodeStmt*)nodesMakeNode(type);
|
||||||
|
CHECK_OUT_OF_MEM(pStmt);
|
||||||
|
pStmt->dnodeId = taosStr2Int32(pDnodeId->z, NULL, 10);
|
||||||
|
return (SNode*)pStmt;
|
||||||
|
}
|
||||||
|
|
||||||
SNode* createCreateTopicStmtUseQuery(SAstCreateContext* pCxt, bool ignoreExists, SToken* pTopicName, SNode* pQuery) {
|
SNode* createCreateTopicStmtUseQuery(SAstCreateContext* pCxt, bool ignoreExists, SToken* pTopicName, SNode* pQuery) {
|
||||||
CHECK_PARSER_STATUS(pCxt);
|
CHECK_PARSER_STATUS(pCxt);
|
||||||
if (!checkTopicName(pCxt, pTopicName)) {
|
if (!checkTopicName(pCxt, pTopicName)) {
|
||||||
|
|
|
@ -181,6 +181,7 @@ static SKeyword keywordTable[] = {
|
||||||
{"REPLACE", TK_REPLACE},
|
{"REPLACE", TK_REPLACE},
|
||||||
{"REPLICA", TK_REPLICA},
|
{"REPLICA", TK_REPLICA},
|
||||||
{"RESET", TK_RESET},
|
{"RESET", TK_RESET},
|
||||||
|
{"RESTORE", TK_RESTORE},
|
||||||
{"RETENTIONS", TK_RETENTIONS},
|
{"RETENTIONS", TK_RETENTIONS},
|
||||||
{"REVOKE", TK_REVOKE},
|
{"REVOKE", TK_REVOKE},
|
||||||
{"ROLLUP", TK_ROLLUP},
|
{"ROLLUP", TK_ROLLUP},
|
||||||
|
@ -252,6 +253,7 @@ static SKeyword keywordTable[] = {
|
||||||
{"VERBOSE", TK_VERBOSE},
|
{"VERBOSE", TK_VERBOSE},
|
||||||
{"VGROUP", TK_VGROUP},
|
{"VGROUP", TK_VGROUP},
|
||||||
{"VGROUPS", TK_VGROUPS},
|
{"VGROUPS", TK_VGROUPS},
|
||||||
|
{"VNODE", TK_VNODE},
|
||||||
{"VNODES", TK_VNODES},
|
{"VNODES", TK_VNODES},
|
||||||
{"WAL_FSYNC_PERIOD", TK_WAL_FSYNC_PERIOD},
|
{"WAL_FSYNC_PERIOD", TK_WAL_FSYNC_PERIOD},
|
||||||
{"WAL_LEVEL", TK_WAL_LEVEL},
|
{"WAL_LEVEL", TK_WAL_LEVEL},
|
||||||
|
|
|
@ -5431,6 +5431,29 @@ static int32_t translateAlterDnode(STranslateContext* pCxt, SAlterDnodeStmt* pSt
|
||||||
return buildCmdMsg(pCxt, TDMT_MND_CONFIG_DNODE, (FSerializeFunc)tSerializeSMCfgDnodeReq, &cfgReq);
|
return buildCmdMsg(pCxt, TDMT_MND_CONFIG_DNODE, (FSerializeFunc)tSerializeSMCfgDnodeReq, &cfgReq);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
static int32_t translateRestoreDnode(STranslateContext* pCxt, SRestoreComponentNodeStmt* pStmt) {
|
||||||
|
SRestoreDnodeReq restoreReq = {0};
|
||||||
|
restoreReq.dnodeId = pStmt->dnodeId;
|
||||||
|
switch (nodeType((SNode*)pStmt)) {
|
||||||
|
case QUERY_NODE_RESTORE_DNODE_STMT:
|
||||||
|
restoreReq.restoreType = RESTORE_TYPE__ALL;
|
||||||
|
break;
|
||||||
|
case QUERY_NODE_RESTORE_QNODE_STMT:
|
||||||
|
restoreReq.restoreType = RESTORE_TYPE__QNODE;
|
||||||
|
break;
|
||||||
|
case QUERY_NODE_RESTORE_MNODE_STMT:
|
||||||
|
restoreReq.restoreType = RESTORE_TYPE__MNODE;
|
||||||
|
break;
|
||||||
|
case QUERY_NODE_RESTORE_VNODE_STMT:
|
||||||
|
restoreReq.restoreType = RESTORE_TYPE__VNODE;
|
||||||
|
break;
|
||||||
|
default:
|
||||||
|
return -1;
|
||||||
|
}
|
||||||
|
return buildCmdMsg(pCxt, TDMT_MND_RESTORE_DNODE, (FSerializeFunc)tSerializeSRestoreDnodeReq, &restoreReq);
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
static int32_t getSmaIndexDstVgId(STranslateContext* pCxt, const char* pDbName, const char* pTableName,
|
static int32_t getSmaIndexDstVgId(STranslateContext* pCxt, const char* pDbName, const char* pTableName,
|
||||||
int32_t* pVgId) {
|
int32_t* pVgId) {
|
||||||
SVgroupInfo vg = {0};
|
SVgroupInfo vg = {0};
|
||||||
|
@ -6916,6 +6939,12 @@ static int32_t translateQuery(STranslateContext* pCxt, SNode* pNode) {
|
||||||
case QUERY_NODE_SHOW_CREATE_STABLE_STMT:
|
case QUERY_NODE_SHOW_CREATE_STABLE_STMT:
|
||||||
code = translateShowCreateTable(pCxt, (SShowCreateTableStmt*)pNode);
|
code = translateShowCreateTable(pCxt, (SShowCreateTableStmt*)pNode);
|
||||||
break;
|
break;
|
||||||
|
case QUERY_NODE_RESTORE_DNODE_STMT:
|
||||||
|
case QUERY_NODE_RESTORE_QNODE_STMT:
|
||||||
|
case QUERY_NODE_RESTORE_MNODE_STMT:
|
||||||
|
case QUERY_NODE_RESTORE_VNODE_STMT:
|
||||||
|
code = translateRestoreDnode(pCxt, (SRestoreComponentNodeStmt*)pNode);
|
||||||
|
break;
|
||||||
default:
|
default:
|
||||||
break;
|
break;
|
||||||
}
|
}
|
||||||
|
|
File diff suppressed because it is too large
Load Diff
|
@ -133,6 +133,63 @@ TEST_F(ParserExplainToSyncdbTest, redistributeVgroup) {
|
||||||
run("REDISTRIBUTE VGROUP 5 DNODE 10 DNODE 20 DNODE 30");
|
run("REDISTRIBUTE VGROUP 5 DNODE 10 DNODE 20 DNODE 30");
|
||||||
}
|
}
|
||||||
|
|
||||||
|
TEST_F(ParserExplainToSyncdbTest, restoreDnode) {
|
||||||
|
useDb("root", "test");
|
||||||
|
|
||||||
|
SRestoreDnodeReq expect = {0};
|
||||||
|
|
||||||
|
auto clearRestoreDnodeReq = [&]() { memset(&expect, 0, sizeof(SRestoreDnodeReq)); };
|
||||||
|
|
||||||
|
auto setRestoreDnodeReq = [&](int32_t dnodeId, int8_t type) {
|
||||||
|
expect.dnodeId = dnodeId;
|
||||||
|
expect.restoreType = type;
|
||||||
|
};
|
||||||
|
|
||||||
|
setCheckDdlFunc([&](const SQuery* pQuery, ParserStage stage) {
|
||||||
|
int32_t expectNodeType = 0;
|
||||||
|
switch (expect.restoreType) {
|
||||||
|
case RESTORE_TYPE__ALL:
|
||||||
|
expectNodeType = QUERY_NODE_RESTORE_DNODE_STMT;
|
||||||
|
break;
|
||||||
|
case RESTORE_TYPE__MNODE:
|
||||||
|
expectNodeType = QUERY_NODE_RESTORE_MNODE_STMT;
|
||||||
|
break;
|
||||||
|
case RESTORE_TYPE__VNODE:
|
||||||
|
expectNodeType = QUERY_NODE_RESTORE_VNODE_STMT;
|
||||||
|
break;
|
||||||
|
case RESTORE_TYPE__QNODE:
|
||||||
|
expectNodeType = QUERY_NODE_RESTORE_QNODE_STMT;
|
||||||
|
break;
|
||||||
|
default:
|
||||||
|
break;
|
||||||
|
}
|
||||||
|
ASSERT_EQ(nodeType(pQuery->pRoot), expectNodeType);
|
||||||
|
ASSERT_EQ(pQuery->pCmdMsg->msgType, TDMT_MND_RESTORE_DNODE);
|
||||||
|
SRestoreDnodeReq req = {0};
|
||||||
|
ASSERT_EQ(tDeserializeSRestoreDnodeReq(pQuery->pCmdMsg->pMsg, pQuery->pCmdMsg->msgLen, &req), TSDB_CODE_SUCCESS);
|
||||||
|
ASSERT_EQ(req.dnodeId, expect.dnodeId);
|
||||||
|
ASSERT_EQ(req.restoreType, expect.restoreType);
|
||||||
|
});
|
||||||
|
|
||||||
|
setRestoreDnodeReq(1, RESTORE_TYPE__ALL);
|
||||||
|
run("RESTORE DNODE 1");
|
||||||
|
clearRestoreDnodeReq();
|
||||||
|
|
||||||
|
setRestoreDnodeReq(2, RESTORE_TYPE__MNODE);
|
||||||
|
run("RESTORE MNODE ON DNODE 2");
|
||||||
|
clearRestoreDnodeReq();
|
||||||
|
|
||||||
|
setRestoreDnodeReq(1, RESTORE_TYPE__VNODE);
|
||||||
|
run("RESTORE VNODE ON DNODE 1");
|
||||||
|
clearRestoreDnodeReq();
|
||||||
|
|
||||||
|
setRestoreDnodeReq(2, RESTORE_TYPE__QNODE);
|
||||||
|
run("RESTORE QNODE ON DNODE 2");
|
||||||
|
clearRestoreDnodeReq();
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
// todo reset query cache
|
// todo reset query cache
|
||||||
|
|
||||||
TEST_F(ParserExplainToSyncdbTest, revoke) {
|
TEST_F(ParserExplainToSyncdbTest, revoke) {
|
||||||
|
|
|
@ -283,6 +283,14 @@ int32_t tfsMkdir(STfs *pTfs, const char *rname) {
|
||||||
return 0;
|
return 0;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
bool tfsDirExistAt(STfs *pTfs, const char *rname, SDiskID diskId) {
|
||||||
|
STfsDisk *pDisk = TFS_DISK_AT(pTfs, diskId);
|
||||||
|
char aname[TMPNAME_LEN];
|
||||||
|
|
||||||
|
snprintf(aname, TMPNAME_LEN, "%s%s%s", pDisk->path, TD_DIRSEP, rname);
|
||||||
|
return taosDirExist(aname);
|
||||||
|
}
|
||||||
|
|
||||||
int32_t tfsRmdir(STfs *pTfs, const char *rname) {
|
int32_t tfsRmdir(STfs *pTfs, const char *rname) {
|
||||||
if (rname[0] == 0) {
|
if (rname[0] == 0) {
|
||||||
return 0;
|
return 0;
|
||||||
|
|
|
@ -320,6 +320,9 @@ TAOS_DEFINE_ERROR(TSDB_CODE_QNODE_NOT_DEPLOYED, "Qnode not deployed")
|
||||||
TAOS_DEFINE_ERROR(TSDB_CODE_SNODE_NOT_FOUND, "Snode not found")
|
TAOS_DEFINE_ERROR(TSDB_CODE_SNODE_NOT_FOUND, "Snode not found")
|
||||||
TAOS_DEFINE_ERROR(TSDB_CODE_SNODE_ALREADY_DEPLOYED, "Snode already deployed")
|
TAOS_DEFINE_ERROR(TSDB_CODE_SNODE_ALREADY_DEPLOYED, "Snode already deployed")
|
||||||
TAOS_DEFINE_ERROR(TSDB_CODE_SNODE_NOT_DEPLOYED, "Snode not deployed")
|
TAOS_DEFINE_ERROR(TSDB_CODE_SNODE_NOT_DEPLOYED, "Snode not deployed")
|
||||||
|
TAOS_DEFINE_ERROR(TSDB_CODE_MNODE_NOT_CATCH_UP, "Mnode didn't catch the leader")
|
||||||
|
TAOS_DEFINE_ERROR(TSDB_CODE_MNODE_ALREADY_IS_VOTER, "Mnode already is a leader")
|
||||||
|
TAOS_DEFINE_ERROR(TSDB_CODE_MNODE_ONLY_TWO_MNODE, "Only two mnodes exist")
|
||||||
|
|
||||||
// vnode
|
// vnode
|
||||||
TAOS_DEFINE_ERROR(TSDB_CODE_VND_INVALID_VGROUP_ID, "Vnode is closed or removed")
|
TAOS_DEFINE_ERROR(TSDB_CODE_VND_INVALID_VGROUP_ID, "Vnode is closed or removed")
|
||||||
|
@ -335,6 +338,9 @@ TAOS_DEFINE_ERROR(TSDB_CODE_VND_NO_AVAIL_BUFPOOL, "No availabe buffer po
|
||||||
TAOS_DEFINE_ERROR(TSDB_CODE_VND_STOPPED, "Vnode stopped")
|
TAOS_DEFINE_ERROR(TSDB_CODE_VND_STOPPED, "Vnode stopped")
|
||||||
TAOS_DEFINE_ERROR(TSDB_CODE_VND_DUP_REQUEST, "Duplicate write request")
|
TAOS_DEFINE_ERROR(TSDB_CODE_VND_DUP_REQUEST, "Duplicate write request")
|
||||||
TAOS_DEFINE_ERROR(TSDB_CODE_VND_QUERY_BUSY, "Query busy")
|
TAOS_DEFINE_ERROR(TSDB_CODE_VND_QUERY_BUSY, "Query busy")
|
||||||
|
TAOS_DEFINE_ERROR(TSDB_CODE_VND_NOT_CATCH_UP, "Vnode didn't catch up its leader")
|
||||||
|
TAOS_DEFINE_ERROR(TSDB_CODE_VND_ALREADY_IS_VOTER, "Vnode already is a voter")
|
||||||
|
TAOS_DEFINE_ERROR(TSDB_CODE_VND_DIR_ALREADY_EXIST, "Vnode directory already exist")
|
||||||
|
|
||||||
// tsdb
|
// tsdb
|
||||||
TAOS_DEFINE_ERROR(TSDB_CODE_TDB_INVALID_TABLE_ID, "Invalid table ID")
|
TAOS_DEFINE_ERROR(TSDB_CODE_TDB_INVALID_TABLE_ID, "Invalid table ID")
|
||||||
|
|
Loading…
Reference in New Issue