使用springCloud构建微服务实战(下)

本文涉及的产品
MSE Nacos/ZooKeeper 企业版试用,1600元额度,限量50份
服务治理 MSE Sentinel/OpenSergo,Agent数量 不受限
注册配置 MSE Nacos/ZooKeeper,182元/月
简介: Eureka是开源的服务发现组件,本身是一个基于REST的服务。包含两个组件:Eureka Server和Eureka Client。 (1)Eureka Server提供服务发现的能力,各个微服务启动时,会向Eureka Server注册自己的信息,它会存储这些信息。 (2)Eureka Client是一个java客户端,用于简化与Eureka Server的交互。

三、编写服务消费者

1、引入依赖

(1)除了服务提供者的依赖以外,我们再多引入一个依赖,这个依赖实现声明REST调用。我们会在该消费者中声明一个Feign接口,该接口会调用其他服务提供者的内容。在controller中调用该接口。

<dependency>
            <groupId>org.springframework.cloud</groupId>
            <artifactId>spring-cloud-starter-openfeign</artifactId>
</dependency>

2、启动类上添加@EnableFeignClient注解。

//spring boot 引导类注解
@SpringBootApplication
//注册的注解
@EnableDiscoveryClient
//调用的注解
@EnableFeignClients

3、在配置文件中添加以下配置,跟服务提供者一致:

#端口号
server.port=9011
#用于指定注册到Eureka Server上的应用名称
spring.application.name=myprovider
#设置Eureka Server交互的地址,查询和注册服务都需要依赖这个地址,与注册中心地址一致
eureka.client.service-url.defaultZone=http://localhost:8080/eureka/
#Feign已经为我们集成了Hystrix,经过查证,原来feign集成hystrix需要配置开启
feign.hystrix.enabled=true

4、创建一个Feign接口SchedualServiceHi,并添加@FeignClient注解

(1)注解中的name值是我们调用的其他应用名。该应用名中必须有该类中地址的映射,否则会调用出错。

(2)fallback的值是调用出错时会去调用的方法。

@FeignClient(name= "myprovider",fallback = TestFeignImpl.class)
public interface SchedualServiceHi {
    @RequestMapping("/index")
    String aa();
    @RequestMapping("/bb")
    public boolean mmm(@RequestParam("name") String name, @RequestParam("pwd") String pwd);
}

5、调用出错的类如下,消费者在调用提供者的方法出错时会返回调用这个类对应的方法。

@Component
public class TestFeignImpl implements SchedualServiceHi {
    //降级处理方式
    @Override
    public String aa() {
        return "provider 容断了";
    }
    @Override
    public boolean mmm(String name, String pwd) {
        return false;
    }
}

6、编写该消费者的controller代码,让其调用Feign接口。代码如下:

@RestController
public class Testcontroller {
  @Autowired
  SchedualServiceHi schedualServiceHi;
    @RequestMapping("/mindex2")
    public String mm(){
        return schedualServiceHi.aa();
    }
    @RequestMapping("/mindex3")
    public String mmm(@RequestParam("name") String name, @RequestParam("pwd") String pwd){
        if(schedualServiceHi.mmm(name,pwd)){
          return "成功";
        }else{
          return "失败";
        }
    }
}

6、启动该项目,访问注册中心,又注册成功了该消费者。

7、分别请求消费者中的映射地址。

(1)地址内如果需要调用Feign接口中的方法,会根据下面指定的服务提供者找到对应的映射地址,返回相应的数据,如果没找到会找下面的fallback,返回错误提示。

@FeignClient(name= "myprovider",fallback = TestFeignImpl.class)

四、总结

1、到此,我们使用几个核心组件,写出了一个简单的Spring Cloud微服务,该服务包括:

(1)注册中心

(2)服务提供者

(3)服务消费者

(4)Feign实现RESTful调用,使得不同服务之间进行通信,共同完成一次客户端的请求。

(5)容错处理类TestFeignImpl


目录
相关文章
|
1月前
|
监控 安全 Java
Spring Cloud 微服务治理技术详解与实践指南
本文档全面介绍 Spring Cloud 微服务治理框架的核心组件、架构设计和实践应用。作为 Spring 生态系统中构建分布式系统的标准工具箱,Spring Cloud 提供了一套完整的微服务解决方案,涵盖服务发现、配置管理、负载均衡、熔断器等关键功能。本文将深入探讨其核心组件的工作原理、集成方式以及在实际项目中的最佳实践,帮助开发者构建高可用、可扩展的分布式系统。
113 1
|
1月前
|
jenkins Java 持续交付
使用 Jenkins 和 Spring Cloud 自动化微服务部署
随着单体应用逐渐被微服务架构取代,企业对快速发布、可扩展性和高可用性的需求日益增长。Jenkins 作为领先的持续集成与部署工具,结合 Spring Cloud 提供的云原生解决方案,能够有效简化微服务的开发、测试与部署流程。本文介绍了如何通过 Jenkins 实现微服务的自动化构建与部署,并结合 Spring Cloud 的配置管理、服务发现等功能,打造高效、稳定的微服务交付流程。
199 0
使用 Jenkins 和 Spring Cloud 自动化微服务部署
|
1月前
|
Kubernetes Java 微服务
Spring Cloud 微服务架构技术解析与实践指南
本文档全面介绍 Spring Cloud 微服务架构的核心组件、设计理念和实现方案。作为构建分布式系统的综合工具箱,Spring Cloud 为微服务架构提供了服务发现、配置管理、负载均衡、熔断器等关键功能的标准化实现。本文将深入探讨其核心组件的工作原理、集成方式以及在实际项目中的最佳实践,帮助开发者构建高可用、可扩展的分布式系统。
288 0
|
11月前
|
设计模式 Java API
微服务架构演变与架构设计深度解析
【11月更文挑战第14天】在当今的IT行业中,微服务架构已经成为构建大型、复杂系统的重要范式。本文将从微服务架构的背景、业务场景、功能点、底层原理、实战、设计模式等多个方面进行深度解析,并结合京东电商的案例,探讨微服务架构在实际应用中的实施与效果。
578 6
|
11月前
|
设计模式 Java API
微服务架构演变与架构设计深度解析
【11月更文挑战第14天】在当今的IT行业中,微服务架构已经成为构建大型、复杂系统的重要范式。本文将从微服务架构的背景、业务场景、功能点、底层原理、实战、设计模式等多个方面进行深度解析,并结合京东电商的案例,探讨微服务架构在实际应用中的实施与效果。
265 1
|
10月前
|
Java 开发者 微服务
从单体到微服务:如何借助 Spring Cloud 实现架构转型
**Spring Cloud** 是一套基于 Spring 框架的**微服务架构解决方案**,它提供了一系列的工具和组件,帮助开发者快速构建分布式系统,尤其是微服务架构。
827 70
从单体到微服务:如何借助 Spring Cloud 实现架构转型
|
安全 应用服务中间件 API
微服务分布式系统架构之zookeeper与dubbo-2
微服务分布式系统架构之zookeeper与dubbo-2
|
负载均衡 Java 应用服务中间件
微服务分布式系统架构之zookeeper与dubbor-1
微服务分布式系统架构之zookeeper与dubbor-1
|
10月前
|
运维 监控 持续交付
微服务架构解析:跨越传统架构的技术革命
微服务架构(Microservices Architecture)是一种软件架构风格,它将一个大型的单体应用拆分为多个小而独立的服务,每个服务都可以独立开发、部署和扩展。
2711 36
微服务架构解析:跨越传统架构的技术革命

热门文章

最新文章