初识Springcloud

微服务是一种架构方式,最终肯定需要技术架构去实施。 微服务的实现方式很多,但是最火的莫过于Spring Cloud 了。

为什么要选用Springcloud?

后台硬:作为Spring家族的一员,有整个Spring全家 桶靠山,背景十分强大。

技术强:Spring作为Java领域的前辈,可以说是功力 深厚。有强力的技术团队支撑,一般人还真比不了

群众基础好:可以说大多数程序员的成长都伴随着 Spring框架,试问:现在有几家公司开发不用 Spring?SpringCloud与Spring的各个框架无缝整合,对大家来说一切都是熟悉的配方,熟悉的味道。

使用方便:相信大家都体会到了SpringBoot给我们开 发带来的便利,而SpringCloud完全支持SpringBoot 的开发,用很少的配置就能完成微服务框架的搭建

Springcloud的简介

SpringCloud是Spring旗下的项目之一,官网地址: http://projects.spring.io/spring-cloud/

Spring最擅长的就是集成,把世界上最好的框架拿过 来,集成到自己的项目中。

SpringCloud也是一样,它将现在非常流行的一些技 术整合到一起,实现了诸如:配置管理,服务发现, 智能路由,负载均衡,熔断器,控制总线,集群状态 等等功能

springcloud相关组件

Eureka:服务治理组件,包含服务注册中心,服务 注册与发现机制的实现。(服务治理,服务注册/发现) ,类似的产品还有Consul、Nacos

Zuul:网关组件,提供智能路由,访问过滤功能 ,类似产品还有Spring Cloud GateWay

Ribbon:客户端负载均衡的服务调用组件(客户端负载)

Feign:服务调用,给予Ribbon和Hystrix的声明式服务调用组件 (声明式服务调用)

Hystrix:容错管理组件,实现断路器模式,帮助服 务依赖中出现的延迟和故障提供强大的容错能力。(熔 断、断路器,容错)

springcloud微服务场景模拟

1.创建eureka注册中心工程

1.引入相关依赖

<properties>
<java.version>1.8</java.version>
<spring-cloud.version>2020.0.2</spring-cloud.version>
</properties>

<dependencies>
<dependency>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-starter</artifactId>
</dependency>
<dependency>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-starter-test</artifactId>
<scope>test</scope>
</dependency>
<!-- 引入eureka起步依赖 -->
<dependency>
<groupId>org.springframework.cloud</groupId>
<artifactId>spring-cloud-starter-netflix-eureka-server</artifactId>
</dependency>
</dependencies>
<!-- 引入springcloud环境 -->
<dependencyManagement>
<dependencies>
<dependency>
<groupId>org.springframework.cloud</groupId>
<artifactId>spring-cloud-dependencies</artifactId>
<version>${spring-cloud.version}</version>
<type>pom</type>
<scope>import</scope>
</dependency>
</dependencies>
</dependencyManagement>

注意:spring-cloud的2020.0.2版本,需要springboot 的2.4.4版本支持。

2.配置yml文件

#服务器端口
server:
    port: 8081
# 设置应用的名称
spring:
    application:
        name: eureka-server
# eureka注册中心配置
eureka:
    client:
        service-url:
# eureka注册中心通信地址,单个eureka使用时,表示将来客户端使用该地址和eureka注册中心进行通信,写成#自己的地址
# 多个eureka集群时,写成其他eureka的地址,表示当前eureka作为客户端,连接其他eureka注册中心。
            defaultZone: http://127.0.0.1:8081/eureka
        register-with-eureka: false # 是否将自己的路径注册到eureka注册中心上。单个使用配置为#false,表示自己作为注册中心,自己不注册自己;集群时配置为true,表示作为客户端要注册到其他eureka上

        fetch-registry: false # 是否需要从当前eureka中抓取路径。单个使用配置为false,不需要从自己#这抓取路径,集群时配置为true,需要从自己这抓取其他eureka的路径

