广告
返回顶部
首页 > 资讯 > 后端开发 > GO >详解Go语言微服务开发框架之Go chassis
  • 211
分享到

详解Go语言微服务开发框架之Go chassis

2024-04-02 19:04:59 211人浏览 八月长安
摘要

目录引言架构获取配置配置项形态配置运行时热加载例子引言 https://GitHub.com/Go-chassis/go-chassis是一个微服务开发框架,而微服务开发框架带来的其

引言

https://GitHub.com/Go-chassis/go-chassis是一个微服务开发框架,而微服务开发框架带来的其中一个课题就是:当单体应用向微服务转型后,有大量的配置需要管理,而你并不希望登录到远端机器去更改配置,并重启应用,尤其是现在已经是容器的时代了,也不希望因为一个配置的变更,而发布一个新的软件包。那么分布式系统中每个进程的动态配置管理及运行时热加载就成为了一个亟待解决的问题。Https://github.com/go-chassis/go-archaius为gochassis而生,他汲取了netflix的archaius框架经验,并做出来自己的创新特性。

架构

Source:配置源是一种标准接口,可以通过实现一个source来接入不同配置源,它定义配置来自哪个资源,配置可以来自配置中心confiGCenter,来自本地文件,来自环境变量或是启动命令行。source负责将配置项缓存到本地内存。用户可以选择加载任意的source实现。

Config center source:配置中心源不同于其他source,它包含一个client抽象,可以对接不同的生态系统,目前对接了携程开源的配置中心Apollo。

Config manager:负责整合管理所有source的配置,每个source可以定义优先级,当通过manager获取配置时,如果2个不同的source有相同的配置,那么就会取最大优先级的配置。

Event Dispatcher:用户可以通过Archaius api进行配置变化监听,当source内部的配置项新增,更新,删除配置时,都会通知到监听器。

Source优先级:优先级由大到小依次为Config center,CLI,ENV,file,当有相同配置项的时候仅优先级大的配置生效。在一个分布式系统中,远程的配置中心理应拥有最大优先级,而在本地运行一个独立的进程时,通常的思维是,命令行参数优先级高于环境变量,高于本地文件内容。拥有了这样一套机制后,用户就无需再写代码处理配置项生效逻辑。

Config Factory:封装了event 和 config manager的API

Archaius API:封装底层实现,提供友好的API供开发者使用

获取配置

获取配置有2种不同的手段:

1. 调用archaius API的Get 方法

2. 注册监听器

事件的触发是由soruce的开发者来决定的,每个source的行为会有不同:

命令行与环境变量是不会产生任何事件的,当archaius运行后配置项就已经定下来了,只能使用Get方法获取。而文件source会在启动后拉取一遍本地文件内容并转换为配置项(可自定义转换算法,决定配置项形态),之后持续监听本地文件变化,当有变化发生时会刷新本地配置并通知到监听器。所以2种方法都支持。config center source行为与文件又不同,在启动后,它就会周期拉取配置中心的配置,并且对比每一次配置项的不同,并触发不同类型事件。

配置项形态

假设程序有一个配置文件叫a.yaml,内容如下

reGIStry:

  enabled: true

  interval: 30s复制代码

要考虑该如何去对待这raw data,目前有2种方式

第一种,将配置项拆分为java properties风格的配置:

registry.refresh: true

registry.interval: 30s

go archaius开放了file handler接口,允许你决定如何将文件内容处理为配置项

那么在远程的配置中心中,key value的管理方式就要遵循 file handler的行为,当你想变更registry.refresh时,就要在配置中心种更改这个配置项及值。

类似于开关类的配置项,这种java properties的管理方式还是不错的,当一个配置项改变时触发一次事件。

但是有一类配置项并不适合如此管理,这就是第二种方式,比如go chassis中的路由管理配置文件:

通常都需要大范围的更改配置项,那么如果还使用切分的方式在配置中心中管理将会引起go archaius运行时大量的事件触发,并且,用户在使用体验上大打折扣,到处去找分散的配置项,逐一更改。正确的行为是,将文件名作为配置中心中的key,文件内容作为value。用户需要更改时,去找对应的文件名即可,修改后一次性下发,只会触发一次事件,完成路由的变更。

开发者应根据实际场景判断如何处理配置项形态。也可以自己实现handler来决定配置项形态

配置运行时热加载

在运行时可以随时通过统一的配置中心或者本地文件(不推荐分布式环境登到机器里改文件,但在本地debug时还是推荐使用文件来测试程序的热加载逻辑)更改配置了,那么接下来要解决的问题就是配置在运行时生效。

这里的技巧是使用go语言中的读写。我以go chassis中路由配置来说明

go chassis运行时总是会有不断地大并发数据访问router config这块缓存,使用一个读写锁lock中的读锁,每次访问缓存都用读锁,使用后,解开读锁。

