服务注册与发现:Nacos Discovery

导读:本篇文章讲解 服务注册与发现:Nacos Discovery,希望对大家有帮助,欢迎收藏,转发!站点地址:www.bmabk.com

目录

一、概述

二、Nacos discovery——服务的注册与发现

 1. 版本关系

 2. 下载安装

(1)下载

(2)启动 

(3)浏览器访问

 三、Nacos服务注册与发现实战

1. 构建Spring Cloud Alibaba工程

(1)创建父工程

 (2)创建子项目

2. 编写测试Controller

3. 服务注册与发现的配置 

4. 验证负载均衡配置


一、概述

Nacos是一个更易于构建云原生应用的动态服务发现配置管理服务管理平台

特性:

(1)服务发现与服务健康检测

(2)动态配置服务

(3)动态 DNS 服务

(4)服务及其元数据管理

二、Nacos discovery——服务的注册与发现

        Nacos Discovery Starter 可以帮助您将服务自动注册到 Nacos 服务端,并且能够动态感知和刷新某个服务实例的服务列表。除此之外,Nacos Discovery Starter 也将服务实例自身的一些元数据信息-例如 host,port,健康检查URL,主页等-注册到 Nacos 。

 1. 版本关系

        关于Spring Cloud Alibaba与Spring boot, Spring Cloud Alibaba 与其他微服务组件之间的版本对应关系:Home · alibaba/spring-cloud-alibaba Wiki · GitHub

这里截取部分对应关系,我使用的 Spring Cloud Alibaba 版本为 2.2.9.RELEASE。

服务注册与发现:Nacos Discovery

服务注册与发现:Nacos Discovery

 2. 下载安装

(1)下载

Nacos 下载地址:Releases · alibaba/nacos (github.com)

这里我下载的Windows版本:

服务注册与发现:Nacos Discovery

(2)启动 

将压缩包放至文件夹解压即可,运行bin目录下startup.cmd脚本即可启动:

服务注册与发现:Nacos Discovery

服务注册与发现:Nacos Discovery

注意:这里启动的是单机模式,默认是集群模式

服务注册与发现:Nacos Discovery

 (3)浏览器访问

默认用户名和密码都是 nacos

服务注册与发现:Nacos Discovery

 三、Nacos服务注册与发现实战

说明:这里先构建一个父工程,父工程下分别有两个微服务模块,一个是订单模块,一个是库存模块,订单要调用库存模块的接口,下面演示如何调用,以及使用Nacos进行服务的注册与发现。

1. 构建Spring Cloud Alibaba工程

(1)创建父工程

服务注册与发现:Nacos Discovery

 服务注册与发现:Nacos Discovery

 (2)创建子项目

创建订单服务模块:

服务注册与发现:Nacos Discovery服务注册与发现:Nacos Discovery

 创建库存服务模块:

服务注册与发现:Nacos Discovery服务注册与发现:Nacos Discovery

 搭建父子关系:

更改父工程 pom.xml 的打包方式,并引入子模块:

<packaging>pom</packaging>
<modules>
    <module>order-nacos</module>
    <module>stock-nacos</module>
</modules>

 在子模块中指定父模块:

    <parent>
        <groupId>com.example</groupId>
        <artifactId>nacos-learn-parent</artifactId>
        <version>0.0.1-SNAPSHOT</version>
    </parent>

2. 编写测试Controller

在order启动类中引入RestTemplate,用于微服务之间的接口调用

@SpringBootApplication
public class OrderNacosApplication {
    public static void main(String[] args) {
        SpringApplication.run(OrderNacosApplication.class, args);
    }

    @Bean
    public RestTemplate restTemplate(RestTemplateBuilder builder) {
        RestTemplate restTemplate = builder.build();
        return restTemplate;
    }
}

在订单的微服务模块下创建 OrderController:

@RestController
@RequestMapping("/order")
public class OrderController {

    @Autowired
    RestTemplate restTemplate;

    @RequestMapping("/add")
    public String add() {
        System.out.println("下单成功!");
        String msg = restTemplate.getForObject("http://stock-service/stock/reduct", String.class);
        return "下订单了!" + msg;
    }

}

在库存的微服务模块下创建 StockController:

@RestController
@RequestMapping("/stock")
public class StockController {

    @Value("${server.port}")
    String port;

    @RequestMapping("/reduct")
    public String reduct() {
        System.out.println("扣减库存");
        return "库存-1,调用的库存服务的端口号为:" + port;
    }
}

3. 服务注册与发现的配置 

订单模块Application.yml 配置:

server:
  port: 8020  #订单服务启动的端口
spring:
  application:
    name: order-service  #nacos会将该名称当作服务名称
  cloud:
    nacos:
      server-addr: 127.0.0.1:8848  #nacos服务地址
      discovery:
        username: nacos  #登录到nacos管理平台的用户名
        password: nacos  #登录到nacos管理平台的密码
        namespace: public      #服务的命名空间,就相当于一个文件夹,用来区分服务实例

