Nacos系列第一篇-Nacos之Spring Discovery

Posted 毕来生

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了Nacos系列第一篇-Nacos之Spring Discovery相关的知识,希望对你有一定的参考价值。

你的关注意义重大!

作者:毕来生 微信:878799579

前言

    个人比较看好Spring Cloud Alibaba家族。此系列以Nacos为主题,从Spring、Spring boot、Spring Cloud多个方面逐步进行演示,源码解读。目前来看官方文档还有待完善。网络上除了官网外缺少Nacos系列文章。都是零零散散的知识点。如此系列文章哪里写的有不周全,错误之处。欢迎大家指正。谢谢。

1、Nacos是什么?

来自官网提供Nacos说明

服务(Service)是 Nacos 世界的一等公民。Nacos 支持几乎所有主流类型的“服务”的发现、配置和管理:

Kubernetes Service

gRPC & Dubbo RPC Service

Spring Cloud RESTful Service

Nacos 的关键特性包括一下等等:

  • 服务发现和服务健康监测

  • 动态配置服务

  • 动态 DNS 服务

  • 服务及其元数据管理

Nacos架构图

2、准备工作

工具:IDEA2018.3 、JDK: 1.8、Maven:3.5(通用配置。后续不在提及此部分。均已此版本演示)

Nacos:0.7.0(写此文章时最新版本,如后续更新。以最新版本给大家演示)

环境:Windows(演示用,后续更新完成后会有一章在linux下演示。有坑,但原理一样。不多赘述。)

Nacos稳定版本:https://github.com/alibaba/nacos/releases

Linux下请下载tar后解压。Windows下请下载zip。

 
   
   
 
  1.  unzip nacos-server-$version.zip 或者 tar -xvf nacos-server-$version.tar.gz

下载后启动Nacos。Nacos默认启动端口为8848,意为珠穆朗玛峰高度。如启动有端口冲突,请自行调整端口。

3、工程结构

上面说了那么多,现在先整理来看一下我们的工程结构

附上关键部分代码。

