微信公众号搜"智元新知"关注
微信扫一扫可直接关注哦!

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;
    }
}

版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 [email protected] 举报,一经查实,本站将立刻删除。

相关推荐