SpringCloud Alibaba-Nacos注册中心
Nacos是阿里巴巴开源的一个更易于构建云原生应用的动态服务发现、配置管理和服务管理平台。他是使用Java编写,需要依赖Java环境。
Nacos文档地址:http://nacos.io/zh-cn/docs/quick-start.html
1)下载nacos-server
地址:http://github.com/alibaba/nacos/releases
2)启动nacos-server
双击bin中的startup.cmd文件
访问http://localhost:8848/nacos/
使用默认的用户名/密码nacos/nacos进行登录
3)将微服务注册到nacos中
1、首先修改pom.xml文件,引入Nacos Discovery Starter。
<dependency>
<groupld>com.alibaba.cloud</groupld>
<artifactld>spring-cloud-starter-alibaba-nacos-discovery</artifactld>
</dependency>
2、在应用中的 /src/main/resources/application.properties 配置文件中配置Nacos Server地址
spring.cloud.nacos.discovery.server-addr=127.0.0.1:8848
3、使用注解@EnableDiscoveryClient开启服务注册发现功能
@SpringBootApplication
@EnableDiscoveryClient
public class ProviderApplication {
public static void main(Stringll args) {
SpringApplication.run(Application.class, args);
}
}
4、启动应用,观察nacos服务列表是否已经注册上服务
注意:每一个应用都应该有名字,这样才能注册上去。修改application.properties文件
spring.applcation.name=service-provider
server.port=8000
4)Feign的远程调用
想要远程调用别的服务引入open-feign,编写一个接口,告诉SpringCloud这个接口需要调用远程服务。
- 加注解@FeignClient(“nacos服务名”),例如@FeignClient(“gulimall-coupon”)
- 声明接口的每一个方法都是调用哪个远程服务的哪个请求
- 开启远程调用功能:启动类加注解@EnableFeignClients
- 编写测试类:
- 启动对应的两个服务查看运行结果:
Nacos配置中心 简单示例:
- 在common中导入依赖
- 在coupon服务中添加配置文件bootstrap.properties(优先于application.properties文件加载),定义当前应用名称和配置中心服务器地址
传统配置方法
application.properties文件中进行配置:
控制层使用@Value注解引用配置:
- 启动服务看到日志,Nacos获取gulimall-coupon.properties配置信息
- 到配置中心的配置列表,点击+号新建配置,给配置中心默认添加一个数据集(Data Id),默认规则:应用名.properties(例如:gulimall-coupon.properties)
- 控制层加注解@RefreshScope,目的动态获取并刷新配置,
加注解@Value(“${配置项的名}”),目的获取到配置
- 更改Nacos配置信息,点击发布,刷新页面查看结果更改成功!
细节:
1)命名空间:配置隔离
默认:public(保留空间):默认新增的所有配置都在public空间。
1、开发,测试,生产:利用命名空间来做环境隔离。
注意:在bootstrap.properties:配置上,需要使用哪个命名空间下的配置