NacosConfiguration

 
   
   
 
  1. package org.nacos.spring;


  2. import com.alibaba.nacos.api.annotation.NacosProperties;

  3. import com.alibaba.nacos.spring.context.annotation.config.NacosPropertySource;

  4. import com.alibaba.nacos.spring.context.annotation.discovery.EnableNacosDiscovery;

  5. import org.springframework.beans.factory.annotation.Configurable;


  6. /**

  7. * @Author: bilaisheng

  8. * @Wechat: 878799579

  9. * @Date: 2019/1/13 19:28

  10. * @Todo: NacosConfiguration,用以注册以及测试Service Name : nacos-spring

  11. * @Version : JDK8 , IDEA2018

  12. */

  13. @Configurable

  14. @EnableNacosConfig(globalProperties = @NacosProperties(serverAddr = "127.0.0.1:8848"))

  15. @NacosPropertySource(dataId = "nacos-spring", autoRefreshed = true)

  16. public class NacosConfiguration {

  17. }

  • @EnableNacosConfig 注解启用 Nacos Spring 的配置管理服务。

  • @NacosPropertySource 加载了dataId nacos-spring`的配置源,并开启自动更新。

  • 对 Nacos Spring 的用户来说,在自身应用中就只是设置 “autoRefreshed” 的一个布尔值。然后在需要修改配置的时候,调用 Nacos 修改配置的接口,或使用 Nacos 的控制台去修改,配置发生变更后, Nacos 就会把最新的配置推送到该应用的所有机器上。

NacosDiscoveryController

 
   
   
 
  1. package org.nacos.spring.controller;


  2. import com.alibaba.nacos.api.annotation.NacosInjected;

  3. import com.alibaba.nacos.api.config.annotation.NacosValue;

  4. import com.alibaba.nacos.api.exception.NacosException;

  5. import com.alibaba.nacos.api.naming.NamingService;

  6. import com.alibaba.nacos.api.naming.pojo.Instance;

  7. import com.alibaba.nacos.spring.context.annotation.discovery.EnableNacosDiscovery;

  8. import org.springframework.stereotype.Controller;

  9. import org.springframework.web.bind.annotation.PathVariable;

  10. import org.springframework.web.bind.annotation.RequestMapping;

  11. import org.springframework.web.bind.annotation.RequestParam;

  12. import org.springframework.web.bind.annotation.ResponseBody;


  13. import java.util.Date;

  14. import java.util.List;


  15. import static org.springframework.web.bind.annotation.RequestMethod.GET;


  16. /**

  17. * @Author: bilaisheng

  18. * @Wechat: 878799579

  19. * @Date: 2019/1/13 19:29

  20. * @Todo: NacosDisCoveryTest

  21. * @Version : JDK8 , IDEA2018

  22. */

  23. @Controller

  24. @RequestMapping("nacos")

  25. public class NacosDiscoveryController {


  26.    @NacosInjected

  27.    private NamingService namingService;


  28.    @NacosValue(value = "${useLocalCache:false}", autoRefreshed = true)

  29.    private boolean useLocalCache;


  30.    @RequestMapping("/{str}")

  31.    public String helloNacos(@PathVariable String str){

  32.        return new Date() + "Hello Nacos " + str;

  33.    }


  34.    @RequestMapping("/instance")

  35.    @ResponseBody

  36.    public List<Instance> getInstance(@PathVariable  String serviceName) throws NacosException {

  37.        return namingService.getAllInstances(serviceName);

  38.    }


  39.    @RequestMapping(value = "/get", method = GET)

  40.    @ResponseBody

  41.    public boolean get() {

  42.        return useLocalCache;

  43.    }

  44. }

此文件为普通Spring映射控制器,话说Nacos Spring还是小马哥@mercyblitz亲自操刀。大家可以不用怀疑质量啦。相信很多同学都快被小马哥逼的要劝退了。

着重说明一下,这个也是Nacos中常用的方法之一。

 
   
   
 
  1.    @RequestMapping("/instance")

  2.    @ResponseBody

  3.    public List<Instance> getInstance(@PathVariable  String serviceName) throws NacosException {

  4.        return namingService.getAllInstances(serviceName);

  5.    }

获取全部实例

 
   
   
 
  1. List<Instance> getAllInstances(String serviceName) throws NacosException;


  2. List<Instance> getAllInstances(String serviceName, List<String> clusters) throws NacosException;

请求参数

名称 类型 描述
serviceName 字符串 服务名
clusters List 集群列表

返回参数

List 实例列表。

获取配置

描述

用于服务启动的时候从 Nacos 获取配置。

 
   
   
 
  1. public String getConfig(String dataId, String group, long timeoutMs) throws NacosException

请求参数

参数名 参数类型 描述
dataId string 配置 ID,采用类似 package.class(如com.taobao.tc.refund.log.level)的命名规则保证全局唯一性,class 部分建议是配置的业务含义。全部字符小写。只允许英文字符和 4 种特殊字符("."、":"、"-"、"_"),不超过 256 字节。
group string 配置分组,建议填写产品名:模块名(Nacos:Test)保证唯一性,只允许英文字符和4种特殊字符("."、":"、"-"、"_"),不超过128字节。
timeout long 读取配置超时时间,单位 ms,推荐值 3000。

返回值

参数类型 描述
string 配置值

请求示例

 
   
   
 
  1. try {

  2.    String serverAddr = "{serverAddr}";

  3.    String dataId = "{dataId}";

  4.    String group = "{group}";

  5.    Properties properties = new Properties();

  6.    properties.put("serverAddr", serverAddr);

  7.    ConfigService configService = NacosFactory.createConfigService(properties);

  8.    String content = configService.getConfig(dataId, group, 5000);

  9.    System.out.println(content);

  10. } catch (NacosException e) {

  11.    // TODO Auto-generated catch block

  12.    e.printStackTrace();

  13. }


上述两个文件中关于Nacos使用,请参考官网NacosSDK。里面详细标注了每个方法以及对应参数以及测试案例。

父pom.xml

 
   
   
 
  1. <?xml version="1.0" encoding="UTF-8"?>


  2. <project xmlns="http://maven.apache.org/POM/4.0.0" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"

  3.  xsi:schemaLocation="http://maven.apache.org/POM/4.0.0 http://maven.apache.org/xsd/maven-4.0.0.xsd">

  4.  <modelVersion>4.0.0</modelVersion>


  5.  <groupId>org.bilaisheng.nacos</groupId>

  6.  <artifactId>nacos-spring-examples</artifactId>

  7.  <packaging>pom</packaging>

  8.  <version>1.0-SNAPSHOT</version>

  9.  <modules>

  10.    <module>nacos-spring-discvoery</module>

  11.  </modules>


  12.  <name>nacos-spring-examples</name>


  13.  <properties>

  14.    <maven.compiler.source>1.8</maven.compiler.source>

  15.    <maven.compiler.target>1.8</maven.compiler.target>

  16.    <project.build.sourceEncoding>UTF-8</project.build.sourceEncoding>

  17.    <spring.framework.version>5.1.3.RELEASE</spring.framework.version>

  18.    <servlet-api.version>4.0.1</servlet-api.version>

  19.    <nacos-spring-context.version>0.2.2-RC1</nacos-spring-context.version>

  20.  </properties>


  21.  <dependencyManagement>

  22.    <dependencies>

  23.      <!-- https://mvnrepository.com/artifact/javax.servlet/javax.servlet-api -->

  24.      <dependency>

  25.        <groupId>javax.servlet</groupId>

  26.        <artifactId>javax.servlet-api</artifactId>

  27.        <version>${servlet-api.version}</version>

  28.        <scope>provided</scope>

  29.      </dependency>


  30.      <!-- https://mvnrepository.com/artifact/org.springframework/spring-core -->

  31.      <dependency>

  32.        <groupId>org.springframework</groupId>

  33.        <artifactId>spring-core</artifactId>

  34.        <version>${spring.framework.version}</version>

  35.      </dependency>


  36.      <!-- https://mvnrepository.com/artifact/org.springframework/spring-context -->

  37.      <dependency>

  38.        <groupId>org.springframework</groupId>

  39.        <artifactId>spring-context</artifactId>

  40.        <version>${spring.framework.version}</version>

  41.      </dependency>


  42.      <!-- https://mvnrepository.com/artifact/org.springframework/spring-webmvc -->

  43.      <dependency>

  44.        <groupId>org.springframework</groupId>

  45.        <artifactId>spring-webmvc</artifactId>

  46.        <version>${spring.framework.version}</version>

  47.      </dependency>


  48.      <!-- https://mvnrepository.com/artifact/com.alibaba.nacos/nacos-spring-context -->

  49.      <dependency>

  50.        <groupId>com.alibaba.nacos</groupId>

  51.        <artifactId>nacos-spring-context</artifactId>

  52.        <version>${nacos-spring-context.version}</version>

  53.      </dependency>


  54.    </dependencies>

  55.  </dependencyManagement>

  56. </project>

本工程pom.xml

 
   
   
 
  1. <?xml version="1.0" encoding="UTF-8"?>

  2. <project xmlns="http://maven.apache.org/POM/4.0.0"

  3.         xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"

  4.         xsi:schemaLocation="http://maven.apache.org/POM/4.0.0 http://maven.apache.org/xsd/maven-4.0.0.xsd">

  5.    <parent>

  6.        <artifactId>nacos-spring-examples</artifactId>

  7.        <groupId>org.bilaisheng.nacos</groupId>

  8.        <version>1.0-SNAPSHOT</version>

  9.    </parent>

  10.    <modelVersion>4.0.0</modelVersion>


  11.    <artifactId>nacos-spring-discvoery</artifactId>

  12.    <dependencies>

  13.        <!-- https://mvnrepository.com/artifact/javax.servlet/javax.servlet-api -->

  14.        <dependency>

  15.            <groupId>javax.servlet</groupId>

  16.            <artifactId>javax.servlet-api</artifactId>

  17.        </dependency>


  18.        <!-- https://mvnrepository.com/artifact/org.springframework/spring-webmvc -->

  19.        <dependency>

  20.            <groupId>org.springframework</groupId>

  21.            <artifactId>spring-webmvc</artifactId>

  22.        </dependency>


  23.        <!-- https://mvnrepository.com/artifact/com.alibaba.nacos/nacos-spring-context -->

  24.        <dependency>

  25.            <groupId>com.alibaba.nacos</groupId>

  26.            <artifactId>nacos-spring-context</artifactId>

  27.        </dependency>

  28.    </dependencies>

  29. </project>

页面请求

页面请求同普通Spring相同,启动后根据http://ip:端口/controller/xxx。

喜欢就关注我吧


以上是关于Nacos系列第一篇-Nacos之Spring Discovery的主要内容,如果未能解决你的问题,请参考以下文章

微服务Spring Cloud Alibaba之Nacos篇, Nacos 就是注册中心 + 配置中心的组合

微服务Spring Cloud Alibaba之Nacos篇, Nacos 就是注册中心 + 配置中心的组合

微服务Spring Cloud Alibaba之Sentinel篇,使用熔断器防止雪崩

微服务Spring Cloud Alibaba之Sentinel篇,使用熔断器防止雪崩

Nacos的数据持久化

第一篇:Nacos 下载和运行