springboot 整合 nacos 配置实现多个环境不同配置
作者:风兮雨露
1、描述
一个项目一般会有中心配置文件,现在简单上手主流有Apollo,nacos config ,从性能对比可知,nacos 相比于Apollo 更高效率,更好
2、Nacos服务端安装
- 最新版本下载地址:
https://github.com/alibaba/nacos/releases
- 访问:
http://127.0.0.1:8848/nacos
- 用户名/密码:nacos/nacos
- 由于git下载有点慢提供已经打包好的下载文件:https://download.csdn.net/download/wcy18818429914/15679179
- 启动nacos 之前需要修改jar里面的数据连接和执行SQL
修改application 数据库连接:
在 nacos-server-1.1.4\nacos\target\nacos-server.jar ,用解压工具打开,找到nacos-default.properties ,修改里面的数据库连接就可以
将里面的SQL 执行到部署的服务器上
如果是window 双击启动bin 里面的 startup.cmd
如果是linux 则进入bin 执行:sh startup.sh
输入 http://localhost:8848/nacos/index.html , 输入 用户名/密码:nacos/nacos ,有以下图像就代表成功了
3、创建dataId 配置中心
其中Data ID 必需要跟代码的dataId 保存一致,group 可以默认就可以
在nacos 平台创建一个YAML配置:
命名空间:dev-local
Data ID:com-member-service.yml
Group:DEFAULT_GROUP
配置内容为:
server: servlet: context-path: /member/api custom: test: data: 用于测试的没什么用
4、创建一个springboot 项目
项目使用的是bootstrap 进行配置
(1)引入mevan 包:
<dependency> <groupId>com.alibaba.cloud</groupId> <artifactId>spring-cloud-starter-alibaba-nacos-config</artifactId> <version>2.2.1.RELEASE</version> </dependency> <dependency> <groupId>org.springframework.cloud</groupId> <artifactId>spring-cloud-starter-bootstrap</artifactId> <version>3.0.4</version> </dependency>
(2)创建bootstrap.yml 引入读取配置中心
server: port: 9087 #端口号 spring: application: name: com-member-service # nacos 平台配置的名称Data ID cloud: nacos: config: enabled: true server-addr: legrand.nacos.com:8848 # nacos 地址端口 file-extension: yml # 指定文本后缀 namespace: dev-local # nacos 命名空间 group: DEFAULT_GROUP # nacos Group refresh-enabled: true
其中dataId 必需跟nacos 客户创建的dataID 一致
(3)创建controller ,引入获取nacos 的配置
package com.example.demo.controller; import com.example.demo.service.AbstractService; import org.springframework.beans.factory.annotation.Autowired; import org.springframework.beans.factory.annotation.Value; import org.springframework.web.bind.annotation.RequestBody; import org.springframework.web.bind.annotation.RequestMapping; import org.springframework.web.bind.annotation.RestController; /** * @project: demo * * * @className: AbstractController * * * @description: **/ @RestController @RequestMapping("/abstract") public class AbstractController { @Autowired private AbstractService abstractService; @RequestMapping("/test") public String test(){ return abstractService.test(); } @Value("${custom.test.data}") private String cloud_secret_key; @RequestMapping("/nacos") public String nacos(){ return cloud_secret_key; } }
(5)启动服务:会发现端口号是8099,而且输入http://localhost:9087/member/api/abstract/nacos是 用于测试的没什么用,说明基本成功
5、重点:不同的springboot 读取不同application
如果我们按以上的操作,只能读取到一个nacos配置文件的,但是对于很多程序来说,有开发环境,测试环境,正式环境等等,这样的话就不能操作了。但是我发现nacos 还有个 空间namespace 可以用,那么我们可不可以用namespace
来区别不同的配置呢?
(1)在nacos 平台创建2个命名空间,test,dev
(2)在nacos 配置不同命名空间的值,在dev,test 分别创建 member ,里面的内容对应test.properties-version=testing_nacos_dev ,test.properties-version=testing_nacos_test
(4)在 springboot 的bootstrap.yml选择对应的启动配置spring.cloud.nacos.config.namespace,分别选择dev 和 test
server: port: 9087 #端口号 spring: application: name: com-member-service # nacos 平台配置的名称Data ID cloud: nacos: config: enabled: true server-addr: legrand.nacos.com:8848 # nacos 地址端口 file-extension: yml # 指定文本后缀 namespace: dev-local # nacos 命名空间(修改这里) group: DEFAULT_GROUP # nacos Group refresh-enabled: true
6、总结
通过以上学习,可以简单的用nacos 做配置中心。
到此这篇关于springboot 整合 nacos 配置实现多个环境不同配置的文章就介绍到这了,更多相关springboot 整合 nacos内容请搜索脚本之家以前的文章或继续浏览下面的相关文章希望大家以后多多支持脚本之家!