SpringCloud Alibaba Nacos服务组件
Spring Cloud Alibaba
Github项目地址: https://github.com/alibaba/spring-cloud-alibaba/
nacos服务发现
概览
Nacos 致力于帮助您发现、配置和管理微服务。Nacos 提供了一组简单易用的特性集,帮助您快速实现动态服务发现、服务配置、服务元数据及流量管理。
特性
- 服务发现和服务健康监测
- 动态配置服务
- 动态DNS服务
- 服务及其元数据管理
nacos快速开始
1.搭建nacos服务端
下载地址:https://github.com/alibaba/nacos/releases
sh startup.sh -m standalone 单机模式启动命令
sh startup.sh -m cluster 集群模式启动命令
如果启动之后,访问不了需关闭防火墙
systemctl stop firewalld
sh shutdown.sh 关闭命令
具体启动方式参考 Nacos 官网
-
访问http://192.168.1.88:8848/nacos/,默认账号及密码均为nacos
-
搭建nacos 客户端。创建nacos-client服务,添加依赖
<dependency>
<groupId>com.alibaba.cloud</groupId>
<artifactId>spring-cloud-starter-alibaba-nacos-discovery</artifactId>
</dependency>
<!--必须添加,否则注册不上-->
<dependency>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-starter-web</artifactId>
</dependency>
- 编写配置文件application.yml
server:
port: 9527
spring:
application:
name: nacos-client
cloud:
nacos:
discovery:
server-addr: 192.168.1.88:8848
|-----------------------其他配置项----------------------|
group: MICROCLOUD_GROUP # 一般建议大写
cluster-name: YootkCluster # 配置集群名称
metadata: # 根据自身的需要配置元数据
version: 1.0 # 自定义元数据项
author: jyd0124 # 自定义元数据项
- 登录Nacos控制台,在发现服务列表中,已经显示了我们刚才创建的项目
nacos data model
- Namespace,用于进行租户粒度的配置隔离。不同的命名空间下,可以存在相同的 Group 或 Data ID 的配置。Namespace 的常用场景之一是不同环境的配置的区分隔离,例如开发测试环境和生产环境的资源(如配置、服务)隔离。
- Group,一般代表项目,如XX项目。
- DataID, 每个项目下往往有若干个工程,一般表示服务
nacos配置中心
使用 Spring Cloud Alibaba Nacos Config,您可以在 Nacos Server 集中管理你 Spring Cloud 应用的外部属性配置。
- 启动nacos-server,通过控制台发布配置
- 添加nacos config依赖
<dependency>
<groupId>com.alibaba.cloud</groupId>
<artifactId>spring-cloud-starter-alibaba-nacos-config</artifactId>
</dependency>
-
因为配置文件优先级(由高到低):
bootstrap.properties -> bootstrap.yml -> application.properties -> application.yml在 bootstrap.yml添加配置
spring:
application:
name: nacos-client
cloud:
nacos:
config:
enabled: true #配置全局开关 默认true开启
server-addr: 192.168.1.88:8848
file-extension: yaml # 此处为配置使用的后缀名
prefix: nacos-client #DataId 名称(不写默认就是服务名称)
group: DEFAULT_GROUP #分组名称
#命名空间,如果不设置命名空间,默认为public
namespace: a6c05e95-e049-4fb0-9e88-f7302a66a1de
- 启动类。@NacosConfigurationProperties用于加载dataID,autoRefreshed表示开始自动
@SpringBootApplication
@EnableDiscoveryClient
@NacosConfigurationProperties(dataId = "nacos-client",autoRefreshed=true)
public class NacosDiscoveryApplication {
public static void main(String[] args) {
SpringApplication.run(NacosDiscoveryApplication.class, args);
}
}
- 通过 Nacos 的
@NacosValue
或者@Value 注解设置属性值,编写接口进行访问。
@Controller
@RefreshScope
public class TestController {
@Value("${user.name}")
private String name;
@Value("${user.id}")
private String id;
@Value("${user.age}")
private String age;
@Value("${user.dept:计算机}") //没有值取默认值
private String dept;
@RequestMapping(value = "/user", method = RequestMethod.GET)
@ResponseBody
public JSONObject getInfo() {
JSONObject jsonObject = new JSONObject();
jsonObject.put("id", id);
jsonObject.put("name", name);
jsonObject.put("age", age);
jsonObject.put("dept", dept);
return jsonObject;
}
}