Skip to content
体验新版
项目
组织
正在加载...
登录
切换导航
打开侧边栏
taosdata
TDengine
提交
00080750
T
TDengine
项目概览
taosdata
/
TDengine
1 年多 前同步成功
通知
1185
Star
22016
Fork
4786
代码
文件
提交
分支
Tags
贡献者
分支图
Diff
Issue
1
列表
看板
标记
里程碑
合并请求
0
Wiki
0
Wiki
分析
仓库
DevOps
项目成员
Pages
T
TDengine
项目概览
项目概览
详情
发布
仓库
仓库
文件
提交
分支
标签
贡献者
分支图
比较
Issue
1
Issue
1
列表
看板
标记
里程碑
合并请求
0
合并请求
0
Pages
分析
分析
仓库分析
DevOps
Wiki
0
Wiki
成员
成员
收起侧边栏
关闭侧边栏
动态
分支图
创建新Issue
提交
Issue看板
提交
00080750
编写于
10月 17, 2022
作者:
S
Shengliang Guan
浏览文件
操作
浏览文件
下载
电子邮件补丁
差异文件
fix: mnode may deadlock while drop another mnode if it crashed
上级
8fe672fe
变更
4
隐藏空白更改
内联
并排
Showing
4 changed file
with
65 addition
and
49 deletion
+65
-49
source/dnode/mnode/sdb/inc/sdb.h
source/dnode/mnode/sdb/inc/sdb.h
+4
-0
source/dnode/mnode/sdb/src/sdb.c
source/dnode/mnode/sdb/src/sdb.c
+20
-0
source/dnode/mnode/sdb/src/sdbFile.c
source/dnode/mnode/sdb/src/sdbFile.c
+3
-4
source/dnode/mnode/sdb/src/sdbHash.c
source/dnode/mnode/sdb/src/sdbHash.c
+38
-45
未找到文件。
source/dnode/mnode/sdb/inc/sdb.h
浏览文件 @
00080750
...
...
@@ -403,6 +403,10 @@ const char *sdbStatusName(ESdbStatus status);
void
sdbPrintOper
(
SSdb
*
pSdb
,
SSdbRow
*
pRow
,
const
char
*
oper
);
int32_t
sdbGetIdFromRaw
(
SSdb
*
pSdb
,
SSdbRaw
*
pRaw
);
void
sdbWriteLock
(
SSdb
*
pSdb
,
int32_t
type
);
void
sdbReadLock
(
SSdb
*
pSdb
,
int32_t
type
);
void
sdbUnLock
(
SSdb
*
pSdb
,
int32_t
type
);
#ifdef __cplusplus
}
#endif
...
...
source/dnode/mnode/sdb/src/sdb.c
浏览文件 @
00080750
...
...
@@ -181,3 +181,23 @@ void sdbGetCommitInfo(SSdb *pSdb, int64_t *index, int64_t *term, int64_t *config
pSdb
->
applyIndex
,
pSdb
->
applyTerm
,
pSdb
->
applyConfig
,
*
index
,
*
term
,
*
config
);
#endif
}
void
sdbWriteLock
(
SSdb
*
pSdb
,
int32_t
type
)
{
TdThreadRwlock
*
pLock
=
&
pSdb
->
locks
[
type
];
// mTrace("sdb table:%d start write lock:%p", type, pLock);
taosThreadRwlockWrlock
(
pLock
);
// mTrace("sdb table:%d stop write lock:%p", type, pLock);
}
void
sdbReadLock
(
SSdb
*
pSdb
,
int32_t
type
)
{
TdThreadRwlock
*
pLock
=
&
pSdb
->
locks
[
type
];
// mTrace("sdb table:%d start read lock:%p", type, pLock);
taosThreadRwlockRdlock
(
pLock
);
// mTrace("sdb table:%d stop read lock:%p", type, pLock);
}
void
sdbUnLock
(
SSdb
*
pSdb
,
int32_t
type
)
{
TdThreadRwlock
*
pLock
=
&
pSdb
->
locks
[
type
];
// mTrace("sdb table:%d unlock:%p", type, pLock);
taosThreadRwlockUnlock
(
pLock
);
}
source/dnode/mnode/sdb/src/sdbFile.c
浏览文件 @
00080750
...
...
@@ -363,9 +363,8 @@ static int32_t sdbWriteFileImp(SSdb *pSdb) {
mInfo
(
"write %s to sdb file, total %d rows"
,
sdbTableName
(
i
),
sdbGetSize
(
pSdb
,
i
));
SHashObj
*
hash
=
pSdb
->
hashObjs
[
i
];
TdThreadRwlock
*
pLock
=
&
pSdb
->
locks
[
i
];
taosThreadRwlockWrlock
(
pLock
);
SHashObj
*
hash
=
pSdb
->
hashObjs
[
i
];
sdbWriteLock
(
pSdb
,
i
);
SSdbRow
**
ppRow
=
taosHashIterate
(
hash
,
NULL
);
while
(
ppRow
!=
NULL
)
{
...
...
@@ -410,7 +409,7 @@ static int32_t sdbWriteFileImp(SSdb *pSdb) {
sdbFreeRaw
(
pRaw
);
ppRow
=
taosHashIterate
(
hash
,
ppRow
);
}
taosThreadRwlockUnlock
(
pLock
);
sdbUnLock
(
pSdb
,
i
);
}
if
(
code
==
0
)
{
...
...
source/dnode/mnode/sdb/src/sdbHash.c
浏览文件 @
00080750
...
...
@@ -133,12 +133,12 @@ static int32_t sdbGetkeySize(SSdb *pSdb, ESdbType type, const void *pKey) {
}
static
int32_t
sdbInsertRow
(
SSdb
*
pSdb
,
SHashObj
*
hash
,
SSdbRaw
*
pRaw
,
SSdbRow
*
pRow
,
int32_t
keySize
)
{
TdThreadRwlock
*
pLock
=
&
pSdb
->
locks
[
pRow
->
type
]
;
taosThreadRwlockWrlock
(
pLock
);
int32_t
type
=
pRow
->
type
;
sdbWriteLock
(
pSdb
,
type
);
SSdbRow
*
pOldRow
=
taosHashGet
(
hash
,
pRow
->
pObj
,
keySize
);
if
(
pOldRow
!=
NULL
)
{
taosThreadRwlockUnlock
(
pLock
);
sdbUnLock
(
pSdb
,
type
);
sdbFreeRow
(
pSdb
,
pRow
,
false
);
terrno
=
TSDB_CODE_SDB_OBJ_ALREADY_THERE
;
return
terrno
;
...
...
@@ -149,7 +149,7 @@ static int32_t sdbInsertRow(SSdb *pSdb, SHashObj *hash, SSdbRaw *pRaw, SSdbRow *
sdbPrintOper
(
pSdb
,
pRow
,
"insert"
);
if
(
taosHashPut
(
hash
,
pRow
->
pObj
,
keySize
,
&
pRow
,
sizeof
(
void
*
))
!=
0
)
{
taosThreadRwlockUnlock
(
pLock
);
sdbUnLock
(
pSdb
,
type
);
sdbFreeRow
(
pSdb
,
pRow
,
false
);
terrno
=
TSDB_CODE_OUT_OF_MEMORY
;
return
terrno
;
...
...
@@ -164,12 +164,12 @@ static int32_t sdbInsertRow(SSdb *pSdb, SHashObj *hash, SSdbRaw *pRaw, SSdbRow *
taosHashRemove
(
hash
,
pRow
->
pObj
,
keySize
);
sdbFreeRow
(
pSdb
,
pRow
,
false
);
terrno
=
code
;
taosThreadRwlockUnlock
(
pLock
);
sdbUnLock
(
pSdb
,
type
);
return
terrno
;
}
}
taosThreadRwlockUnlock
(
pLock
);
sdbUnLock
(
pSdb
,
type
);
if
(
pSdb
->
keyTypes
[
pRow
->
type
]
==
SDB_KEY_INT32
)
{
pSdb
->
maxId
[
pRow
->
type
]
=
TMAX
(
pSdb
->
maxId
[
pRow
->
type
],
*
((
int32_t
*
)
pRow
->
pObj
));
...
...
@@ -183,26 +183,27 @@ static int32_t sdbInsertRow(SSdb *pSdb, SHashObj *hash, SSdbRaw *pRaw, SSdbRow *
}
static
int32_t
sdbUpdateRow
(
SSdb
*
pSdb
,
SHashObj
*
hash
,
SSdbRaw
*
pRaw
,
SSdbRow
*
pNewRow
,
int32_t
keySize
)
{
TdThreadRwlock
*
pLock
=
&
pSdb
->
locks
[
pNewRow
->
type
]
;
taosThreadRwlockWrlock
(
pLock
);
int32_t
type
=
pNewRow
->
type
;
sdbWriteLock
(
pSdb
,
type
);
SSdbRow
**
ppOldRow
=
taosHashGet
(
hash
,
pNewRow
->
pObj
,
keySize
);
if
(
ppOldRow
==
NULL
||
*
ppOldRow
==
NULL
)
{
taosThreadRwlockUnlock
(
pLock
);
sdbUnLock
(
pSdb
,
type
);
return
sdbInsertRow
(
pSdb
,
hash
,
pRaw
,
pNewRow
,
keySize
);
}
SSdbRow
*
pOldRow
=
*
ppOldRow
;
pOldRow
->
status
=
pRaw
->
status
;
sdbPrintOper
(
pSdb
,
pOldRow
,
"update"
);
sdbUnLock
(
pSdb
,
type
);
int32_t
code
=
0
;
SdbUpdateFp
updateFp
=
pSdb
->
updateFps
[
pNewRow
->
type
];
SdbUpdateFp
updateFp
=
pSdb
->
updateFps
[
type
];
if
(
updateFp
!=
NULL
)
{
code
=
(
*
updateFp
)(
pSdb
,
pOldRow
->
pObj
,
pNewRow
->
pObj
);
}
taosThreadRwlockUnlock
(
pLock
);
sdbUnLock
(
pSdb
,
type
);
sdbFreeRow
(
pSdb
,
pNewRow
,
false
);
pSdb
->
tableVer
[
pOldRow
->
type
]
++
;
...
...
@@ -210,12 +211,12 @@ static int32_t sdbUpdateRow(SSdb *pSdb, SHashObj *hash, SSdbRaw *pRaw, SSdbRow *
}
static
int32_t
sdbDeleteRow
(
SSdb
*
pSdb
,
SHashObj
*
hash
,
SSdbRaw
*
pRaw
,
SSdbRow
*
pRow
,
int32_t
keySize
)
{
TdThreadRwlock
*
pLock
=
&
pSdb
->
locks
[
pRow
->
type
]
;
taosThreadRwlockWrlock
(
pLock
);
int32_t
type
=
pRow
->
type
;
sdbWriteLock
(
pSdb
,
type
);
SSdbRow
**
ppOldRow
=
taosHashGet
(
hash
,
pRow
->
pObj
,
keySize
);
if
(
ppOldRow
==
NULL
||
*
ppOldRow
==
NULL
)
{
taosThreadRwlockUnlock
(
pLock
);
sdbUnLock
(
pSdb
,
type
);
sdbFreeRow
(
pSdb
,
pRow
,
false
);
terrno
=
TSDB_CODE_SDB_OBJ_NOT_THERE
;
return
terrno
;
...
...
@@ -228,7 +229,7 @@ static int32_t sdbDeleteRow(SSdb *pSdb, SHashObj *hash, SSdbRaw *pRaw, SSdbRow *
taosHashRemove
(
hash
,
pOldRow
->
pObj
,
keySize
);
pSdb
->
tableVer
[
pOldRow
->
type
]
++
;
taosThreadRwlockUnlock
(
pLock
);
sdbUnLock
(
pSdb
,
type
);
sdbFreeRow
(
pSdb
,
pRow
,
false
);
...
...
@@ -282,12 +283,11 @@ void *sdbAcquire(SSdb *pSdb, ESdbType type, const void *pKey) {
void
*
pRet
=
NULL
;
int32_t
keySize
=
sdbGetkeySize
(
pSdb
,
type
,
pKey
);
TdThreadRwlock
*
pLock
=
&
pSdb
->
locks
[
type
];
taosThreadRwlockRdlock
(
pLock
);
sdbReadLock
(
pSdb
,
type
);
SSdbRow
**
ppRow
=
taosHashGet
(
hash
,
pKey
,
keySize
);
if
(
ppRow
==
NULL
||
*
ppRow
==
NULL
)
{
taosThreadRwlockUnlock
(
pLock
);
sdbUnLock
(
pSdb
,
type
);
terrno
=
TSDB_CODE_SDB_OBJ_NOT_THERE
;
return
NULL
;
}
...
...
@@ -310,13 +310,13 @@ void *sdbAcquire(SSdb *pSdb, ESdbType type, const void *pKey) {
break
;
}
taosThreadRwlockUnlock
(
pLock
);
sdbUnLock
(
pSdb
,
type
);
return
pRet
;
}
static
void
sdbCheckRow
(
SSdb
*
pSdb
,
SSdbRow
*
pRow
)
{
TdThreadRwlock
*
pLock
=
&
pSdb
->
locks
[
pRow
->
type
]
;
taosThreadRwlockWrlock
(
pLock
);
int32_t
type
=
pRow
->
type
;
sdbWriteLock
(
pSdb
,
type
);
int32_t
ref
=
atomic_sub_fetch_32
(
&
pRow
->
refCount
,
1
);
sdbPrintOper
(
pSdb
,
pRow
,
"check"
);
...
...
@@ -324,7 +324,7 @@ static void sdbCheckRow(SSdb *pSdb, SSdbRow *pRow) {
sdbFreeRow
(
pSdb
,
pRow
,
true
);
}
taosThreadRwlockUnlock
(
pLock
);
sdbUnLock
(
pSdb
,
type
);
}
void
sdbReleaseLock
(
SSdb
*
pSdb
,
void
*
pObj
,
bool
lock
)
{
...
...
@@ -333,9 +333,9 @@ void sdbReleaseLock(SSdb *pSdb, void *pObj, bool lock) {
SSdbRow
*
pRow
=
(
SSdbRow
*
)((
char
*
)
pObj
-
sizeof
(
SSdbRow
));
if
(
pRow
->
type
>=
SDB_MAX
)
return
;
TdThreadRwlock
*
pLock
=
&
pSdb
->
locks
[
pRow
->
type
]
;
int32_t
type
=
pRow
->
type
;
if
(
lock
)
{
taosThreadRwlockWrlock
(
pLock
);
sdbWriteLock
(
pSdb
,
type
);
}
int32_t
ref
=
atomic_sub_fetch_32
(
&
pRow
->
refCount
,
1
);
...
...
@@ -345,7 +345,7 @@ void sdbReleaseLock(SSdb *pSdb, void *pObj, bool lock) {
}
if
(
lock
)
{
taosThreadRwlockUnlock
(
pLock
);
sdbUnLock
(
pSdb
,
type
);
}
}
...
...
@@ -357,8 +357,7 @@ void *sdbFetch(SSdb *pSdb, ESdbType type, void *pIter, void **ppObj) {
SHashObj
*
hash
=
sdbGetHash
(
pSdb
,
type
);
if
(
hash
==
NULL
)
return
NULL
;
TdThreadRwlock
*
pLock
=
&
pSdb
->
locks
[
type
];
taosThreadRwlockRdlock
(
pLock
);
sdbReadLock
(
pSdb
,
type
);
SSdbRow
**
ppRow
=
taosHashIterate
(
hash
,
pIter
);
while
(
ppRow
!=
NULL
)
{
...
...
@@ -373,7 +372,7 @@ void *sdbFetch(SSdb *pSdb, ESdbType type, void *pIter, void **ppObj) {
*
ppObj
=
pRow
->
pObj
;
break
;
}
taosThreadRwlockUnlock
(
pLock
);
sdbUnLock
(
pSdb
,
type
);
return
ppRow
;
}
...
...
@@ -384,9 +383,8 @@ void *sdbFetchAll(SSdb *pSdb, ESdbType type, void *pIter, void **ppObj, ESdbStat
SHashObj
*
hash
=
sdbGetHash
(
pSdb
,
type
);
if
(
hash
==
NULL
)
return
NULL
;
TdThreadRwlock
*
pLock
=
&
pSdb
->
locks
[
type
];
if
(
lock
)
{
taosThreadRwlockRdlock
(
pLock
);
sdbReadLock
(
pSdb
,
type
);
}
SSdbRow
**
ppRow
=
taosHashIterate
(
hash
,
pIter
);
...
...
@@ -404,7 +402,7 @@ void *sdbFetchAll(SSdb *pSdb, ESdbType type, void *pIter, void **ppObj, ESdbStat
break
;
}
if
(
lock
)
{
taosThreadRwlockUnlock
(
pLock
);
sdbUnLock
(
pSdb
,
type
);
}
return
ppRow
;
...
...
@@ -416,18 +414,17 @@ void sdbCancelFetch(SSdb *pSdb, void *pIter) {
SHashObj
*
hash
=
sdbGetHash
(
pSdb
,
pRow
->
type
);
if
(
hash
==
NULL
)
return
;
TdThreadRwlock
*
pLock
=
&
pSdb
->
locks
[
pRow
->
type
]
;
taosThreadRwlockRdlock
(
pLock
);
int32_t
type
=
pRow
->
type
;
sdbReadLock
(
pSdb
,
type
);
taosHashCancelIterate
(
hash
,
pIter
);
taosThreadRwlockUnlock
(
pLock
);
sdbUnLock
(
pSdb
,
type
);
}
void
sdbTraverse
(
SSdb
*
pSdb
,
ESdbType
type
,
sdbTraverseFp
fp
,
void
*
p1
,
void
*
p2
,
void
*
p3
)
{
SHashObj
*
hash
=
sdbGetHash
(
pSdb
,
type
);
if
(
hash
==
NULL
)
return
;
TdThreadRwlock
*
pLock
=
&
pSdb
->
locks
[
type
];
taosThreadRwlockRdlock
(
pLock
);
sdbReadLock
(
pSdb
,
type
);
SSdbRow
**
ppRow
=
taosHashIterate
(
hash
,
NULL
);
while
(
ppRow
!=
NULL
)
{
...
...
@@ -443,17 +440,16 @@ void sdbTraverse(SSdb *pSdb, ESdbType type, sdbTraverseFp fp, void *p1, void *p2
ppRow
=
taosHashIterate
(
hash
,
ppRow
);
}
taosThreadRwlockUnlock
(
pLock
);
sdbUnLock
(
pSdb
,
type
);
}
int32_t
sdbGetSize
(
SSdb
*
pSdb
,
ESdbType
type
)
{
SHashObj
*
hash
=
sdbGetHash
(
pSdb
,
type
);
if
(
hash
==
NULL
)
return
0
;
TdThreadRwlock
*
pLock
=
&
pSdb
->
locks
[
type
];
taosThreadRwlockRdlock
(
pLock
);
sdbReadLock
(
pSdb
,
type
);
int32_t
size
=
taosHashGetSize
(
hash
);
taosThreadRwlockUnlock
(
pLock
);
sdbUnLock
(
pSdb
,
type
);
return
size
;
}
...
...
@@ -465,9 +461,7 @@ int32_t sdbGetMaxId(SSdb *pSdb, ESdbType type) {
if
(
pSdb
->
keyTypes
[
type
]
!=
SDB_KEY_INT32
)
return
-
1
;
int32_t
maxId
=
0
;
TdThreadRwlock
*
pLock
=
&
pSdb
->
locks
[
type
];
taosThreadRwlockRdlock
(
pLock
);
sdbReadLock
(
pSdb
,
type
);
SSdbRow
**
ppRow
=
taosHashIterate
(
hash
,
NULL
);
while
(
ppRow
!=
NULL
)
{
...
...
@@ -477,8 +471,7 @@ int32_t sdbGetMaxId(SSdb *pSdb, ESdbType type) {
ppRow
=
taosHashIterate
(
hash
,
ppRow
);
}
taosThreadRwlockUnlock
(
pLock
);
sdbUnLock
(
pSdb
,
type
);
maxId
=
TMAX
(
maxId
,
pSdb
->
maxId
[
type
]);
return
maxId
+
1
;
}
...
...
编辑
预览
Markdown
is supported
0%
请重试
或
添加新附件
.
添加附件
取消
You are about to add
0
people
to the discussion. Proceed with caution.
先完成此消息的编辑!
取消
想要评论请
注册
或
登录