目录
1、描述
2、Nacos服务端安装
3、创建dataId 配置中心
4、创建一个springboot 项目
5、重点:不同的springboot 读取不同application
6、总结
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#/login , 输入 用户名/密码: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 做配置中心。