TDengine/source/dnode/vnode/src/tsdb/dev/tsdbFS.c

553 lines
14 KiB
C
Raw Normal View History

2023-03-23 09:15:51 +00:00
/*
* 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/>.
2023-03-24 09:57:37 +00:00
*/
2023-05-08 02:27:55 +00:00
#include "inc/tsdbFS.h"
2023-03-27 08:30:22 +00:00
2023-05-09 06:50:37 +00:00
#define TSDB_FS_EDIT_MIN TSDB_FEDIT_COMMIT
#define TSDB_FS_EDIT_MAX (TSDB_FEDIT_MERGE + 1)
2023-05-08 02:27:55 +00:00
enum {
TSDB_FS_STATE_NONE = 0,
TSDB_FS_STATE_OPEN,
TSDB_FS_STATE_EDIT,
TSDB_FS_STATE_CLOSE,
};
2023-05-08 05:20:15 +00:00
typedef enum {
TSDB_FCURRENT = 1,
2023-05-08 08:16:45 +00:00
TSDB_FCURRENT_C, // for commit
TSDB_FCURRENT_M, // for merge
2023-05-08 05:20:15 +00:00
} EFCurrentT;
static const char *gCurrentFname[] = {
[TSDB_FCURRENT] = "current.json",
2023-05-09 06:50:37 +00:00
[TSDB_FCURRENT_C] = "current.c.json",
[TSDB_FCURRENT_M] = "current.m.json",
2023-05-08 05:20:15 +00:00
};
2023-05-15 09:14:45 +00:00
static int32_t create_fs(STsdb *pTsdb, STFileSystem **fs) {
fs[0] = taosMemoryCalloc(1, sizeof(*fs[0]));
if (fs[0] == NULL) return TSDB_CODE_OUT_OF_MEMORY;
fs[0]->cstate = taosArrayInit(16, sizeof(STFileSet));
fs[0]->nstate = taosArrayInit(16, sizeof(STFileSet));
if (fs[0]->cstate == NULL || fs[0]->nstate == NULL) {
taosArrayDestroy(fs[0]->nstate);
taosArrayDestroy(fs[0]->cstate);
taosMemoryFree(fs[0]);
2023-04-07 07:12:31 +00:00
return TSDB_CODE_OUT_OF_MEMORY;
}
2023-05-15 09:14:45 +00:00
fs[0]->pTsdb = pTsdb;
fs[0]->state = TSDB_FS_STATE_NONE;
tsem_init(&fs[0]->canEdit, 0, 1);
fs[0]->neid = 0;
2023-04-07 07:12:31 +00:00
2023-03-27 09:07:59 +00:00
return 0;
}
2023-05-15 09:14:45 +00:00
static int32_t destroy_fs(STFileSystem **fs) {
if (fs[0] == NULL) return 0;
taosArrayDestroy(fs[0]->nstate);
taosArrayDestroy(fs[0]->cstate);
tsem_destroy(&fs[0]->canEdit);
taosMemoryFree(fs[0]);
fs[0] = NULL;
2023-03-27 09:07:59 +00:00
return 0;
}
2023-05-08 05:20:15 +00:00
static int32_t current_fname(STsdb *pTsdb, char *fname, EFCurrentT ftype) {
2023-04-10 09:52:51 +00:00
if (pTsdb->pVnode->pTfs) {
snprintf(fname, //
TSDB_FILENAME_LEN, //
"%s%s%s%s%s", //
tfsGetPrimaryPath(pTsdb->pVnode->pTfs), //
TD_DIRSEP, //
pTsdb->path, //
TD_DIRSEP, //
2023-05-08 05:20:15 +00:00
gCurrentFname[ftype]);
2023-04-10 09:52:51 +00:00
} else {
snprintf(fname, //
TSDB_FILENAME_LEN, //
"%s%s%s", //
pTsdb->path, //
TD_DIRSEP, //
2023-05-08 05:20:15 +00:00
gCurrentFname[ftype]);
2023-04-06 08:26:41 +00:00
}
return 0;
}
2023-05-08 08:16:45 +00:00
static int32_t fs_from_json_str(const char *pData, STFileSystem *pFS) {
2023-04-10 09:52:51 +00:00
int32_t code = 0;
int32_t lino;
2023-05-08 08:16:45 +00:00
ASSERTS(0, "TODO: Not implemented yet");
2023-04-10 09:52:51 +00:00
2023-05-08 08:16:45 +00:00
_exit:
return code;
}
2023-04-10 09:52:51 +00:00
2023-05-08 08:16:45 +00:00
static int32_t save_json(const cJSON *json, const char *fname) {
2023-05-08 10:15:31 +00:00
int32_t code = 0;
2023-05-08 08:16:45 +00:00
char *data = cJSON_Print(json);
if (data == NULL) return TSDB_CODE_OUT_OF_MEMORY;
TdFilePtr fp = taosOpenFile(fname, TD_FILE_WRITE | TD_FILE_CREATE | TD_FILE_TRUNC);
if (fp == NULL) {
code = TAOS_SYSTEM_ERROR(code);
goto _exit;
2023-04-10 09:52:51 +00:00
}
2023-05-08 08:16:45 +00:00
if (taosWriteFile(fp, data, strlen(data) + 1) < 0) {
code = TAOS_SYSTEM_ERROR(code);
goto _exit;
2023-04-10 09:52:51 +00:00
}
2023-05-08 08:16:45 +00:00
if (taosFsyncFile(fp) < 0) {
code = TAOS_SYSTEM_ERROR(code);
goto _exit;
}
2023-04-10 09:52:51 +00:00
2023-05-08 08:16:45 +00:00
taosCloseFile(&fp);
2023-04-10 09:52:51 +00:00
_exit:
2023-05-08 08:16:45 +00:00
taosMemoryFree(data);
2023-04-10 09:52:51 +00:00
return code;
}
2023-05-08 10:15:31 +00:00
static int32_t load_json(const char *fname, cJSON **json) {
int32_t code = 0;
void *data = NULL;
TdFilePtr fp = taosOpenFile(fname, TD_FILE_READ);
if (fp == NULL) return TAOS_SYSTEM_ERROR(code);
int64_t size;
if (taosFStatFile(fp, &size, NULL) < 0) {
code = TAOS_SYSTEM_ERROR(code);
goto _exit;
}
data = taosMemoryMalloc(size);
if (data == NULL) {
code = TSDB_CODE_OUT_OF_MEMORY;
goto _exit;
}
if (taosReadFile(fp, data, size) < 0) {
code = TAOS_SYSTEM_ERROR(code);
goto _exit;
}
json[0] = cJSON_Parse(data);
if (json[0] == NULL) {
code = TSDB_CODE_FILE_CORRUPTED;
goto _exit;
}
_exit:
taosCloseFile(&fp);
if (data) taosMemoryFree(data);
if (code) json[0] = NULL;
return code;
}
2023-05-08 08:16:45 +00:00
static int32_t save_fs(int64_t eid, SArray *aTFileSet, const char *fname) {
2023-04-10 09:52:51 +00:00
int32_t code = 0;
2023-05-08 08:16:45 +00:00
int32_t lino = 0;
2023-04-10 09:52:51 +00:00
2023-05-08 08:16:45 +00:00
cJSON *json = cJSON_CreateObject();
if (json == NULL) return TSDB_CODE_OUT_OF_MEMORY;
2023-04-10 09:52:51 +00:00
2023-05-08 08:16:45 +00:00
// fmtv
if (cJSON_AddNumberToObject(json, "fmtv", 1) == NULL) {
code = TSDB_CODE_OUT_OF_MEMORY;
TSDB_CHECK_CODE(code, lino, _exit)
2023-04-10 09:52:51 +00:00
}
2023-05-08 08:16:45 +00:00
// eid
if (cJSON_AddNumberToObject(json, "eid", eid) == NULL) {
code = TSDB_CODE_OUT_OF_MEMORY;
TSDB_CHECK_CODE(code, lino, _exit)
2023-04-10 09:52:51 +00:00
}
2023-05-08 08:16:45 +00:00
// fset
cJSON *ajson = cJSON_AddArrayToObject(json, "fset");
if (ajson == NULL) {
code = TSDB_CODE_OUT_OF_MEMORY;
TSDB_CHECK_CODE(code, lino, _exit)
}
for (int32_t i = 0; i < taosArrayGetSize(aTFileSet); i++) {
STFileSet *pFileSet = (STFileSet *)taosArrayGet(aTFileSet, i);
2023-05-09 06:50:37 +00:00
cJSON *item;
2023-05-08 08:16:45 +00:00
2023-05-09 06:50:37 +00:00
if ((item = cJSON_CreateObject()) == NULL) {
2023-05-08 08:16:45 +00:00
code = TSDB_CODE_OUT_OF_MEMORY;
TSDB_CHECK_CODE(code, lino, _exit)
}
2023-05-09 06:50:37 +00:00
code = tsdbFileSetToJson(pFileSet, item);
2023-04-10 09:52:51 +00:00
TSDB_CHECK_CODE(code, lino, _exit);
2023-05-08 08:16:45 +00:00
2023-05-09 06:50:37 +00:00
cJSON_AddItemToArray(ajson, item);
2023-04-10 09:52:51 +00:00
}
2023-05-08 08:16:45 +00:00
code = save_json(json, fname);
TSDB_CHECK_CODE(code, lino, _exit)
2023-04-10 09:52:51 +00:00
_exit:
if (code) {
2023-05-08 08:16:45 +00:00
tsdbError("%s failed at line %d since %s", __func__, lino, tstrerror(code));
2023-04-10 09:52:51 +00:00
}
2023-05-08 08:16:45 +00:00
cJSON_Delete(json);
2023-04-10 09:52:51 +00:00
return code;
2023-04-07 07:12:31 +00:00
}
2023-05-08 10:15:31 +00:00
static int32_t load_fs(const char *fname, SArray *aTFileSet, int64_t *eid) {
int32_t code = 0;
int32_t lino = 0;
taosArrayClear(aTFileSet);
// load json
cJSON *json = NULL;
code = load_json(fname, &json);
TSDB_CHECK_CODE(code, lino, _exit)
// parse json
const cJSON *item;
/* fmtv */
item = cJSON_GetObjectItem(json, "fmtv");
if (cJSON_IsNumber(item)) {
ASSERT(item->valuedouble == 1);
} else {
2023-05-09 06:50:37 +00:00
TSDB_CHECK_CODE(code = TSDB_CODE_FILE_CORRUPTED, lino, _exit)
2023-05-08 10:15:31 +00:00
}
/* eid */
item = cJSON_GetObjectItem(json, "eid");
if (cJSON_IsNumber(item)) {
eid[0] = item->valuedouble;
} else {
2023-05-09 06:50:37 +00:00
TSDB_CHECK_CODE(code = TSDB_CODE_FILE_CORRUPTED, lino, _exit)
2023-05-08 10:15:31 +00:00
}
/* fset */
item = cJSON_GetObjectItem(json, "fset");
if (cJSON_IsArray(item)) {
const cJSON *titem;
cJSON_ArrayForEach(titem, item) {
2023-05-09 06:50:37 +00:00
STFileSet *pFileSet;
if ((pFileSet = taosArrayReserve(aTFileSet, 1)) == NULL) {
TSDB_CHECK_CODE(code = TSDB_CODE_OUT_OF_MEMORY, lino, _exit);
2023-05-08 10:15:31 +00:00
}
code = tsdbFileSetFromJson(titem, pFileSet);
TSDB_CHECK_CODE(code, lino, _exit)
}
} else {
2023-05-09 06:50:37 +00:00
TSDB_CHECK_CODE(code = TSDB_CODE_FILE_CORRUPTED, lino, _exit)
2023-05-08 10:15:31 +00:00
}
_exit:
if (code) {
tsdbError("%s failed at line %d since %s, fname:%s", __func__, lino, tstrerror(code), fname);
}
if (json) cJSON_Delete(json);
return code;
2023-04-07 07:12:31 +00:00
}
2023-05-09 08:24:18 +00:00
static int32_t apply_commit(STFileSystem *fs) {
// TODO
return 0;
}
static int32_t commit_edit(STFileSystem *fs) {
2023-05-09 06:50:37 +00:00
char current[TSDB_FILENAME_LEN];
char current_t[TSDB_FILENAME_LEN];
2023-04-07 08:52:30 +00:00
2023-05-09 08:24:18 +00:00
current_fname(fs->pTsdb, current, TSDB_FCURRENT);
if (fs->etype == TSDB_FEDIT_COMMIT) {
current_fname(fs->pTsdb, current, TSDB_FCURRENT_C);
} else if (fs->etype == TSDB_FEDIT_MERGE) {
current_fname(fs->pTsdb, current, TSDB_FCURRENT_M);
2023-05-09 06:50:37 +00:00
} else {
ASSERT(0);
2023-04-07 08:52:30 +00:00
}
2023-05-09 06:50:37 +00:00
int32_t code;
int32_t lino;
if ((code = taosRenameFile(current_t, current))) {
TSDB_CHECK_CODE(code = TAOS_SYSTEM_ERROR(code), lino, _exit)
}
2023-04-07 08:52:30 +00:00
2023-05-09 08:24:18 +00:00
code = apply_commit(fs);
TSDB_CHECK_CODE(code, lino, _exit)
2023-05-09 06:50:37 +00:00
_exit:
if (code) {
2023-05-09 08:24:18 +00:00
tsdbError("vgId:%d %s failed at line %d since %s", TD_VID(fs->pTsdb->pVnode), __func__, lino, tstrerror(code));
} else {
tsdbInfo("vgId:%d %s success, eid:%" PRId64 " etype:%d", TD_VID(fs->pTsdb->pVnode), __func__, fs->eid, fs->etype);
2023-05-09 06:50:37 +00:00
}
return code;
2023-04-07 07:12:31 +00:00
}
2023-05-09 08:24:18 +00:00
// static int32_t
static int32_t apply_abort(STFileSystem *fs) {
// TODO
return 0;
}
static int32_t abort_edit(STFileSystem *fs) {
2023-05-09 06:50:37 +00:00
char fname[TSDB_FILENAME_LEN];
2023-04-07 08:52:30 +00:00
2023-05-09 08:24:18 +00:00
if (fs->etype == TSDB_FEDIT_COMMIT) {
current_fname(fs->pTsdb, fname, TSDB_FCURRENT_C);
} else if (fs->etype == TSDB_FEDIT_MERGE) {
current_fname(fs->pTsdb, fname, TSDB_FCURRENT_M);
2023-05-09 06:50:37 +00:00
} else {
ASSERT(0);
}
2023-04-07 08:52:30 +00:00
2023-05-09 08:24:18 +00:00
int32_t code;
int32_t lino;
if ((code = taosRemoveFile(fname))) {
TSDB_CHECK_CODE(code = TAOS_SYSTEM_ERROR(code), lino, _exit)
}
2023-04-07 08:52:30 +00:00
2023-05-09 08:24:18 +00:00
code = apply_abort(fs);
TSDB_CHECK_CODE(code, lino, _exit)
_exit:
if (code) {
tsdbError("vgId:%d %s failed since %s", TD_VID(fs->pTsdb->pVnode), __func__, tstrerror(code));
} else {
tsdbInfo("vgId:%d %s success, eid:%" PRId64 " etype:%d", TD_VID(fs->pTsdb->pVnode), __func__, fs->eid, fs->etype);
}
return code;
2023-04-07 08:52:30 +00:00
}
2023-05-09 08:24:18 +00:00
static int32_t scan_and_fix_fs(STFileSystem *pFS) {
2023-05-09 06:50:37 +00:00
// TODO
2023-04-07 07:12:31 +00:00
return 0;
}
2023-05-08 05:20:15 +00:00
static int32_t update_fs_if_needed(STFileSystem *pFS) {
// TODO
return 0;
}
2023-05-09 06:50:37 +00:00
static int32_t open_fs(STFileSystem *fs, int8_t rollback) {
2023-04-07 07:12:31 +00:00
int32_t code = 0;
2023-05-08 02:27:55 +00:00
int32_t lino = 0;
2023-05-09 06:50:37 +00:00
STsdb *pTsdb = fs->pTsdb;
2023-04-07 07:12:31 +00:00
2023-05-09 06:50:37 +00:00
code = update_fs_if_needed(fs);
2023-05-08 05:20:15 +00:00
TSDB_CHECK_CODE(code, lino, _exit)
2023-04-07 07:12:31 +00:00
2023-05-08 05:20:15 +00:00
char fCurrent[TSDB_FILENAME_LEN];
char cCurrent[TSDB_FILENAME_LEN];
char mCurrent[TSDB_FILENAME_LEN];
2023-04-07 07:12:31 +00:00
2023-05-08 05:20:15 +00:00
current_fname(pTsdb, fCurrent, TSDB_FCURRENT);
current_fname(pTsdb, cCurrent, TSDB_FCURRENT_C);
2023-05-08 08:16:45 +00:00
current_fname(pTsdb, mCurrent, TSDB_FCURRENT_M);
2023-04-07 07:12:31 +00:00
2023-05-08 05:20:15 +00:00
if (taosCheckExistFile(fCurrent)) { // current.json exists
2023-05-09 06:50:37 +00:00
code = load_fs(fCurrent, fs->cstate, &fs->neid);
2023-05-08 05:20:15 +00:00
TSDB_CHECK_CODE(code, lino, _exit);
2023-04-07 07:12:31 +00:00
2023-05-08 05:20:15 +00:00
if (taosCheckExistFile(cCurrent)) {
2023-05-09 06:50:37 +00:00
// current.c.json exists
fs->etype = TSDB_FEDIT_COMMIT;
2023-05-08 05:20:15 +00:00
if (rollback) {
2023-05-09 06:50:37 +00:00
code = abort_edit(fs);
2023-05-08 05:20:15 +00:00
TSDB_CHECK_CODE(code, lino, _exit);
} else {
2023-05-09 06:50:37 +00:00
code = load_fs(cCurrent, fs->nstate, &fs->eid);
TSDB_CHECK_CODE(code, lino, _exit)
code = commit_edit(fs);
2023-04-07 07:12:31 +00:00
TSDB_CHECK_CODE(code, lino, _exit);
}
2023-05-09 06:50:37 +00:00
} else if (taosCheckExistFile(mCurrent)) {
// current.m.json exists
fs->etype = TSDB_FEDIT_MERGE;
code = abort_edit(fs);
2023-04-07 07:12:31 +00:00
TSDB_CHECK_CODE(code, lino, _exit);
}
2023-05-08 08:16:45 +00:00
2023-05-09 08:24:18 +00:00
code = scan_and_fix_fs(fs);
2023-05-08 08:16:45 +00:00
TSDB_CHECK_CODE(code, lino, _exit);
2023-05-08 05:20:15 +00:00
} else {
2023-05-15 09:14:45 +00:00
code = save_fs(0, fs->cstate, fCurrent);
2023-05-08 05:20:15 +00:00
TSDB_CHECK_CODE(code, lino, _exit);
2023-04-07 07:12:31 +00:00
}
_exit:
if (code) {
2023-05-08 02:27:55 +00:00
tsdbError("vgId:%d %s failed at line %d since %s", TD_VID(pTsdb->pVnode), __func__, lino, tstrerror(code));
2023-04-07 07:12:31 +00:00
} else {
2023-05-08 02:27:55 +00:00
tsdbInfo("vgId:%d %s success", TD_VID(pTsdb->pVnode), __func__);
2023-04-07 07:12:31 +00:00
}
2023-03-27 09:07:59 +00:00
return 0;
}
2023-05-08 02:27:55 +00:00
static int32_t close_file_system(STFileSystem *pFS) {
2023-04-07 07:12:31 +00:00
ASSERTS(0, "TODO: Not implemented yet");
2023-03-27 08:30:22 +00:00
return 0;
}
2023-03-27 09:07:59 +00:00
2023-05-08 02:27:55 +00:00
static int32_t apply_edit(STFileSystem *pFS) {
2023-04-11 09:04:52 +00:00
int32_t code = 0;
2023-04-07 07:12:31 +00:00
ASSERTS(0, "TODO: Not implemented yet");
2023-04-11 09:04:52 +00:00
return code;
2023-04-06 08:26:41 +00:00
}
2023-05-08 02:27:55 +00:00
static int32_t fset_cmpr_fn(const struct STFileSet *pSet1, const struct STFileSet *pSet2) {
2023-04-12 07:18:12 +00:00
if (pSet1->fid < pSet2->fid) {
return -1;
} else if (pSet1->fid > pSet2->fid) {
return 1;
}
return 0;
}
2023-05-08 02:27:55 +00:00
static int32_t edit_fs(STFileSystem *pFS, const SArray *aFileOp) {
2023-04-11 09:04:52 +00:00
int32_t code = 0;
2023-05-12 01:07:50 +00:00
int32_t lino = 0;
2023-04-11 09:04:52 +00:00
2023-05-11 10:16:55 +00:00
STFileSet *pSet = NULL;
2023-04-11 07:34:40 +00:00
for (int32_t iop = 0; iop < taosArrayGetSize(aFileOp); iop++) {
2023-05-11 10:16:55 +00:00
struct STFileOp *op = taosArrayGet(aFileOp, iop);
2023-04-12 07:18:12 +00:00
2023-05-11 10:16:55 +00:00
if (pSet == NULL || pSet->fid != op->fid) {
STFileSet fset = {.fid = op->fid};
pSet = taosArraySearch(pFS->nstate, &fset, (__compar_fn_t)tsdbFSetCmprFn, TD_EQ);
2023-04-12 07:18:12 +00:00
}
2023-05-12 08:23:07 +00:00
// create fset if need
2023-05-12 01:07:50 +00:00
if (pSet == NULL) {
ASSERT(op->oState.size == 0 && op->nState.size > 0);
2023-05-12 08:23:07 +00:00
STFileSet fset = {.fid = op->fid};
int32_t idx = taosArraySearchIdx(pFS->nstate, &fset, (__compar_fn_t)tsdbFSetCmprFn, TD_GT);
if (idx < 0) idx = taosArrayGetSize(pFS->nstate);
pSet = taosArrayInsert(pFS->nstate, idx, &fset);
if (pSet == NULL) {
code = TSDB_CODE_OUT_OF_MEMORY;
TSDB_CHECK_CODE(code, lino, _exit)
}
tsdbFileSetInit(pSet);
2023-05-12 01:07:50 +00:00
}
code = tsdbFSetEdit(pSet, op);
TSDB_CHECK_CODE(code, lino, _exit)
2023-04-11 07:34:40 +00:00
}
2023-04-11 09:04:52 +00:00
_exit:
2023-04-06 08:26:41 +00:00
return 0;
}
2023-05-15 09:14:45 +00:00
int32_t tsdbOpenFS(STsdb *pTsdb, STFileSystem **fs, int8_t rollback) {
2023-03-27 09:07:59 +00:00
int32_t code;
int32_t lino;
2023-05-15 09:14:45 +00:00
code = create_fs(pTsdb, fs);
2023-03-27 09:07:59 +00:00
TSDB_CHECK_CODE(code, lino, _exit);
2023-05-15 09:14:45 +00:00
code = open_fs(fs[0], rollback);
2023-05-08 02:27:55 +00:00
TSDB_CHECK_CODE(code, lino, _exit)
2023-03-27 09:07:59 +00:00
_exit:
if (code) {
2023-05-08 02:27:55 +00:00
tsdbError("vgId:%d %s failed at line %d since %s", TD_VID(pTsdb->pVnode), __func__, lino, tstrerror(code));
2023-05-15 09:14:45 +00:00
destroy_fs(fs);
2023-03-27 09:07:59 +00:00
} else {
2023-05-08 02:27:55 +00:00
tsdbInfo("vgId:%d %s success", TD_VID(pTsdb->pVnode), __func__);
2023-03-27 09:07:59 +00:00
}
return 0;
}
2023-05-09 08:24:18 +00:00
int32_t tsdbCloseFS(STFileSystem **ppFS) {
2023-03-27 09:07:59 +00:00
if (ppFS[0] == NULL) return 0;
close_file_system(ppFS[0]);
2023-05-08 05:20:15 +00:00
destroy_fs(ppFS);
2023-03-27 09:07:59 +00:00
return 0;
}
2023-04-06 08:26:41 +00:00
2023-05-11 10:16:55 +00:00
int32_t tsdbFSAllocEid(STFileSystem *pFS, int64_t *eid) {
eid[0] = ++pFS->neid; // TODO: use atomic operation
return 0;
}
int32_t tsdbFSEditBegin(STFileSystem *fs, int64_t eid, const SArray *aFileOp, EFEditT etype) {
2023-04-06 08:26:41 +00:00
int32_t code = 0;
2023-04-11 07:34:40 +00:00
int32_t lino;
2023-05-09 08:46:23 +00:00
char current_t[TSDB_FILENAME_LEN];
2023-04-06 08:26:41 +00:00
2023-05-09 08:46:23 +00:00
if (etype == TSDB_FEDIT_COMMIT) {
current_fname(fs->pTsdb, current_t, TSDB_FCURRENT_C);
} else {
current_fname(fs->pTsdb, current_t, TSDB_FCURRENT_M);
}
tsem_wait(&fs->canEdit);
2023-04-06 08:26:41 +00:00
2023-05-09 08:46:23 +00:00
fs->etype = etype;
2023-05-11 10:16:55 +00:00
fs->eid = eid;
2023-04-06 08:26:41 +00:00
2023-05-09 08:46:23 +00:00
// edit
code = edit_fs(fs, aFileOp);
TSDB_CHECK_CODE(code, lino, _exit);
2023-04-11 07:34:40 +00:00
2023-05-09 08:46:23 +00:00
// save fs
code = save_fs(fs->eid, fs->nstate, current_t);
TSDB_CHECK_CODE(code, lino, _exit)
2023-04-06 08:26:41 +00:00
_exit:
if (code) {
2023-05-09 08:46:23 +00:00
tsdbError("vgId:%d %s failed at line %d since %s, eid:%" PRId64 " etype:%d", TD_VID(fs->pTsdb->pVnode), __func__,
lino, tstrerror(code), fs->eid, etype);
2023-04-07 08:52:30 +00:00
} else {
2023-05-09 08:46:23 +00:00
tsdbInfo("vgId:%d %s done, eid:%" PRId64 " etype:%d", TD_VID(fs->pTsdb->pVnode), __func__, fs->eid, etype);
2023-04-06 08:26:41 +00:00
}
return code;
}
2023-05-09 08:46:23 +00:00
int32_t tsdbFSEditCommit(STFileSystem *fs) {
int32_t code = commit_edit(fs);
tsem_post(&fs->canEdit);
2023-04-06 08:26:41 +00:00
return code;
}
2023-05-09 08:46:23 +00:00
int32_t tsdbFSEditAbort(STFileSystem *fs) {
int32_t code = abort_edit(fs);
tsem_post(&fs->canEdit);
2023-04-06 08:26:41 +00:00
return code;
2023-05-11 10:16:55 +00:00
}
int32_t tsdbFSGetFSet(STFileSystem *fs, int32_t fid, const STFileSet **ppFSet) {
STFileSet fset = {.fid = fid};
ppFSet[0] = taosArraySearch(fs->cstate, &fset, (__compar_fn_t)tsdbFSetCmprFn, TD_EQ);
return 0;
2023-04-06 08:26:41 +00:00
}