向archaius注册监听器,需要自己编写监听器的逻辑,每当事件出发后就会通过archaius中的数据构建一个结构体数据,然后将数据存到本地缓存,首先使用lock的写锁锁住router config,更新后,解开写锁。

在这样的机制下,就可以做到运行时热加载配置项而无需重启服务。

例子

一个本地文件事件监控的例子

https://github.com/go-chassis/go-archaius/tree/master/examples/event

管理本地多文件的例子

https://github.com/go-chassis/go-archaius/tree/master/examples/file

Go chassis介绍

https://juejin.im/post/6844903682362834952

以上就是详解Go语言微服务开发框架之Go chassis的详细内容,更多关于Go语言的资料请关注编程网其它相关文章!

您可能感兴趣的文档:

--结束END--

本文标题: 详解Go语言微服务开发框架之Go chassis

本文链接: https://www.lsjlt.com/news/126306.html(转载时请注明来源链接)

有问题或投稿请发送至: 邮箱/279061341@qq.com    QQ/279061341

本篇文章演示代码以及资料文档资料下载

下载Word文档到电脑,方便收藏和打印~

下载Word文档
猜你喜欢
  • 详解Go语言微服务开发框架之Go chassis
    目录引言架构获取配置配置项形态配置运行时热加载例子引言 https://github.com/go-chassis/go-chassis是一个微服务开发框架,而微服务开发框架带来的其...
    99+
    2022-11-12
  • Go chassis云原生微服务开发框架应用编程实战
    目录什么是Go chassis文章目标诞生背景如何快速开发一个微服务统一治理和协议模型可扩展的处理链条:handler chain as middleware不只是API,通过配置简...
    99+
    2022-11-11
  • go语言有微服务框架吗
    go语言有微服务框架,例如:1、Istio,是一个开源的微服务管理、保护和监控框架;2、Go-kit,是一个Go语言的分布式开发包,用于开发微服务;3、Go-zero,是一个集成了各种工程实践的web和rpc框架;4、Go-micro,是一...
    99+
    2023-05-14
    微服务框架 go语言 Golang Go
  • Go微服务开发框架DMicro设计思路详解
    目录背景概述架构设计理念面向接口设计会话 Session消息 Message协议 Proto编码 Codec连接 Socket有机的组合插件 Plugin组件未来展望背景 ...
    99+
    2022-11-11
  • go语言微服务怎么开发
    go语言微服务开发步骤:1、定义微服务接口;2、创建项目结构来组织微服务代码;3、使用HTTP或RPC进行通信;4、实现业务逻辑,包括处理请求、访问数据库、调用其他微服务等;5、数据库访问,使用数据库驱动程序来连接和操作数据库;6、利用错误...
    99+
    2023-12-12
    go语言 Golang
  • 如何使用Go语言开发微服务?
    伴随着云计算、容器技术、大数据等新兴技术的不断涌现,微服务架构因为其高度可扩展性、灵活性等特点,越来越受到人们的青睐。在微服务架构中,每个服务都是一个独立的进程,每个进程都有自己的数据存储方式,操作系统环境等等。微服务通过通信协议(如HTT...
    99+
    2023-05-16
    Go语言 微服务 开发
  • Go语言开发框架反射机制及常见函数示例详解
    目录基本介绍反射中常见函数和概念reflect.TypeOf(变量名)reflect.ValueOf(变量名)变量.interface{}和reflect.Value是可以相互转换的...
    99+
    2022-11-11
  • 基于微服务框架go-micro开发gRPC应用程序
    go-micro是golang的一个微服务框架。这篇文章将介绍使用go-micro最新版本v4开发gRPC服务的方式。 1、安装protoc 这个工具也称为proto编译器,可以用来...
    99+
    2022-11-13
  • go-micro微服务domain层开发示例详解
    目录一 domain层介绍说明二 model层开发三 repository层开发四 service层开发最后一 domain层介绍说明 domain层专注于数据库数据领域开发,我们...
    99+
    2023-01-10
    go-micro微服务domain层 go micro微服务
  • GO语言开发中的IDE选择烦恼?SPRING框架中的NUMY能否帮你解决?
    在GO语言开发中,选择一个合适的IDE工具是非常重要的。一个好的IDE工具能够帮助我们提高开发效率,减少代码错误,降低调试难度。但是由于市面上的IDE工具种类繁多,很多开发者在选择时往往会感到犹豫不决。那么,如何选择一个合适的IDE工具呢...
    99+
    2023-06-13
    ide spring numy
软考高级职称资格查询
编程网,编程工程师的家园,是目前国内优秀的开源技术社区之一,形成了由开源软件库、代码分享、资讯、协作翻译、讨论区和博客等几大频道内容,为IT开发者提供了一个发现、使用、并交流开源技术的平台。
  • 官方手机版

  • 微信公众号

  • 商务合作