3.引导类中配置@EnableEurekaServer

 4.启动测试

 2.创建服务提供方工程

1.引入相关依赖

<properties>
<java.version>1.8</java.version>
<spring-cloud.version>2020.0.2</spring-cloud.version>
</properties>
<dependencies>
<dependency>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-starter</artifactId>
</dependency>
<dependency>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-starter-test</artifactId>
<scope>test</scope>
</dependency>
<dependency>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-starter-web</artifactId>
</dependency>
<!-- 引入eureka-client起步依赖,此依赖需要spring-boot-starter-web依赖辅助 -->
<dependency>
<groupId>org.springframework.cloud</groupId>
<artifactId>spring-cloud-starter-netflix-eureka-client</artifactId>
</dependency>
</dependencies>
<!-- 引入springcloud环境 -->
<dependencyManagement>
<dependencies>
<dependency>
<groupId>org.springframework.cloud</groupId>
<artifactId>spring-cloud-dependencies</artifactId>
<version>${spring-cloud.version}</version>
<type>pom</type>
<scope>import</scope>
</dependency>
</dependencies>
</dependencyManagement>

2.编写配置文件

server:
    port: 8082
spring:
    application:
        name: eureka-provider
eureka:
    client:
        service-url:
            defaultZone: http://127.0.0.1:8081/eureka

3.编写controller

@RestController
public class TestController {
    @RequestMapping("/test")
    public String test(){
        return "Hello Eureka Consumer";
    }
}

4.给启动类添加注解

 5.启动之后,会在eureka注册中心中看到注册的信息

 3.创建服务消费方工程

1.引入相关依赖

<properties>
<java.version>1.8</java.version>
<spring-cloud.version>2020.0.2</spring-cloud.version>
</properties>
<dependencies>
<dependency>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-starter</artifactId>
</dependency>
<dependency>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-starter-test</artifactId>
<scope>test</scope>
</dependency>
<dependency>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-starter-web</artifactId>
</dependency>
<!-- 引入eureka-client起步依赖,此依赖需要spring-boot-starter-web依赖辅助 -->
<dependency>
<groupId>org.springframework.cloud</groupId>
<artifactId>spring-cloud-starter-netflix-eureka-client</artifactId>
</dependency>
</dependencies>
<!-- 引入springcloud环境 -->
<dependencyManagement>
<dependencies>
<dependency>
<groupId>org.springframework.cloud</groupId>
<artifactId>spring-cloud-dependencies</artifactId>
<version>${spring-cloud.version}</version>
<type>pom</type>
<scope>import</scope>
</dependency>
</dependencies>
</dependencyManagement>

2.编写配置文件

server:
    port: 8083
spring:
    application:
        name: eureka-consumer
eureka:
    client:
        service-url:
            defaultZone: http://127.0.0.1:8081/eureka

3.编写Config配置类

@Configuration
public class MyConfiguration {
    @Bean
    public RestTemplate restTemplate(){
        return new RestTemplate();
}
}

 4.编写Controller测试类

@RestController
public class TestController{
    @Autowired
    private RestTemplate restTemplate;
    @Autowired
    private DiscoveryClient discoveryClient;
    
    @RequestMapping("/test")
    public String test(){
     //参数:服务提供方在eureka中的名称
    List<ServiceInstance> instances =discoveryClient.getInstances("EUREKA-PROVIDER");     
    ServiceInstance serviceInstance =instances.get(0);
    String host =serviceInstance.getHost(); //获取服务提供方主机地址
    int port =serviceInstance.getPort();//获取服务提供方端口
    String url ="http://"+host+":"+port+"/test"; //拼接服务提供方访问路径
    String s =restTemplate.getForObject(url,String.class);//访问服务提供方接口。
    return s;
    }
}

5.给启动类添加注解

 6.进行测试

个人笔记,若有错误请指出谢谢

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值