提交 a086019d 编写于 作者: H Hongze Cheng

more concurrency fix

上级 bce29321
...@@ -15,94 +15,99 @@ ...@@ -15,94 +15,99 @@
#include "tsdb.h" #include "tsdb.h"
static int32_t tsdbDoRetentionImpl(STsdb *pTsdb, int64_t now, int8_t try, int8_t *canDo) { static bool tsdbShouldDoRetention(STsdb *pTsdb, int64_t now) {
int32_t code = 0; for (int32_t iSet = 0; iSet < taosArrayGetSize(pTsdb->fs.aDFileSet); iSet++) {
#if 0 SDFileSet *pSet = (SDFileSet *)taosArrayGet(pTsdb->fs.aDFileSet, iSet);
STsdbFSState *pState; int32_t expLevel = tsdbFidLevel(pSet->fid, &pTsdb->keepCfg, now);
SDiskID did;
if (expLevel == pSet->diskId.level) continue;
if (try) { if (expLevel < 0) {
pState = pTsdb->pFS->cState; return true;
*canDo = 0;
} else { } else {
pState = pTsdb->pFS->nState; if (tfsAllocDisk(pTsdb->pVnode->pTfs, expLevel, &did) < 0) {
return false;
} }
for (int32_t iSet = 0; iSet < taosArrayGetSize(pState->aDFileSet); iSet++) { if (did.level == pSet->diskId.level) continue;
SDFileSet *pDFileSet = (SDFileSet *)taosArrayGet(pState->aDFileSet, iSet);
int32_t expLevel = tsdbFidLevel(pDFileSet->fid, &pTsdb->keepCfg, now); return true;
SDiskID did; }
}
return false;
}
// check int32_t tsdbDoRetention(STsdb *pTsdb, int64_t now) {
if (expLevel == pDFileSet->diskId.id) continue; int32_t code = 0;
if (!tsdbShouldDoRetention(pTsdb, now)) {
return code;
}
// do retention
STsdbFS fs;
code = tsdbFSCopy(pTsdb, &fs);
if (code) goto _err;
for (int32_t iSet = 0; iSet < taosArrayGetSize(fs.aDFileSet); iSet++) {
SDFileSet *pSet = (SDFileSet *)taosArrayGet(pTsdb->fs.aDFileSet, iSet);
int32_t expLevel = tsdbFidLevel(pSet->fid, &pTsdb->keepCfg, now);
SDiskID did;
// delete or move
if (expLevel < 0) { if (expLevel < 0) {
if (try) { taosMemoryFree(pSet->pHeadF);
*canDo = 1; taosMemoryFree(pSet->pDataF);
} else { taosMemoryFree(pSet->pLastF);
tsdbFSStateDeleteDFileSet(pState, pDFileSet->fid); taosMemoryFree(pSet->pSmaF);
taosArrayRemove(fs.aDFileSet, iSet);
iSet--; iSet--;
}
} else { } else {
// alloc
if (tfsAllocDisk(pTsdb->pVnode->pTfs, expLevel, &did) < 0) { if (tfsAllocDisk(pTsdb->pVnode->pTfs, expLevel, &did) < 0) {
code = terrno; code = terrno;
goto _exit; goto _exit;
} }
if (did.level == pDFileSet->diskId.level) continue; if (did.level == pSet->diskId.level) continue;
if (try) {
*canDo = 1;
} else {
// copy the file to new disk
SDFileSet nDFileSet = *pDFileSet;
nDFileSet.diskId = did;
tfsMkdirRecurAt(pTsdb->pVnode->pTfs, pTsdb->path, did); // copy file to new disk (todo)
SDFileSet fSet = *pSet;
fSet.diskId = did;
code = tsdbDFileSetCopy(pTsdb, pDFileSet, &nDFileSet); code = tsdbDFileSetCopy(pTsdb, pSet, &fSet);
if (code) goto _exit; if (code) goto _err;
code = tsdbFSUpsertFSet(pState, &nDFileSet); code = tsdbFSUpsertFSet(&fs, &fSet);
if (code) goto _exit; if (code) goto _err;
}
}
} }
#endif /* code */
_exit: }
return code;
}
int32_t tsdbDoRetention(STsdb *pTsdb, int64_t now) { // do change fs
int32_t code = 0; code = tsdbFSCommit1(pTsdb, &fs);
#if 0 if (code) goto _err;
int8_t canDo;
// try taosThreadRwlockWrlock(&pTsdb->rwLock);
tsdbDoRetentionImpl(pTsdb, now, 1, &canDo);
if (!canDo) goto _exit;
// begin code = tsdbFSCommit2(pTsdb, &fs);
code = tsdbFSBegin(pTsdb->pFS); if (code) {
if (code) goto _err; taosThreadRwlockUnlock(&pTsdb->rwLock);
goto _err;
}
// do retention taosThreadRwlockUnlock(&pTsdb->rwLock);
code = tsdbDoRetentionImpl(pTsdb, now, 0, NULL);
if (code) goto _err;
// commit tsdbFSDestroy(&fs);
code = tsdbFSCommit(pTsdb->pFS);
if (code) goto _err;
_exit: _exit:
return code; return code;
_err: _err:
tsdbError("vgId:%d tsdb do retention failed since %s", TD_VID(pTsdb->pVnode), tstrerror(code)); tsdbError("vgId:%d tsdb do retention failed since %s", TD_VID(pTsdb->pVnode), tstrerror(code));
tsdbFSRollback(pTsdb->pFS); ASSERT(0);
#endif // tsdbFSRollback(pTsdb->pFS);
return code; return code;
} }
\ No newline at end of file
Markdown is supported
0% .
You are about to add 0 people to the discussion. Proceed with caution.
先完成此消息的编辑!
想要评论请 注册