库存模块Applicaion.yml 配置:

server:
  port: 8021  #库存服务启动的端口号
spring:
  application:
    name: stock-service  #nacos会将该名称当作服务名称
  cloud:
    nacos:
      server-addr: 127.0.0.1:8848  #nacos服务地址
      discovery:
        username: nacos  #登录到nacos管理平台的用户名
        password: nacos  #登录到nacos管理平台的密码
        namespace: public      #服务的命名空间,就相当于一个文件夹,用来区分服务实例

启动两个服务:

服务注册与发现:Nacos Discovery

访问浏览器测试调用接口是否成功:

服务注册与发现:Nacos Discovery

    @Bean
    @LoadBalanced
    public RestTemplate restTemplate(RestTemplateBuilder builder) {
        RestTemplate restTemplate = builder.build();
        return restTemplate;
    }

查看Nacos 管理面板:

可以看到两个服务以及注册到nacos。

服务注册与发现:Nacos Discovery

补充:关于 Nacos Starter 更多的配置项信息

配置项 Key 默认值 说明

服务端地址

spring.cloud.nacos.discovery.server-addr

Nacos Server 启动监听的ip地址和端口

服务名

spring.cloud.nacos.discovery.service

${spring.application.name}

给当前的服务命名

服务分组

spring.cloud.nacos.discovery.group

DEFAULT_GROUP

设置服务所处的分组

权重

spring.cloud.nacos.discovery.weight

1

取值范围 1 到 100,数值越大,权重越大

网卡名

spring.cloud.nacos.discovery.network-interface

当IP未配置时,注册的IP为此网卡所对应的IP地址,如果此项也未配置,则默认取第一块网卡的地址

注册的IP地址

spring.cloud.nacos.discovery.ip

优先级最高

注册的端口

spring.cloud.nacos.discovery.port

-1

默认情况下不用配置,会自动探测

命名空间

spring.cloud.nacos.discovery.namespace

常用场景之一是不同环境的注册的区分隔离,例如开发测试环境和生产环境的资源(如配置、服务)隔离等。

AccessKey

spring.cloud.nacos.discovery.access-key

当要上阿里云时,阿里云上面的一个云账号名

SecretKey

spring.cloud.nacos.discovery.secret-key

当要上阿里云时,阿里云上面的一个云账号密码

Metadata

spring.cloud.nacos.discovery.metadata

使用Map格式配置,用户可以根据自己的需要自定义一些和服务相关的元数据信息

日志文件名

spring.cloud.nacos.discovery.log-name

集群

spring.cloud.nacos.discovery.cluster-name

DEFAULT

配置成Nacos集群名称

接入点

spring.cloud.nacos.discovery.enpoint

UTF-8

地域的某个服务的入口域名,通过此域名可以动态地拿到服务端地址

是否集成Ribbon

ribbon.nacos.enabled

true

一般都设置成true即可

是否开启Nacos Watch

spring.cloud.nacos.discovery.watch.enabled

true

可以设置成false来关闭 watch

注册的IP地址类型

spring.cloud.nacos.discovery.ip-type

IPv4

可以配置IPv4和IPv6两种类型

 4. 验证负载均衡配置

        Nacos 默认使用的是 Ribbon 提供的负载均衡机制,Ribbon 属于客户端的负载均衡,默认使用的方式是轮询。

(1)在RestTemplate配置上加 @LoadBalanced注解

    @Bean
    @LoadBalanced
    public RestTemplate restTemplate(RestTemplateBuilder builder) {
        RestTemplate restTemplate = builder.build();
        return restTemplate;
    }

(2)在StockController 的/reduct接口被调用时,返回该服务的端口号

@RestController
@RequestMapping("/stock")
public class StockController {

    @Value("${server.port}")
    String port;

    @RequestMapping("/reduct")
    public String reduct() {
        System.out.println("扣减库存");
        return "库存-1,调用的库存服务的端口号为:" + port;
    }
}

 (3)启动两个库存服务,右键点击 Copy Configuration 选项,选择启动的端口号为8022:

就是库存服务要在多个端口启动时,这样来操作

服务注册与发现:Nacos Discovery服务注册与发现:Nacos Discovery

可以看到在Nacos服务列表中,stock-service多了一个实例:

服务注册与发现:Nacos Discovery

 验证负载均衡:

服务注册与发现:Nacos Discovery

服务注册与发现:Nacos Discovery

 服务注册与发现:Nacos Discovery

 

 

 

 

 

 

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

文章由极客之音整理,本文链接:https://www.bmabk.com/index.php/post/87925.html

(0)
小半的头像小半

相关推荐

极客之音——专业性很强的中文编程技术网站,欢迎收藏到浏览器,订阅我们!