SpringCloud中Eureka注册中心

SpringCloud简介

简介

Spring Cloud是Spring旗下的项目之一,官网地址:http://projects.spring.io/spring-cloud/
Spring最擅长的就是集成,把世界上最好的框架拿过来,集成到自己的项目中。
Spring Cloud也是一样,它将现在非常流行的一些技术整合到一起,实现了诸如:配置管理,服务发现,智能路由,负载均衡,熔断器,控制总线,集群状态等等功能。其主要涉及的组件包括:

  1. Eureka:注册中心
  2. Zuul:服务网关
  3. Ribbon:负载均衡
  4. Feign:服务调用
  5. Hystrix:熔断器

    在这里插入图片描述

版本

Spring Cloud的版本命名比较特殊,因为它不是一个组件,而是许多组件的集合,它的命名是以A到Z为首字母的一 些单词组成(其实是伦敦地铁站的名字):
在这里插入图片描述Spring Clound 和Spring Boot版本对应关系
在这里插入图片描述

微服务场景模拟

创建父工程

先创建一个父工程,后续的工程都以这个工程为父,使用 Maven的聚合和继承。统一管理子工程的版本和配置。
在这里插入图片描述pom.xml文件:

<parent> 
	<groupId>org.springframework.boot</groupId> 
	<artifactId>spring-boot-starter-parent</artifactId> 
	<version>2.1.5.RELEASE</version> 
	<relativePath/> 
</parent> 
<properties> 
	<java.version>1.8</java.version> 
	<spring-cloud.version>Greenwich.SR1</spring-cloud.version> 
	<mapper.starter.version>2.1.5</mapper.starter.version> 
	<mysql.version>5.1.46</mysql.version> 
</properties> 
<dependencyManagement> 
	<dependencies>
	<!-- springCloud --> 
		<dependency> 
			<groupId>org.springframework.cloud</groupId> 
			<artifactId>spring-cloud-dependencies</artifactId> 
			<version>${spring-cloud.version}</version> 
			<type>pom</type> 
			<scope>import</scope> 
		</dependency> 
		<!-- 通用Mapper启动器 --> 
		<dependency> 
			<groupId>tk.mybatis</groupId> 
			<artifactId>mapper-spring-boot-starter</artifactId> 
			<version>${mapper.starter.version}</version> 
		</dependency> 
			<!-- mysql驱动 --> 
		<dependency> 
			<groupId>mysql</groupId> 
			<artifactId>mysql-connector-java</artifactId> 
			<version>${mysql.version}</version> 
		</dependency> 
	</dependencies> 
</dependencyManagement> 
	<dependencies> 
		<dependency> 
			<groupId>org.projectlombok</groupId> 
			<artifactId>lombok</artifactId> 
		</dependency> 
	</dependencies> 
	<build> 
		<plugins> 
			<plugin> 
				<groupId>org.springframework.boot</groupId> 
				<artifactId>spring-boot-maven-plugin</artifactId> 
			</plugin> 
		</plugins> 
	</build> 

服务提供者

创建Module

选中lxs-springclound,创建子工程: pom.xml文件
在这里插入图片描述

编写配置文件

创建 user-service\src\main\resources\application.yml 属性文件,这里我们采用了yaml语法,而不是 properties:

在这里插入图片描述

服务调用者

pom:
在这里插入图片描述

代码

启动器:
在这里插入图片描述Spring提供了一个RestTemplate模板工具类,对基于HTTP的客户端进行了封装,并且实现了对象与json的序列化 和反序列化,非常方便。RestTemplate并没有限定HTTP的客户端类型,而是进行了抽象,目前常用的3种都有支 持:

  1. HTTPClient
  2. OkHTTP
  3. JDK原生的URLConnection(默认的)

实体类:

@Data 
public class User { 
	private Long id; 
	// 用户名 
	private String userName; 
	// 密码 
	private String password; 
	// 姓名 
	private String name; 
	// 年龄 
	private Integer age; 
	// 性别,1男性,2女性 
	private Integer sex; 
	// 出生日期 
	private Date birthday; 
	// 创建时间 
	private Date created; 
	// 更新时间 
	private Date updated; 
	// 备注 
	private String note; 
}

