前往小程序,Get更优阅读体验!
立即前往
首页
学习
活动
专区
工具
TVP
发布
社区首页 >专栏 >Nacos入门指南03 - 服务发现实践

Nacos入门指南03 - 服务发现实践

原创
作者头像
dys
修改2020-11-02 10:45:35
9490
修改2020-11-02 10:45:35
举报
文章被收录于专栏:性能与架构性能与架构

你好,欢迎阅读,本文是系列文章中的第3篇。

Part1 - Nacos 是什么?

Part2 - Nacos 环境搭建

Part3 - Nacos 服务发现实践

Part4 - Nacos 分布式配置实践

本文的目的是对 SpringBoot 服务整合 Nacos,实现服务调用。

下面会创建2个 SpringBoot 项目:

  • service-provider
  • service-consumer

都整合 Nacos,启动后可以自动注册到 Nacos 服务注册中心。

然后在 service-consumer 的 Controller 中实现对 service-provider 的接口调用。

步骤:

(1)创建 service-provider 与 service-consumer,整合 Nacos

(2)service-provider 中添加测试接口 "/hello",service-consumer 中调用其 "/hello" 接口

1. 创建服务 整合 Nacos

1.1 service-provider

pom.xml

代码语言:txt
复制
<?xml version="1.0" encoding="UTF-8"?>
...
    <parent>
        <groupId>org.springframework.boot</groupId>
        <artifactId>spring-boot-starter-parent</artifactId>
        <!-- spring boot 版本 -->
        <version>2.2.5.RELEASE</version>
        <relativePath/>
    </parent>
    <groupId>com.example</groupId>
    <artifactId>service-provider</artifactId>
    <version>0.0.1-SNAPSHOT</version>
    <name>service-provider</name>
    <description>Demo project for Spring Boot</description>

    <properties>
        <java.version>1.11</java.version>
    </properties>

    <dependencies>
        <dependency>
            <groupId>org.springframework.boot</groupId>
            <artifactId>spring-boot-starter-web</artifactId>
        </dependency>
        <!-- 加依赖 nacos-discovery -->
        <dependency>
            <groupId>com.alibaba.cloud</groupId>
            <artifactId>spring-cloud-starter-alibaba-nacos-discovery</artifactId>
        </dependency>

    </dependencies>

    <dependencyManagement>
        <dependencies>
            <!-- spring cloud 依赖管理 -->
            <dependency>
                <groupId>org.springframework.cloud</groupId>
                <artifactId>spring-cloud-dependencies</artifactId>
                <version>Hoxton.SR3</version>
                <type>pom</type>
                <scope>import</scope>
            </dependency>
            <!-- spring cloud alibaba 依赖管理 -->
            <dependency>
                <groupId>com.alibaba.cloud</groupId>
                <artifactId>spring-cloud-alibaba-dependencies</artifactId>
                <version>2.2.1.RELEASE</version>
                <type>pom</type>
                <scope>import</scope>
            </dependency>
        </dependencies>
    </dependencyManagement>

    <build>
        <plugins>
            <plugin>
                <groupId>org.springframework.boot</groupId>
                <artifactId>spring-boot-maven-plugin</artifactId>
            </plugin>
        </plugins>
    </build>
...

重点是 SpringBoot、SpringCloud、SpringCloud Alibaba 这3者的版本问题,这里使用的版本为:

  • SpringBoot 2.2.5.RELEASE
  • SpringCloud Hoxton.SR3
  • SpringCloud Alibaba 2.2.1.RELEASE

如何确定各自的版本呢?在 SpringCloud Alibaba 项目的 wiki 文档中有所说明,地址为:

代码语言:txt
复制
https://github.com/alibaba/spring-cloud-alibaba/wiki/%E7%89%88%E6%9C%AC%E8%AF%B4%E6%98%8E

页面效果:

添加好依赖之后,添加相关配置:

代码语言:txt
复制
server:
  port: 8081 # 端口
spring:
  application:
    name: service-provider # 服务名
  cloud:
    nacos:
      discovery:
        server-addr: localhost:8848 # nacos server 地址

然后在启动类中添加注解:

代码语言:txt
复制
...
@SpringBootApplication
@EnableDiscoveryClient // 开启服务发现
public class ServiceProviderApplication {

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

}

1.2 service-consumer

依赖于 service-provider 中一致,还有添加的注解也是一样的。

只是配置有点不同,需要使用不同的端口,以及服务名称:

代码语言:txt
复制
server:
  port: 8082 # 端口
spring:
  application:
    name: service-consumer # 服务名
  cloud:
    nacos:
      discovery:
        server-addr: localhost:8848 # nacos server 地址

1.3 启动测试

分别启动 service-provider 与 service-consumer,启动后即可在 Nacos 控制台的服务列表中看到:

说明整合 Nacos 成功。

2. 服务调用

2.1 service-provider

在 service-provider 中添加一个测试接口 /hello:

代码语言:txt
复制
...
@RestController
public class TestController {
    @GetMapping("hello")
    public String hello(@RequestParam String name){
        return "hello " + name;
    }
}

2.2 service-consumer

在 service-consumer 中进行调用,因为需要使用 RestTemplate,所以先配置一下:

代码语言:txt
复制
...
@Configuration
public class ConsumerConfig {
    // 定义 RestTemplate Bean
    @Bean
    public RestTemplate restTemplate(){
        return new RestTemplate();
    }
}

下面开始调用:

代码语言:txt
复制
...
@RestController
public class TestController {
    // 引入 RestTemplate 和 LoadBalancerClient
    @Autowired
    RestTemplate restTemplate;
    @Autowired
    LoadBalancerClient loadBalancerClient;

    @GetMapping("hello")
    public String hello(@RequestParam String name) {
        String result = "";

        // 根据服务名获取服务实例
        ServiceInstance serviceInstance = loadBalancerClient.choose("service-provider");

        // 发起调用,返回调用结果
        return restTemplate.getForObject(serviceInstance.getUri() + "/hello?name=" + name, String.class);
    }
}

2.3 启动测试

重启 service-provider、service-consumer,访问 service-consumer 的 /hello 接口,地址:

http://localhost:8082/hello?name=nacos

返回结果为 "hello nacos",调用成功。

原创声明:本文系作者授权腾讯云开发者社区发表,未经许可,不得转载。

如有侵权,请联系 cloudcommunity@tencent.com 删除。

原创声明:本文系作者授权腾讯云开发者社区发表,未经许可,不得转载。

如有侵权,请联系 cloudcommunity@tencent.com 删除。

评论
登录后参与评论
0 条评论
热度
最新
推荐阅读
目录
  • 1. 创建服务 整合 Nacos
    • 1.1 service-provider
      • 1.2 service-consumer
        • 1.3 启动测试
        • 2. 服务调用
          • 2.1 service-provider
            • 2.2 service-consumer
              • 2.3 启动测试
              相关产品与服务
              对象存储
              对象存储(Cloud Object Storage,COS)是由腾讯云推出的无目录层次结构、无数据格式限制,可容纳海量数据且支持 HTTP/HTTPS 协议访问的分布式存储服务。腾讯云 COS 的存储桶空间无容量上限,无需分区管理,适用于 CDN 数据分发、数据万象处理或大数据计算与分析的数据湖等多种场景。
              领券
              问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档