SpringCloud微服务实战:Nacos服务注册与配置中心(非常详细附git源码)

Springboot-cli 开发脚手架系列


文章目录

  • Springboot-cli 开发脚手架系列
  • 简介
        • `Nacos 的特性`
        • `Nacos 服务注册中心`
    • 1. 环境准备
    • 2. 创建Springcloud项目
    • 3. 服务提供者
    • 4. 服务消费者
    • 6. 源码分享


简介

Nacos 提供了一系列简单易用的特性,能够帮助我们快速地实现动态服务发现、服务配置等功能。

Nacos 的特性

  • 服务发现
  • 服务健康监测
  • 动态配置服务
  • 动态 DNS 服务
  • 服务及其元数据管理

Nacos 服务注册中心

  • Nacos 作为服务注册中心可以实现服务的注册与发现
    SpringCloud微服务实战:Nacos服务注册与配置中心(非常详细附git源码)_第1张图片

共涉及到以下 3 个角色:

  • 服务注册中心(Register Service):它是一个 Nacos Server,可以为服务提供者和服务消费者提供服务注册和发现功能。
  • 服务提供者(Provider Service):它是一个 Nacos Client,用于对外服务。它将自己提供的服务注册到服务注册中心,以供服务消费者发现和调用。
  • 服务消费者(Consumer Service):它是一个 Nacos Client,用于消费服务。它可以从服务注册中心获取服务列表,调用所需的服务。

接下来我们进入实战演示

1. 环境准备

  • 安装nacos
  1. docker安装参考http://t.csdn.cn/xSyjO
  2. 其它环境略
  • 打开nacos管理页面http://ip:8848/nacos/
  • 新增一个test命名空间
    SpringCloud微服务实战:Nacos服务注册与配置中心(非常详细附git源码)_第2张图片
    SpringCloud微服务实战:Nacos服务注册与配置中心(非常详细附git源码)_第3张图片
  • 保存这个命名空间id
    SpringCloud微服务实战:Nacos服务注册与配置中心(非常详细附git源码)_第4张图片

2. 创建Springcloud项目

  • 创建过程略,结尾有源码
  • springCloud与nacos版本对照信息参考 https://start.spring.io/actuator/info
  • pom添加依赖,此处采用2021.1版本的nacos
 <properties>
        <project.build.sourceEncoding>UTF-8project.build.sourceEncoding>
        <project.reporting.outputEncoding>UTF-8project.reporting.outputEncoding>
        <maven.compiler.source>1.8maven.compiler.source>
        <maven.compiler.target>1.8maven.compiler.target>
        <spring-cloud.version>2020.0.5spring-cloud.version>
        <spring-cloud-alibaba.version>2021.1spring-cloud-alibaba.version>
        <spring-boot-dependencies.version>2.5.3spring-boot-dependencies.version>
    properties>
<dependencies>
        <dependency>
            <groupId>org.springframework.bootgroupId>
            <artifactId>spring-boot-starter-webartifactId>
        dependency>
        
        <dependency>
            <groupId>com.alibaba.cloudgroupId>
            <artifactId>spring-cloud-starter-alibaba-nacos-discoveryartifactId>
        dependency>
        <dependency>
            <groupId>com.alibaba.cloudgroupId>
            <artifactId>spring-cloud-starter-alibaba-nacos-configartifactId>
        dependency>
        
        <dependency>
            <groupId>org.springframework.cloudgroupId>
            <artifactId>spring-cloud-starter-openfeignartifactId>
        dependency>
        
        <dependency>
            <groupId>org.springframework.cloudgroupId>
            <artifactId>spring-cloud-loadbalancerartifactId>
        dependency>
        <dependency>
            <groupId>org.springframework.cloudgroupId>
            <artifactId>spring-cloud-starter-bootstrapartifactId>
        dependency>
        <dependency>
            <groupId>org.projectlombokgroupId>
            <artifactId>lombokartifactId>
            <optional>trueoptional>
        dependency>
        <dependency>
            <groupId>org.springframework.bootgroupId>
            <artifactId>spring-boot-starter-testartifactId>
            <scope>testscope>
            <exclusions>
                <exclusion>
                    <groupId>org.junit.vintagegroupId>
                    <artifactId>junit-vintage-engineartifactId>
                exclusion>
            exclusions>
        dependency>
    dependencies>

    <dependencyManagement>
        <dependencies>
            <dependency>
                <groupId>com.alibaba.cloudgroupId>
                <artifactId>spring-cloud-alibaba-dependenciesartifactId>
                <version>${spring-cloud-alibaba.version}version>
                <type>pomtype>
                <scope>importscope>
            dependency>
            
            <dependency>
                <groupId>org.springframework.bootgroupId>
                <artifactId>spring-boot-dependenciesartifactId>
                <version>${spring-boot-dependencies.version}version>
                <type>pomtype>
                <scope>importscope>
            dependency>
            <dependency>
                <groupId>org.springframework.cloudgroupId>
                <artifactId>spring-cloud-dependenciesartifactId>
                <version>${spring-cloud.version}version>
                <type>pomtype>
                <scope>importscope>
            dependency>
        dependencies>
    dependencyManagement>

