登录
注册
开源
企业版
高校版
搜索
帮助中心
使用条款
关于我们
开源
企业版
高校版
私有云
模力方舟
AI 队友
登录
注册
Gitee 2025 年度开源项目评选中
代码拉取完成,页面将自动刷新
捐赠
捐赠前请先登录
取消
前往登录
扫描微信二维码支付
取消
支付完成
支付提示
将跳转至支付宝完成支付
确定
取消
Watch
不关注
关注所有动态
仅关注版本发行动态
关注但不提醒动态
22
Star
16
Fork
82
openGauss
/
DSS
代码
Issues
28
Pull Requests
1
Wiki
统计
流水线
服务
JavaDoc
PHPDoc
质量分析
Jenkins for Gitee
腾讯云托管
腾讯云 Serverless
悬镜安全
阿里云 SAE
Codeblitz
SBOM
我知道了,不再自动展开
582
stopdss 优化:缩短主线程和后台线程的 sleep 时间,减少优雅退出耗时
已关闭
Xilai:stopdss
openGauss:master
Xilai
创建于 2025-02-20 11:42
克隆/下载
HTTPS
SSH
复制
下载 Email Patch
下载 Diff 文件
【标题】(请简要描述下实现的内容) stopdss 优化:缩短主线程、recovery线程、delay_clean 线程的 sleep 时间,减少优雅退出耗时 【实现内容】: 缩短主线程、recovery线程、delay_clean 线程的 sleep 时间,减少优雅退出耗时 【根因分析】: 经过统计,某次优雅退出各个阶段耗时如下: | 阶段 | 耗时/ms | 相关线程的sleep/阻塞周期/ms | |----------------------|-----------------|--------------------| | 主线程检测 abort_status | 383 | 500 | | pause LSNR 线程 | 11 | 50 | | 关闭 reactor0-iothread | 14 | 16 | | 关闭reactor0线程池 | 878(平均每个线程27.4) | 50 | | 关闭 reactor1-iothread | 16 | 16 | | 关闭reactor1线程池 | 850(平均每个线程26.6) | 50 | | 关闭recovery线程 | 413 | 500 | | 关闭delay_clean线程 | 994 | 1000 | | 关闭dynamic_extend线程 | 441 | 500 | | 关闭alram_check线程 | 8 | 500 | | 关闭 meta_sync线程 | 7 | 10 | | 关闭 recycle_meta 线程 | 64 | 200 | | stop lsnr | 0 | | | unlatch disk_latch | 0 | | | 总计 | 4079 | | 可见,耗时长的主要原因是:(1)主线程和后台线程的 sleep 时间过长;(2)reactor 线程池的线程数量较多且串行关闭。 应当针对这两点进行优化。 【实现方案】: 1. 减少主线程和后台线程的 sleep 时长; 2. 优化关闭后台线程的流程,先批量将所有后台线程标记为 closed,再统一 wait join 3. 优化 reactor 线程池销毁流程。 【关联需求或issue】: stopdss 优化:减少 DSS 优雅退出时长 https://gitee.com/opengauss/DSS/issues/IBNKEN 【开发自验报告】: 1. 请附上自验结果(内容或者截图) 已自验:多次执行 dsscmd stopdss,通过日志观察从 dsscmd stopdss 响应到 dssserver 完成优雅退出,总耗时显著降低,低于 3 秒。 2. 是否涉及资料修改,如是,请在docs仓库补充资料 否 3. 是否涉及接口修改,如是,请在openGauss-server仓库同步 否 4. 是否对其他模块产生影响 否 【其他说明】: 选填
此 Pull Request 需要通过一些审核项
类型
指派人员
状态
审查
xiangxinyong
进行中
(0/1人)
测试
xiangxinyong
进行中
(0/1人)
此 Pull Request 无法自动合并
尝试通过 WebIDE 解决冲突
怎样手动合并此 Pull Request
git checkout master
git pull https://gitee.com/xilai-chen/DSS.git stopdss
git push origin master
评论
16
提交
1
文件
3
检查
代码问题
0
批量操作
展开设置
折叠设置
审查
Code Owner
审查人员
peibaoyi
peibaoyi
wangwei5
wangwei5
胡习林
hu-xilin
陈栋
chendong76
junhangis
junhangis
cchen676
struggle_hw
zjxqxf
zjxqxf
yz
yz_db
wanghuanzhuo
wanghuanzhuo
zhulixia
zhulixia
dengyong
dengyong2
刘博文
bowen9799
zhaodu
zhaodu
yangwei
yangwei129
andy
git_for_andy
黄堰蛟
huang-yanjiao
薛蒙恩
xue_meng_en
xiangxinyong
xiangxinyong
Carl
chen-zhikai-999
未设置
最少人数
1
测试
peibaoyi
peibaoyi
wangwei5
wangwei5
胡习林
hu-xilin
陈栋
chendong76
junhangis
junhangis
cchen676
struggle_hw
zjxqxf
zjxqxf
yz
yz_db
wanghuanzhuo
wanghuanzhuo
zhulixia
zhulixia
dengyong
dengyong2
刘博文
bowen9799
zhaodu
zhaodu
yangwei
yangwei129
andy
git_for_andy
黄堰蛟
huang-yanjiao
薛蒙恩
xue_meng_en
xiangxinyong
xiangxinyong
Carl
chen-zhikai-999
未设置
最少人数
1
优先级
不指定
严重
主要
次要
不重要
标签
opengauss-cla/yes
ci-pipeline-success
sig/cm
codecheck-success
关联 Issue
IBNKEN
stopdss 优化:减少 DSS 优雅退出时长
Pull Request 合并后将关闭上述关联 Issue
里程碑
未关联里程碑
参与者
(2)
1
https://gitee.com/opengauss/DSS.git
git@gitee.com:opengauss/DSS.git
opengauss
DSS
DSS
点此查找更多帮助
搜索帮助
Git 命令在线学习
如何在 Gitee 导入 GitHub 仓库
Git 仓库基础操作
企业版和社区版功能对比
SSH 公钥设置
如何处理代码冲突
仓库体积过大,如何减小?
如何找回被删除的仓库数据
Gitee 产品配额说明
GitHub仓库快速导入Gitee及同步更新
什么是 Release(发行版)
将 PHP 项目自动发布到 packagist.org
仓库举报
回到顶部
登录提示
该操作需登录 Gitee 帐号,请先登录后再操作。
立即登录
没有帐号,去注册