手把手教你Spring Cloud Alibaba系列教程:Nacos实现服务注册与发现

简介: 手把手教你Spring Cloud Alibaba系列教程:Nacos实现服务注册与发现

Nacos实现服务注册与发现



什么是Nacos?


Nacos致力于帮助您发现、配置和管理微服务。Nacos提供了一组简单易用的特性集,帮助您快速实现动态服务发现、服务配置、服务元数据及流量管理。Nacos帮助您更敏捷和容易地构建、交付和管理微服务平台。


在接下来的教程里将使用Nacos作为微服务架构中的注册中心(替代:consul等)以及配置中心(spring cloud config)来使用。

安装Nacos


 下载地址:https://github.com/alibaba/nacos/releases 
 本文版本:2.1.1

通过下载工具下载之后,解压。里面有不同脚本文件,根据不同平台,执行相应命令,启动单机版Nacos服务:

Linux/Unix/Mac:sh startup.sh -m standalone
Windows:cmd startup.cmd -m standalone

相应startup.sh脚本在Nacos解压后的bin目录下。

1.png

启动完成之后,访问:http://localhost:8848/,可以进入Nacos的服务管理页面,具体如下;

1.png


应用接入Nacos注册中心


在完成了Nacos服务的安装和启动之后,下面我们编写两个应用(服务提供者与服务消费者)来验证服务的注册与发现了。


服务提供者


  • 第一步:创建一个Spring Boot应用
  • 第二步:修改pom文件
<parent>
    <groupId>org.springframework.boot</groupId>
    <artifactId>spring-boot-starter-parent</artifactId>
    <version>2.7.1</version>
    <relativePath/> <!-- lookup parent from repository -->
</parent>
<dependencyManagement>
    <dependencies>
        <dependency>
            <groupId>org.springframework.cloud</groupId>
            <artifactId>spring-cloud-dependencies</artifactId>
            <version>2021.0.3</version>
            <type>pom</type>
            <scope>import</scope>
        </dependency>
        <dependency>
            <groupId>org.springframework.cloud</groupId>
            <artifactId>spring-cloud-alibaba-dependencies</artifactId>
            <version>2021.1</version>
            <type>pom</type>
            <scope>import</scope>
        </dependency>
    </dependencies>
</dependencyManagement>
<dependencies>
    <dependency>
        <groupId>org.springframework.boot</groupId>
        <artifactId>spring-boot-starter-web</artifactId>
    </dependency>
    <dependency>
        <groupId>org.springframework.cloud</groupId>
        <artifactId>spring-cloud-starter-alibaba-nacos-discovery</artifactId>
    </dependency>
    <dependency>
        <groupId>org.projectlombok</groupId>
        <artifactId>lombok</artifactId>
        <version>1.18.22</version>
        <optional>true</optional>
    </dependency>
</dependencies>

述内容主要三部分:


parent:定义spring boot的版本

dependencyManagement:spring cloud的版本以及spring cloud alibaba的版本,

dependencies:当前应用要使用的依赖内容。这里主要新加入了Nacos的服务注册与发现模块:spring-cloud-starter-alibaba-nacos-discovery。


第三步:创建应用主类,并实现一个HTTP接口

@EnableDiscoveryClient
@SpringBootApplication
public class ErosApplication {
    public static void main(String[] args) {
        SpringApplication.run(ErosApplication.class, args);
    }
    @Slf4j
    @RestController
    static class ErosController {
        @GetMapping("/hello")
        public String hello(@RequestParam String name) {
            return "hello " + name;
        }
    }
}
  • 第四步:配置服务名称和Nacos地址spring:
  server:
    port: 8001
  application:
    name: eros-gateway
  cloud:
    discovery:
      server-addr=127.0.0.1:8848 
  • 第五步:启动应用。
INFO 10475 --- [           main] o.s.c.a.n.registry.NacosServiceRegistry  : nacos registry, eros-gateway 192.168.177.1:8801 register finished

在启动都没问题后可以访问Nacos的管理页面http://127.0.0.1:8848/nacos/来查看服务列表


服务消费者


接下来,实现一个应用来消费上面已经注册到Nacos的服务。

  • 第一步:创建一个Spring Boot应用
  • 第二步:编辑pom.xml中的依赖内容,与上面服务提供者的一样即可。
  • 第三步:创建应用,实现一个HTTP接口,在该接口中调用服务提供方的接口。