controller:

@RestController
@RequestMapping("/consumer")
public class ConsumerController {
	@Autowired
	private RestTemplate restTemplate;
	@GetMapping("/{id}")
	public User queryById(@PathVariable Long id){
		String url = "HTTP://localhost:9091/user/" + id;
		return restTemplate.getForObject(url, User.class);
	}
}

启动测试,我们没有配置端口,那么默认就是8080,我们访问:http://localhost:8080/consume/7

问题

刚才的测试案例中:
user-service:对外提供了查询用户的接口
consumer-demo:通过RestTemplate访问 http://locahost:9091/user/{id} 接口,查询用户数据存在着问题:

  1. 在consumer中,我们把url地址硬编码到了代码中,不方便后期维护
  2. consumer需要记忆user-service的地址,如果出现变更,可能得不到通知,地址将失效
  3. consumer不清楚user-service的状态,服务宕机也不知道
  4. user-service只有1台服务,不具备高可用性
  5. 即便user-service形成集群,consumer还需自己实现负载均衡

上面说的问题,概括一下就是分布式服务必然要面临的问题:
   服务管理:
      如何自动注册和发现
      如何实现状态监管
      如何实现动态路由
   服务如何实现负载均衡
   服务如何解决容灾问题
   服务如何实现统一配置

Eureka注册中心

Eureka简介

问题分析
   在刚才的案例中,user-service对外提供服务,需要对外暴露自己的地址。而consumer(调用者)需要记录服务 提供者的地址。将来地址出现变更,还需要及时更新。这在服务较少的时候并不觉得有什么,但是在现在日益复杂 的互联网环境,一个项目肯定会拆分出十几,甚至数十个微服务。此时如果还人为管理地址,不仅开发困难,将来 测试、发布上线都会非常麻烦,这与DevOps的思想是背道而驰的。
网约车
   这就好比是网约车出现以前,人们出门叫车只能叫出租车。一些私家车想做出租却没有资格,被称为黑车。而很多 人想要约车,但是无奈出租车太少,不方便。私家车很多却不敢拦,而且满大街的车,谁知道哪个才是愿意载人 的。一个想要,一个愿意给,就是缺少引子,缺乏管理啊。
    此时滴滴这样的网约车平台出现了,所有想载客的私家车全部到滴滴注册,记录你的车型(服务类型),身份信息 (联系方式)。这样提供服务的私家车,在滴滴那里都能找到,一目了然。
   此时要叫车的人,只需要打开APP,输入你的目的地,选择车型(服务类型),滴滴自动安排一个符合需求的车到 你面前,为你服务,完美!
Eureka做什么?
    Eureka就好比是滴滴,负责管理、记录服务提供者的信息。服务调用者无需自己寻找服务,而是把自己的需求告诉 Eureka,然后Eureka会把符合你需求的服务告诉你。
   同时,服务提供方与Eureka之间通过 “心跳” 机制进行监控,当某个服务提供方出现问题,Eureka自然会把它从服 务列表中剔除。
   这就实现了服务的自动注册、发现、状态监控。

原理图

在这里插入图片描述

  1. Eureka:就是服务注册中心(可以是一个集群),对外暴露自己的地址
  2. 提供者:启动后向Eureka注册自己信息(地址,提供什么服务)
  3. 消费者:向Eureka订阅服务,Eureka会将对应服务的所有提供者地址列表发送给消费者,并且定期更新
  4. 心跳(续约):提供者定期通过HTTP方式向Eureka刷新自己的状态

Eureka架构中的三个核心角色:
   服务注册中心
      Eureka的服务端应用,提供服务注册和发现功能,就是刚刚我们建立的eureka-server
   服务提供者
       提供服务的应用,可以是Spring Boot应用,也可以是其它任意技术实现,只要对外提供的是REST风格服务即 可。本例中就是我们实现的user-service
   服务消费者
      消费应用从注册中心获取服务列表,从而得知每个服务方的信息,知道去哪里调用服务方。本例中就是我们 实现的consumer-demo

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值