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 官网

  1. 访问http://192.168.1.88:8848/nacos/,默认账号及密码均为nacos

  2. 搭建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>
  1. 编写配置文件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 # 自定义元数据项
  1. 登录Nacos控制台,在发现服务列表中,已经显示了我们刚才创建的项目

nacos data model
  • Namespace,用于进行租户粒度的配置隔离。不同的命名空间下,可以存在相同的 Group 或 Data ID 的配置。Namespace 的常用场景之一是不同环境的配置的区分隔离,例如开发测试环境和生产环境的资源(如配置、服务)隔离。
  • Group,一般代表项目,如XX项目。
  • DataID, 每个项目下往往有若干个工程,一般表示服务

nacos配置中心

使用 Spring Cloud Alibaba Nacos Config,您可以在 Nacos Server 集中管理你 Spring Cloud 应用的外部属性配置。

  1. 启动nacos-server,通过控制台发布配置

  1. 添加nacos config依赖
<dependency>
    <groupId>com.alibaba.cloud</groupId>
    <artifactId>spring-cloud-starter-alibaba-nacos-config</artifactId>
</dependency>
  1. 因为配置文件优先级(由高到低):
    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
  1. 启动类。@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);
    }

}
  1. 通过 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;
    }
}

posted @ 2022-06-15 02:51  jyd0124  阅读(107)  评论(1编辑  收藏  举报