十三、SpringCloud

一、基本概念

Spring Cloud是一系列框架的有序集合。它利用Spring Boot的开发便利性巧妙地简化了分布式系统基础设施的开发,如服务发现注册、配置中心、消息总线、负载均衡、断路器、数据监控等,都可以用Spring Boot的开发风格做到一键启动和部署。
Spring Cloud并没有重复制造轮子,它只是将各家公司开发的比较成熟、经得起实际考验的服务框架组合起来,通过Spring Boot风格进行再封装屏蔽掉了复杂的配置和实现原理,最终给开发者留出了一套简单易懂、易部署和易维护的分布式系统开发工具包。
常见的组件包括:

  • Eureka:服务治理组件,可以实现服务的自动注册、自动发现等功能。
  • Ribbon:客户端负载均衡组件,可以实现请求在多个服务实例之间的负载均衡。
  • Feign:声明式 REST 客户端,可将 REST 接口转换为 Java 接口,更容易地发起 REST 调用。
  • Hystrix:断路器组件,用于实现服务的容错和快速失败等机制。
  • Zuul:网关组件,可以实现请求的路由、负载均衡、请求过滤等功能。
  • Config:配置中心组件,可以集中管理微服务的配置信息,并且支持动态刷新。

二、基本用例

注意:SpringBoot和SpringCloud一定要版本对应,不然会报错
1、创建一个普通的maven项目,在pom文件中加上

 <packaging>pom</packaging>

2、创建一个springboot模块取名cloud-eureka,pom文件加上

 <dependencies>
   <dependency>
            <groupId>org.springframework.cloud</groupId>
            <artifactId>spring-cloud-starter-netflix-eureka-server</artifactId>
        </dependency>
 </dependencies>
  <dependencyManagement>
        <dependencies>
            <dependency>
                <groupId>org.springframework.cloud</groupId>
                <artifactId>spring-cloud-dependencies</artifactId>
                <!--   注意cloud的版本-->
                <version>2021.0.6</version>
                <type>pom</type>
                <scope>import</scope>
            </dependency>
        </dependencies>
    </dependencyManagement>

3、application.yaml

server:
  port: 8761

eureka:
  client:
    register-with-eureka: false
    fetch-registry: false

4、在启动类加上注解@EnableEurekaServer

@SpringBootApplication
@EnableEurekaServer //标明是一个server
public class CloudEurekaApplication {

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

}

5、测试 http://localhost:8761/
在这里插入图片描述

6、再创建一个springboot模块,取名cloud-provider1
pom文件在cloud-eureka基础上增加

 <dependency>
            <groupId>org.springframework.boot</groupId>
            <artifactId>spring-boot-starter-web</artifactId>
        </dependency>

启动类同cloud-eureka
yaml文件为

# 应用端口
server:
  port: 7901
spring:
  application:
    # 应用名称
    name: provider-user

eureka:
  client:
    serviceUrl:
      defaultZone: http://jorian:123456@localhost:8761/eureka

创建UserController

@RestController
@RequestMapping("/user")
public class UserController {
        @RequestMapping("/sayHello")
        public String sayhello(){
            return "I`m provider 1 ,Hello consumer!";
        }
}

7、同时启动两个启动类,发现provider已经被注册了
在这里插入图片描述
8、再创建一个springboot模块,取名cloud-sonsumer
pom文件同cloud-eureka
启动类同cloud-eureka
yaml文件为

server:
  port: 8001
spring:
  application:
    name: cloud-consumer
  main:
    #解决spring boot2.6因循环引用导致启动时报错
    allow-circular-references: true

# eureka 配置
eureka:
  client:
    serviceUrl:
      defaultZone: http://jorian:123456@localhost:8761/eureka

创建HelloController

@RestController
public class HelloController {

    @Bean
    @LoadBalanced
    public RestTemplate getResttemplate() {
        return new RestTemplate();
    }

    @Autowired
    private RestTemplate resttemplate;

    @RequestMapping("/hello")
    public String hello() {
        //指出服务地址   http://{服务提供者应用名名称}/{具体的controller}
        String url = "http://provider-user/user/sayHello";

        //返回值类型和我们的业务返回值一致
        return resttemplate.getForObject(url, String.class);


    }
}

9、同时启动三个启动类,发现两个都被注册了
在这里插入图片描述
输入http://localhost:8001/hello
在这里插入图片描述
消费者模块成功调用生产者模块

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值