Skip to content
体验新版
项目
组织
正在加载...
登录
切换导航
打开侧边栏
taosdata
TDengine
提交
b438586a
T
TDengine
项目概览
taosdata
/
TDengine
大约 2 年 前同步成功
通知
1192
Star
22018
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看板
提交
b438586a
编写于
10月 21, 2020
作者:
S
Shengliang Guan
浏览文件
操作
浏览文件
下载
电子邮件补丁
差异文件
TD-1746
上级
7a9e1769
变更
3
隐藏空白更改
内联
并排
Showing
3 changed file
with
18 addition
and
9 deletion
+18
-9
src/balance/src/balance.c
src/balance/src/balance.c
+2
-2
src/vnode/src/vnodeMain.c
src/vnode/src/vnodeMain.c
+13
-4
src/vnode/src/vnodeRead.c
src/vnode/src/vnodeRead.c
+3
-3
未找到文件。
src/balance/src/balance.c
浏览文件 @
b438586a
...
@@ -216,8 +216,8 @@ static bool balanceCheckVgroupReady(SVgObj *pVgroup, SVnodeGid *pRmVnode) {
...
@@ -216,8 +216,8 @@ static bool balanceCheckVgroupReady(SVgObj *pVgroup, SVnodeGid *pRmVnode) {
SVnodeGid
*
pVnode
=
pVgroup
->
vnodeGid
+
i
;
SVnodeGid
*
pVnode
=
pVgroup
->
vnodeGid
+
i
;
if
(
pVnode
==
pRmVnode
)
continue
;
if
(
pVnode
==
pRmVnode
)
continue
;
mTrace
(
"vgId:%d, ch
ange vgroup status, dnode:%d status:%d
"
,
pVgroup
->
vgId
,
pVnode
->
pDnode
->
dnodeId
,
mTrace
(
"vgId:%d, ch
eck vgroup status, dnode:%d status:%d, vnode role:%s
"
,
pVgroup
->
vgId
,
pVnode
->
pDnode
->
dnodeId
,
pVnode
->
pDnode
->
status
);
pVnode
->
pDnode
->
status
,
syncRole
[
pVnode
->
role
]
);
if
(
pVnode
->
pDnode
->
status
==
TAOS_DN_STATUS_DROPPING
)
continue
;
if
(
pVnode
->
pDnode
->
status
==
TAOS_DN_STATUS_DROPPING
)
continue
;
if
(
pVnode
->
pDnode
->
status
==
TAOS_DN_STATUS_OFFLINE
)
continue
;
if
(
pVnode
->
pDnode
->
status
==
TAOS_DN_STATUS_OFFLINE
)
continue
;
...
...
src/vnode/src/vnodeMain.c
浏览文件 @
b438586a
...
@@ -379,9 +379,15 @@ void vnodeRelease(void *pVnodeRaw) {
...
@@ -379,9 +379,15 @@ void vnodeRelease(void *pVnodeRaw) {
return
;
return
;
}
}
vTrace
(
"vgId:%d, vnode will be destroyed, refCount:%d pVnode:%p data:%p"
,
vgId
,
refCount
,
pVnode
,
pVnode
->
ppVnode
);
void
**
ppVnode
=
pVnode
->
ppVnode
;
void
**
ppVnode
=
pVnode
->
ppVnode
;
SVnodeObj
pTempVnode
=
*
pVnode
;
memset
(
pVnode
,
0
,
sizeof
(
SVnodeObj
));
pVnode
=
&
pTempVnode
;
if
(
ppVnode
!=
NULL
)
{
if
(
ppVnode
!=
NULL
)
{
taosCacheRelease
(
tsDnodeVnodesCache
,
(
void
**
)(
&
ppVnode
),
fals
e
);
taosCacheRelease
(
tsDnodeVnodesCache
,
(
void
**
)(
&
ppVnode
),
tru
e
);
}
}
if
(
pVnode
->
qMgmt
)
{
if
(
pVnode
->
qMgmt
)
{
...
@@ -436,9 +442,12 @@ void vnodeRelease(void *pVnodeRaw) {
...
@@ -436,9 +442,12 @@ void vnodeRelease(void *pVnodeRaw) {
}
}
tsem_destroy
(
&
pVnode
->
sem
);
tsem_destroy
(
&
pVnode
->
sem
);
free
(
pVnode
);
int32_t
count
=
taosHashGetSize
(
tsDnodeVnodesCache
->
pHashTable
);
int32_t
count
=
0
;
if
(
tsDnodeVnodesCache
)
{
count
=
taosHashGetSize
(
tsDnodeVnodesCache
->
pHashTable
);
}
vDebug
(
"vgId:%d, vnode is released, vnodes:%d"
,
vgId
,
count
);
vDebug
(
"vgId:%d, vnode is released, vnodes:%d"
,
vgId
,
count
);
}
}
...
@@ -1055,5 +1064,5 @@ PARSE_OVER:
...
@@ -1055,5 +1064,5 @@ PARSE_OVER:
static
void
vnodeFreeVnodeObj
(
void
*
data
)
{
static
void
vnodeFreeVnodeObj
(
void
*
data
)
{
SVnodeObj
*
pVnode
=
*
(
SVnodeObj
**
)
data
;
SVnodeObj
*
pVnode
=
*
(
SVnodeObj
**
)
data
;
vDebug
(
"vgId:%d, vnode is destroyed, pVnode:%p data:%p"
,
pVnode
->
vgId
,
pVnode
,
pVnode
->
ppVnode
);
vDebug
(
"vgId:%d, vnode is destroyed, pVnode:%p data:%p"
,
pVnode
->
vgId
,
pVnode
,
pVnode
->
ppVnode
);
//
taosTFree(pVnode);
taosTFree
(
pVnode
);
}
}
\ No newline at end of file
src/vnode/src/vnodeRead.c
浏览文件 @
b438586a
...
@@ -80,12 +80,12 @@ int32_t vnodeProcessRead(void *param, SReadMsg *pRead) {
...
@@ -80,12 +80,12 @@ int32_t vnodeProcessRead(void *param, SReadMsg *pRead) {
if
(
code
==
TSDB_CODE_APP_NOT_READY
&&
pRead
->
rpcMsg
.
msgType
==
TSDB_MSG_TYPE_QUERY
)
{
if
(
code
==
TSDB_CODE_APP_NOT_READY
&&
pRead
->
rpcMsg
.
msgType
==
TSDB_MSG_TYPE_QUERY
)
{
// After the fetch request enters the vnode queue
// After the fetch request enters the vnode queue
// If the vnode cannot provide services, the following operations are still required
// If the vnode cannot provide services, the following operations are still required
// Or there will be a deadlock
// Or
,
there will be a deadlock
void
**
qhandle
=
(
void
**
)
pRead
->
pCont
;
void
**
qhandle
=
(
void
**
)
pRead
->
pCont
;
vError
(
"QInfo:%p msg:%p will be killed for vstatus is %s"
,
*
qhandle
,
pRead
,
vnodeStatus
[
pVnode
->
status
]);
vError
(
"QInfo:%p msg:%p will be killed for vstatus is %s"
,
*
qhandle
,
pRead
,
vnodeStatus
[
pVnode
->
status
]);
qKillQuery
(
*
qhandle
);
//
qKillQuery(*qhandle);
qReleaseQInfo
(
pVnode
->
qMgmt
,
(
void
**
)
&
qhandle
,
true
);
//
qReleaseQInfo(pVnode->qMgmt, (void **)&qhandle, true);
return
TSDB_CODE_APP_NOT_READY
;
return
TSDB_CODE_APP_NOT_READY
;
}
else
{
}
else
{
return
code
;
return
code
;
...
...
编辑
预览
Markdown
is supported
0%
请重试
或
添加新附件
.
添加附件
取消
You are about to add
0
people
to the discussion. Proceed with caution.
先完成此消息的编辑!
取消
想要评论请
注册
或
登录