注册中心
nacos
nacos可以帮助发现、配置、管理微服务
nacos的discovery
1、首先要下载nacos
官网地址
2、在微服务引入依赖(此时只加入了discovery依赖,没有加入配置中心的依赖)
<dependency>
<groupId>com.alibaba.cloud</groupId>
<artifactId>spring-cloud-starter-alibaba-nacos-discovery</artifactId>
</dependency>
注意一定要选择对应的版本(来自官网)
详情可以点击对应版本详情
3、编写application.properties文件
server.port=8080 //指定微服务启动端口(自定义,只要端口没用被占用)
spring.application.name=nacos-service //指定微服务名称(自定义)
spring.cloud.nacos.discovery.server-addr=127.0.0.1:8848 //nacos的地址
management.endpoints.web.exposure.include=*//表示暴露所有的端口,如果需要细粒度的暴露端口,可以使用","进行分割。
4、在springboot的启动类上@EnableDiscoveryClient
@SpringBootApplication
@EnableDiscoveryClient
public class NacosApplication {
public static void main(String[] args) {
SpringApplication.run(NacosApplication.class, args);
}
}
这样就可以在nacos的控制台上看到微服务名nacos-producer(spring.application.name中定义的)
naxos的配置中心
1、添加依赖
<dependency>
<groupId>com.alibaba.cloud</groupId>
<artifactId>spring-cloud-starter-alibaba-nacos-config</artifactId>
</dependency>
<dependency>
<groupId>com.alibaba.cloud</groupId>
<artifactId>spring-cloud-starter-alibaba-nacos-discovery</artifactId>
</dependency>
2、编写配置文件
由于添加了nacos的配置文件,所有一定要有bootstrap.properties或bootstrap.yml的配置文件。bootstrap的优先级大于application的优先级,所以bootstrap会优先加载。
bootstrap.properties
spring.application.name=nacos-config//服务名称
spring.cloud.nacos.config.server-addr=127.0.0.1:8848//配置中心地址
//配置文件格式
spring.cloud.nacos.config.file-extension=yaml(对应yml)
3、在nacos中新增一个配置文件
Data ID: nacos-config-develop.yaml //对一个配置文件进行唯一标识
Group : DEFAULT_GROUP
配置格式: YAML
配置内容: current.env: develop-env
4、 DataID 的命名规则
DataID的命名规则就是:前缀-环境-扩展名,
即
${spring.cloud.nacos.config.prefix}
-${spring.profiles.active}
.${spring.cloud.nacos.config.file-extension}
- prefix:前缀,默认是 spring.application.name 的值,也可以通过配置项 spring.cloud.nacos.config.prefix 来配置。
- active:配置运行环境,即为当前环境对应的 profile。注意:当 spring.profiles.active 为空时,dataId 的拼接格式变成 p r e f i x . {prefix}. prefix.{file-extension}
- file-exetension:配置文件的类型
例如:
spring.cloud.nacos.config.prefix=cloud-producer-server
spring.profiles.active=dev
spring.cloud.nacos.config.file-extension=yaml
dataID叫 cloud-producer-server-dev.yml
命名空间Namespace
Namespace可以对多环境配置进行管理和隔离。
在配置中心可以使用cloud.nacos.config.namespace指定命名空间,如果不指定命名空间默认是puclic.
Group分组
Namespace进行环境隔离而group则对通一个环境的不同服务进行分组隔离。
在配置文件中可以通过spring.cloud.nacos.config.group进行指定。如果不指定默认是DEFAULT_GROUP。
在需要刷新的地方添加@RefreshScope
例如:
//配置发布之后,动态刷新配置
@RefreshScope
@RestController
@RequestMapping("NocasController")
public class NocasController
{
// 使用原生注解@Value()导入配置
@Value("${u.id}")
private String id;
@Value("${u.name}")
private String name;
@Value("${u.age}")
private String age;
}
只要nacos配置中心修改了配置,那么NocasController中的值就会自动刷新。