@EnableDiscoveryClient
@SpringBootApplication
public class ErosApplication {
    public static void main(String[] args) {
        SpringApplication.run(ErosApplication.class, args);
    }
    @Slf4j
    @RestController
    static class TestController {
        @Autowired
        LoadBalancerClient loadBalancerClient;
        @GetMapping("/test")
        public String test() {
            ServiceInstance serviceInstance = loadBalancerClient.choose("eros-gateway");
            String url = serviceInstance.getUri() + "/hello?name=" + "eros";
            RestTemplate restTemplate = new RestTemplate();
            String result = restTemplate.getForObject(url, String.class);
            return "Invoke : " + url + ", return : " + result;
        }
    }
}

这里使用了Spring Cloud Common中的LoadBalancerClient接口来挑选服务实例信息。然后从挑选出的实例信息中获取可访问的URI,拼接上服务提供方的接口规则来发起调用。


-第四步:配置服务名称和Nacos地址,让服务消费者可以发现上面已经注册到Nacos的服务。

  server:
    port: 8001
  application:
    name: eros-gateway-client
  cloud:
    discovery:
      server-addr=127.0.0.1:8848

第五步:启动服务消费者,然后通过curl或者postman等工具发起访问,下面以curl为例:

$ curl localhost:9000/test
Invoke : http://192.168.177.1:8801/hello?name=eros, return : hello eros
$ curl localhost:9000/test
Invoke : http://192.168.177.1:8802/hello?name=eros, return : hello eros

通过以上请求可以看到,两次不同请求的时候,真正实际调用的服务提供者实例是不同的,也就是说,通过LoadBalancerClient接口在获取服务实例的时候,已经实现了对服务提供方实例的负载均衡。


      以上就是我们今天的教程,如果本文对你有所帮助,欢迎关注点赞,分享给您身边的朋友。您的鼓励就是对我的最大动力。

相关实践学习
部署高可用架构
本场景主要介绍如何使用云服务器ECS、负载均衡SLB、云数据库RDS和数据传输服务产品来部署多可用区高可用架构。
负载均衡入门与产品使用指南
负载均衡(Server Load Balancer)是对多台云服务器进行流量分发的负载均衡服务,可以通过流量分发扩展应用系统对外的服务能力,通过消除单点故障提升应用系统的可用性。 本课程主要介绍负载均衡的相关技术以及阿里云负载均衡产品的使用方法。
相关文章
|
7天前
|
Java API 微服务
【Spring Boot系列】通过OpenAPI规范构建微服务服务接口
【4月更文挑战第5天】通过OpenAPI接口构建Spring Boot服务RestAPI接口
|
1天前
|
Java 数据安全/隐私保护 Sentinel
微服务学习 | Spring Cloud 中使用 Sentinel 实现服务限流
微服务学习 | Spring Cloud 中使用 Sentinel 实现服务限流
|
2天前
|
Java API Nacos
第十二章 Spring Cloud Alibaba Sentinel
第十二章 Spring Cloud Alibaba Sentinel
12 0
|
2天前
|
监控 Java 微服务
第八章 Spring Cloud 之 Hystrix
第八章 Spring Cloud 之 Hystrix
|
2天前
|
监控 Java API
第七章 Spring Cloud 之 GateWay
第七章 Spring Cloud 之 GateWay
|
2天前
|
负载均衡 前端开发 Java
第六章 Spring Cloud 之 OpenFeign
第六章 Spring Cloud 之 OpenFeign
|
2天前
|
消息中间件 Java Nacos
第三章 Spring Cloud简介
第三章 Spring Cloud简介
|
2天前
|
Java Nacos 开发者
Java从入门到精通:4.2.1学习新技术与框架——以Spring Boot和Spring Cloud Alibaba为例
Java从入门到精通:4.2.1学习新技术与框架——以Spring Boot和Spring Cloud Alibaba为例
|
2天前
|
Dubbo Java 应用服务中间件
Java从入门到精通:3.2.2分布式与并发编程——了解分布式系统的基本概念,学习使用Dubbo、Spring Cloud等分布式框架
Java从入门到精通:3.2.2分布式与并发编程——了解分布式系统的基本概念,学习使用Dubbo、Spring Cloud等分布式框架
|
9天前
|
负载均衡 Java 开发者
细解微服务架构实践:如何使用Spring Cloud进行Java微服务治理
【4月更文挑战第17天】Spring Cloud是Java微服务治理的首选框架,整合了Eureka(服务发现)、Ribbon(客户端负载均衡)、Hystrix(熔断器)、Zuul(API网关)和Config Server(配置中心)。通过Eureka实现服务注册与发现,Ribbon提供负载均衡,Hystrix实现熔断保护,Zuul作为API网关,Config Server集中管理配置。理解并运用Spring Cloud进行微服务治理是现代Java开发者的关键技能。