微服务是一种架构方式,最终肯定需要技术架构去实施。 微服务的实现方式很多,但是最火的莫过于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.进行测试
个人笔记,若有错误请指出谢谢