3. 服务提供者

  • 配置文件更名为bootstrap.yml
server:
  port: 9998
# NaCos
spring:
  application:
    name: provider
  # NaCos
  cloud:
    service-registry:
      auto-registration:
        # 是否注册到注册中心
        enabled: true
    nacos:
      discovery:
        server-addr: 192.168.41.128:8848
        namespace: 1d5a097c-898e-403e-8935-fdbe2cf854f6
      config:
        server-addr: ${spring.cloud.nacos.discovery.server-addr}
        namespace: ${spring.cloud.nacos.discovery.namespace}
        file-extension: yaml
        prefix: ${spring.application.name}
  • 此处的namespace即为我们开头创建的命名空间的ID,根据自己实际情况改为你实际的id
  • 创建API接口IndexController.java
@RestController
@Slf4j
public class IndexController {

    @GetMapping("get")
    public String get() {
        return "喵喵喵";
    }
}
  • 启动类上添加@EnableFeignClients注解

从Edgware版本开始,可以不加@EnableDiscoveryClient注解,只要配置好注册中心的相关配置即可自动开启服务注册功能。

@SpringBootApplication
public class ProviderServer {

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

}
  • 启动项目
  • 打开nacos管理界面,可以看到我们的提供者已经成功注册到nacos服务中心了
    SpringCloud微服务实战:Nacos服务注册与配置中心(非常详细附git源码)_第5张图片

4. 服务消费者

  • bootstrap.yml
server:
  port: 9999
# NaCos
spring:
  application:
    name: consumer
# NaCos
  cloud:
    service-registry:
      auto-registration:
        # 是否注册到注册中心
        enabled: true
    nacos:
      discovery:
        server-addr: 192.168.41.128:8848
        namespace: 1d5a097c-898e-403e-8935-fdbe2cf854f6
      config:
        server-addr: ${spring.cloud.nacos.discovery.server-addr}
        namespace: ${spring.cloud.nacos.discovery.namespace}
        file-extension: yaml
        prefix: ${spring.application.name}
  • 创建服务调用接口ProviderApi.java,用于调用提供者的api。
@FeignClient(value = "provider")
public interface ProviderApi {
    /**
     * @return ``
     */
    @GetMapping("/get")
    ResponseEntity<String> get();
}

@FeignClient(value = "provider")中value的值即为需要调用服务的名称,我们上一步创建的提供者名称为provider,所以这里value 的值设为 “provider”

  • 创建测试apiConsumerController.java
@RestController
@Slf4j
@RequiredArgsConstructor
public class ConsumerController {

    private final ProviderApi providerApi;

    @GetMapping("/test")
    public String get() {
        // 从提供者中获取数据
        ResponseEntity<String> stringResponseEntity = providerApi.get();
        log.info("从提供者中获取数据:{}", stringResponseEntity);
        return stringResponseEntity.getBody();
    }
}
  • 启动消费者
  • 浏览器输入http://localhost:9999/test
    SpringCloud微服务实战:Nacos服务注册与配置中心(非常详细附git源码)_第6张图片
  • 可以看到我们通过消费者访问了提供者的接口,完成了服务间的调用。

6. 源码分享

本项目已收录

  • Springboot-cli开发脚手架,集合各种常用框架使用案例,完善的文档,致力于让开发者快速搭建基础环境并让应用跑起来。
  • 项目源码github地址
  • 项目源码国内gitee地址

你可能感兴趣的:(SpringCloud实战,spring,cloud,nacos,openfeign,注册中心,服务发现)