nacos实现对minio的动态版本切换
问题:怎样在项目部署后,在不涉及对源码的改动情况下,以及如部分场景下业务的更替进行版本切换呢?
这里我们选择通过nacos进行相关操作,下面将以nacos控制minio修改服务提供商这一示例进行演示
首先,什么是nacos?
Nacos 是阿里巴巴开源的一个易于构建云原生应用的动态服务发现、配置管理和服务管理平台。Nacos 的目标是帮助您发现、配置和管理微服务。它提供了一组简单易用的特性集,用于构建云原生应用,其特性包括:
-
服务发现与健康监测: Nacos 支持基于 DNS 和基于 RPC 的服务发现,可以检测服务实例的健康状况,并在服务不可用时自动剔除。
-
动态配置服务: 允许应用程序在不重启的情况下动态地更新配置。Nacos 会实时推送配置变更到客户端,减少配置更新时的延迟。
-
动态 DNS 服务: 支持基于服务的 DNS 解析,可以将服务名解析为 IP 地址,支持 A 记录和 SRV 记录。
-
服务及其元数据管理: Nacos 提供服务及其元数据的管理功能,包括命名空间、集群、分组等概念,使得服务管理更加灵活和精细。
-
非侵入式的服务管理: Nacos 的服务管理是无侵入式的,不需要在服务代码中添加任何特殊的 SDK 或者框架,只需在启动时指定 Nacos 的地址即可。
-
丰富的监控指标: 提供详细的监控数据,包括服务调用成功率、响应时间、健康检查状态等,方便运维人员进行监控和故障排查。
-
安全性和权限控制: 支持基于角色的访问控制(RBAC),可以对不同用户设置不同的权限,保护敏感的配置和资源。
Nacos 的设计目标是高度可扩展、高可用、高性能,并且易于使用。它支持多种部署模式,包括单机、集群以及高可用集群,可以根据实际需求选择合适的部署方案。Nacos 已经在阿里巴巴内部大规模使用,并逐渐被社区广泛采纳,适用于各种云原生场景下的服务管理和配置中心需求。
详情可见
nacos 的文档:https://nacos.io/zh-cn/docs/what-is-nacos.html
nacos 的架构原理:https://developer.aliyun.com/ebook/36?spm=a2c6h.20345107.ebook-index.18.152c2984fsi5ST
好了,回归正题我们采用的是虚拟机docker拉取镜像部署的方式
docker search nacos docker pull nacos/nacos-server # 镜像拉完之后,启动脚本 docker run -d \ --name nacos \ --privileged \ --cgroupns host \ --env JVM_XMX=256m \ --env MODE=standalone \ --env JVM_XMS=256m \ -p 8848:8848/tcp \ -p 9848:9848/tcp \ --restart=always \ -w /home/nacos \ nacos/nacos-server
http://***:8848/nacos进入后台管理
输入对应内容后保存
nacos: config: secret-key: nacos access-key: nacos data-id: jc-club-oss group: DEFAULT_GROUP type: yaml server-addr: your-ip:8848 auto-refresh: true remote-first: true bootstrap: enable: true
@NacosValue(value = "${storage.service.type}",autoRefreshed = true) private String storageType; @RequestMapping("/testGetA @RequestMapping("/testNacos") public String testNacos() throws Exception { List<String> allBucket = fileService.getAllBucket(); return storageType; }
这样,只需要修改我们nacos的配置,即可做到不修改源码情况下对服务提供商的具体修改。
pom文件
<dependencies> <dependency> <groupId>org.springframework.boot</groupId> <artifactId>spring-boot-dependencies</artifactId> <version>2.4.2</version> <type>pom</type> <scope>import</scope> </dependency> <dependency> <groupId>org.springframework.boot</groupId> <artifactId>spring-boot-starter-web</artifactId> <version>2.4.2</version> <exclusions> <exclusion> <artifactId>spring-boot-starter-logging</artifactId> <groupId>org.springframework.boot</groupId> </exclusion> </exclusions> </dependency> <dependency> <groupId>io.minio</groupId> <artifactId>minio</artifactId> <version>8.2.0</version> </dependency> <dependency> <groupId>org.projectlombok</groupId> <artifactId>lombok</artifactId> <version>1.18.34</version> <scope>compile</scope> </dependency> <dependency> <groupId>com.alibaba.boot</groupId> <artifactId>nacos-config-spring-boot-starter</artifactId> <version>0.2.11</version> </dependency> <dependency> <groupId>org.springframework.boot</groupId> <artifactId>spring-boot-starter-log4j2</artifactId> <version>2.4.2</version> </dependency> </dependencies>