开发者社区> 问答> 正文

Nacos的用户扩展性为什么也是需要多关注的地方?

Nacos的用户扩展性为什么也是需要多关注的地方?

展开
收起
游客kvzazfncej2yu 2022-01-03 18:02:51 294 0
1 条回答
写回答
取消 提交回答
  • 在框架的设计中,扩展性是⼀个重要的设计原则。Spring、Dubbo、Ribbon 等框架都在用户扩展性 上做了比较好的设计。这些框架的扩展性往往由面向接口及动态类加载等技术,来运行用户扩展约 定的接口,实现用户自定义的逻辑。在 Server 的设计中,用户扩展是比较审慎的。因为用户扩展 代码的引入,可能会影响原有 Server 服务的可用性,同时如果出问题,排查的难度也是比较大的。 设计良好的 SPI 是可能的,但是由此带来的稳定性和运维的风险是需要仔细考虑的。在开源软件中, 往往通过直接贡献代码的方式来实现用户扩展,好的扩展会被很多人不停的更新和维护,这也是⼀ 种比较好的开发模式。Zookeeper 和 Eureka 目前 Server 端都不支持用户扩展,⼀个支持用户扩 展的服务发现产品是 CoreDNS。CoreDNS 整体架构就是通过插件来串联起来的,通过将插件代码 以约定的方式放到 CoreDNS 工程下,重新构建就可以将插件添加到 CoreDNS 整体功能链路的⼀环中。具体架构如图所示:

    资料来源:《Nacos架构&原理》,下载链接为:https://developer.aliyun.com/topic/download?id=8230。

    2022-01-04 20:23:08
    赞同 展开评论 打赏
问答分类:
问答地址:
问答排行榜
最热
最新

相关电子书

更多
一招玩转微服务注册&配置中心 立即下载
Nacos架构&原理 立即下载
Sentinel-Sentinel :保障微服务高可用的利器 立即下载