千家信息网

MDCache中resolve有什么用

发表于:2025-02-04 作者:千家信息网编辑
千家信息网最后更新 2025年02月04日,这篇文章主要介绍MDCache中resolve有什么用,文中介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们一定要看完!MDCache中handle_resolve()函数处理MMDSResolv
千家信息网最后更新 2025年02月04日MDCache中resolve有什么用

这篇文章主要介绍MDCache中resolve有什么用,文中介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们一定要看完!

MDCache中handle_resolve()函数处理MMDSResolve类消息。对于MMDSResolve类消息中slave_requests数组不为空则优先处理该数组,将该数组中的保存的数据写入到uncommitted_masters数组、rejoin_slave_exports数组以及rejoin_imported_caps数组。最后创建MMDSResolveAck类消息且设置对应slave request的commit,最后将MMDSResolveAck类消息发送回给对应的MDS进程。对于MDS处于clientreplay/active/stopping状态则通过遍历my_ambiguous_imports数组得到当前处于ambiguous状态的import的目录,之后在MMDSResolve类消息中的subtrees目录下寻找处于ambiguous状态的import的目录,若找到了则执行migrator->import_finish()函数表示import目录完毕。遍历MMDSResolve类消息中的subtrees数组且调用try_subtree_merge()函数来尝试merge该subtree到MDS。最后遍历MMDSResolve类消息的ambiguous_imports数组来更新other_ambiguous_imports数组,之后调用mybe_resolve_finish()函数来确认resolve是否完毕。

MDCache中handle_resolve_ack()函数处理MMDSResolveAck类消息。首先遍历MMDSResolveAck类消息中的commit数组,对于数组中的元素位于ambiguous_slave_updates数组中则从ambiguous_slave_updates数组中删除对应的项。若MDS处于Resolve状态则得到MDSlaveUpdate类对象,之后将MDSlaveUpdate类对象写入到mdlog中,最后删除uncommitted_slave_update数组中对应的项。若MDS未处于Resolve状态则得到MDRequest类对象,最后调用request_finish()函数完成request请求。之后遍历MMDSResolveAck类消息中的abort数组,若MDS处于Resolve状态则执行适当的rollback操作,否则调用request_finish()函数完成request请求。

以上是"MDCache中resolve有什么用"这篇文章的所有内容,感谢各位的阅读!希望分享的内容对大家有帮助,更多相关知识,欢迎关注行业资讯频道!

数组 消息 函数 状态 目录 对象 处理 内容 篇文章 适当 价值 元素 兴趣 小伙 小伙伴 数据 更多 知识 行业 资讯 数据库的安全要保护哪些东西 数据库安全各自的含义是什么 生产安全数据库录入 数据库的安全性及管理 数据库安全策略包含哪些 海淀数据库安全审计系统 建立农村房屋安全信息数据库 易用的数据库客户端支持安全管理 连接数据库失败ssl安全错误 数据库的锁怎样保障安全 徐汇区特殊软件开发推荐厂家 数据库怎样查询表信息 网络安全比例原则是什么意思 代理服务器无效 魔龙之魂服务器 软件开发实习社会实践报告 软件开发中的的qc手段 时序数据库和关系型数据库优缺点 计算机网络技术的分析 联想服务器转速不稳定 做个前端程序写进数据库 数据库小时换算天数 走之底的网络技术公司 数据库系统的语言包括 大庆招工软件开发 徐州网络安全审计系统咨询辅导 瓦罗兰特哪个服务器对新手比较好 软件开发过程难度 sql数据库分页是什么意思 软件开发服务费发票几个点 黑龙江省招聘网络安全工程师 c 显示数据库中的 软件开发创业培训班 网易我的世界服务器怎么查人数 云服务器数据备份安全性 连接数据库时登陆错误 温州市网络安全专家组 服务器的管理和配置 足球经理 数据库 更新 你要注意网络安全当心被骗翻译
0