zl程序教程

您现在的位置是:首页 >  后端

当前栏目

Spring Cloud Alibaba-Nacos-创建服务消费者

NacosSpringCloud服务 创建 消费者 Alibaba
2023-09-14 09:14:12 时间

概述

服务消费者的创建与服务提供者大同小异,这里采用最原始的一种方式,即显示的使用 LoadBalanceClient 和 RestTemplate 结合的方式来访问。

POM

创建一个工程名为 hello-spring-cloud-alibaba-nacos-consumer 的服务消费者项目,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. <parent>
  6. <groupId>cn.dandelioncloud</groupId>
  7. <artifactId>hello-spring-cloud-alibaba-dependencies</artifactId>
  8. <version>1.0.0-SNAPSHOT</version>
  9. <relativePath>../hello-spring-cloud-alibaba-dependencies/pom.xml</relativePath>
  10. </parent>
  11. <artifactId>hello-spring-cloud-alibaba-nacos-consumer</artifactId>
  12. <packaging>jar</packaging>
  13. <name>hello-spring-cloud-alibaba-nacos-consumer</name>
  14. <url>http://www.dandelioncloud.cn</url>
  15. <inceptionYear>2018-Now</inceptionYear>
  16. <dependencies>
  17. <!-- Spring Boot Begin -->
  18. <dependency>
  19. <groupId>org.springframework.boot</groupId>
  20. <artifactId>spring-boot-starter-web</artifactId>
  21. </dependency>
  22. <dependency>
  23. <groupId>org.springframework.boot</groupId>
  24. <artifactId>spring-boot-starter-actuator</artifactId>
  25. </dependency>
  26. <dependency>
  27. <groupId>org.springframework.boot</groupId>
  28. <artifactId>spring-boot-starter-test</artifactId>
  29. <scope>test</scope>
  30. </dependency>
  31. <!-- Spring Boot End -->
  32. <!-- Spring Cloud Begin -->
  33. <dependency>
  34. <groupId>org.springframework.cloud</groupId>
  35. <artifactId>spring-cloud-starter-alibaba-nacos-discovery</artifactId>
  36. </dependency>
  37. <!-- Spring Cloud End -->
  38. </dependencies>
  39. <build>
  40. <plugins>
  41. <plugin>
  42. <groupId>org.springframework.boot</groupId>
  43. <artifactId>spring-boot-maven-plugin</artifactId>
  44. <configuration>
  45. <mainClass>cn.dandelioncloud.hello.spring.cloud.alibaba.nacos.consumer.NacosConsumerApplication</mainClass>
  46. </configuration>
  47. </plugin>
  48. </plugins>
  49. </build>
  50. </project>

Application

  1. package cn.dandelioncloud.hello.spring.cloud.alibaba.nacos.consumer;
  2. import org.springframework.boot.SpringApplication;
  3. import org.springframework.boot.autoconfigure.SpringBootApplication;
  4. import org.springframework.cloud.client.discovery.EnableDiscoveryClient;
  5. @SpringBootApplication
  6. @EnableDiscoveryClient
  7. public class NacosConsumerApplication {
  8. public static void main(String[] args) {
  9. SpringApplication.run(NacosConsumerApplication.class, args);
  10. }
  11. }

Configuration

创建一个名为 NacosConsumerConfiguration 的 Java 配置类,主要作用是为了注入 RestTemplate

  1. package cn.dandelioncloud.hello.spring.cloud.alibaba.nacos.consumer.config;
  2. import org.springframework.context.annotation.Bean;
  3. import org.springframework.context.annotation.Configuration;
  4. import org.springframework.web.client.RestTemplate;
  5. @Configuration
  6. public class NacosConsumerConfiguration {
  7. @Bean
  8. public RestTemplate restTemplate() {
  9. return new RestTemplate();
  10. }
  11. }

Controller

创建一个名为 NacosConsumerController 测试用的 Controller

  1. package cn.dandelioncloud.hello.spring.cloud.alibaba.nacos.consumer.controller;
  2. import org.springframework.beans.factory.annotation.Autowired;
  3. import org.springframework.beans.factory.annotation.Value;
  4. import org.springframework.cloud.client.ServiceInstance;
  5. import org.springframework.cloud.client.loadbalancer.LoadBalancerClient;
  6. import org.springframework.web.bind.annotation.GetMapping;
  7. import org.springframework.web.bind.annotation.RestController;
  8. import org.springframework.web.client.RestTemplate;
  9. @RestController
  10. public class NacosConsumerController {
  11. @Autowired
  12. private LoadBalancerClient loadBalancerClient;
  13. @Autowired
  14. private RestTemplate restTemplate;
  15. @Value("${spring.application.name}")
  16. private String appName;
  17. @GetMapping(value = "/echo/app/name")
  18. public String echo() {
  19. //使用 LoadBalanceClient 和 RestTemplate 结合的方式来访问
  20. ServiceInstance serviceInstance = loadBalancerClient.choose("nacos-provider");
  21. String url = String.format("http://%s:%s/echo/%s", serviceInstance.getHost(), serviceInstance.getPort(), appName);
  22. return restTemplate.getForObject(url, String.class);
  23. }
  24. }

application.yml

  1. spring:
  2. application:
  3. name: nacos-consumer
  4. cloud:
  5. nacos:
  6. discovery:
  7. server-addr: 127.0.0.1:8848
  8. server:
  9. port: 9091
  10. management:
  11. endpoints:
  12. web:
  13. exposure:
  14. include: "*"

启动工程

通过浏览器访问 http://localhost:8848/nacos,即 Nacos Server 网址

你会发现多了一个名为 nacos-consumer 的服务

这时打开 http://localhost:9091/echo/app/name ,你会在浏览器上看到: 

  1. Hello Nacos Discovery nacos-consumer

服务的端点检查

通过浏览器访问 http://localhost:9091/actuator/nacos-discovery 你会在浏览器上看到: