springcloud(二) 注册中心Eureka

目录

    • 介绍
            • --1 项目A调用项目B
            • --2 项目A调用项目B 项目B调用项目C
    • `Eureka`
    • `案例实践`
        • `Eureka Server`
            • --1 pom中添加依赖
            • --2 在启动代码中添加`@EnableEurekaServer`注解
            • --3 配置文件
    • `集群`
    • `双节点注册中心`
          • --1 创建application-peer1.properties, 作为peer1服务中心的配置, 并将serviceUrl指向peer2
            • --2 创建application-peer2.properties,作为peer2服务中心的配置, 并将serivceUrl指向peer1
            • --3 host转换 `在hosts文件中加入如下配置`
            • --4 打包启动 依次执行下面命令
    • erueka集群的使用



介绍

服务中心也叫做注册中心,管理各种服务功能包括服务的注册、发现、熔断、负载、降级等
有了服务中心调用关系会发生什么变化,看一下下面几个图

–1 项目A调用项目B
  • 正常调用项目A请求项目B
    springcloud(二) 注册中心Eureka_第1张图片
  • 有了服务中心之后,任何一个服务都不能直接去调用,都需要通过服务中心来调用
    springcloud(二) 注册中心Eureka_第2张图片
–2 项目A调用项目B 项目B调用项目C

springcloud(二) 注册中心Eureka_第3张图片

这个时候调用的步骤就会分为两步:第一步,项目A首先从服务中心请求项目B服务器,然后项目B在从服务中心请求项目C服务

springcloud(二) 注册中心Eureka_第4张图片

Eureka

Eureka是一个基于REST的服务, 主要在AWS云中使用,定位服务来进行中间层服务器的负载均衡和故障转移

Spring Cloud 封装了Nerflix公司开发的Eureka模块来实现服务注册和发现,Eureka采用了C-S的设计架构,EurekaServer作为服务注册功能的服务器, 它是服务注册中心,而系统中的其他微服务,使用Eureka的客户端连接到EurekaServer 并维持心跳连接,这样系统的维护人员就可以通过EurekaServer 来监控系统中各个微服务是否正常运行 Spring Cloud的一些其他模块比如(zuul)就可以通过EurekaServer来发现系统中的其他微服务,并执行相关的逻辑.

Eureka由两个组件组成: Eureka服务器和Eureka客户端,Eureka服务器用作服务注册服务器,Eureka客户端是一个java客户端,用来简化与服务器的交互、作为轮询负载均衡器、并提供服务的故障切换支持, Netflix在其生产环境中使用的是另外的客户端,它提供基于流量、资源利用率以及出错状态的加权负载均衡
springcloud(二) 注册中心Eureka_第5张图片

  • –上图简要描述了Eureka的基本架构,由3个角色组成:
    • –Eureka Server
      提供服务注册和发现
    • –Service Provider
      服务提供方
      将自身服务注册到Eureka, 从而使服务消费方能够找到
    • –Service Consumer
      服务消费方
      从Eureka获取注册服务列表,从而能够消费服务

案例实践

Eureka Server

spring cloud已经帮我们实现了服务注册中心,我们主需要很简单的几个步骤就可以完成

–1 pom中添加依赖
<?xml version="1.0" encoding="UTF-8"?>
<project xmlns="http://maven.apache.org/POM/4.0.0" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
	xsi:schemaLocation="http://maven.apache.org/POM/4.0.0 http://maven.apache.org/xsd/maven-4.0.0.xsd">
	<modelVersion>4.0.0</modelVersion>
	<parent>
		<groupId>org.springframework.boot</groupId>
		<artifactId>spring-boot-starter-parent</artifactId>
		<version>2.1.3.RELEASE</version>
		<relativePath/> <!-- lookup parent from repository -->
	</parent>
	<groupId>org.ygq.cloud</groupId>
	<artifactId>fist-eurekaserver</artifactId>
	<version>0.0.1-SNAPSHOT</version>
	<name>fist-eurekaserver</name>
	<description>Demo project for Spring Boot</description>

	<properties>
		<java.version>1.8</java.version>
		<spring-cloud.version>Greenwich.RELEASE</spring-cloud.version>
	</properties>

	<dependencies>
		<dependency>
			<groupId>org.springframework.boot</groupId>
			<artifactId>spring-boot-starter-web</artifactId>
		</dependency>
		<dependency>
			<groupId>org.springframework.cloud</groupId>
			<artifactId>spring-cloud-starter-netflix-eureka-server</artifactId>
		</dependency>

		<dependency>
			<groupId>org.springframework.boot</groupId>
			<artifactId>spring-boot-starter-test</artifactId>
			<scope>test</scope>
		</dependency>
	</dependencies>

	<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>

	<build>
		<plugins>
			<plugin>
				<groupId>org.springframework.boot</groupId>
				<artifactId>spring-boot-maven-plugin</artifactId>
			</plugin>
		</plugins>
	</build>

	<repositories>
		<repository>
			<id>spring-milestones</id>
			<name>Spring Milestones</name>
			<url>https://repo.spring.io/milestone</url>
		</repository>
	</repositories>

</project>
–2 在启动代码中添加@EnableEurekaServer注解
@SpringBootApplication
@EnableEurekaServer
public class SpringCloudEurekaApplication {

	public static void main(String[] args) {
		SpringApplication.run(SpringCloudEurekaApplication.class, args);
	}
}
–3 配置文件

在默认设置下, 该服务注册中心也会将自己作为客户端来尝试注册它自己,所以我们需要警用它的客户端注册行为,在application.properties添加以下配置:

spring.application.name=spring-cloud-eureka

server.port=8000
eureka.client.register-with-eureka=false
eureka.client.fetch-registry=false

eureka.client.serviceUrl.defaultZone=http://localhost:${server.port}/eureka/
  • eureka.client.register-with-eureka :表示是否将自己注册到Eureka Server,默认为true。
  • eureka.client.fetch-registry :表示是否从Eureka Server获取注册信息,默认为true。
  • eureka.client.serviceUrl.defaultZone :设置与Eureka Server交互的地址,查询服务和注册服务都需要依赖这个地址。默认是http://localhost:8761/eureka ;多个地址可使用 , 分隔。

启动工程后, 访问http://localhost:8000/ 可以看到下面的页面, 其中还没发现任何服务

springcloud(二) 注册中心Eureka_第6张图片



集群

注册中心这么关键的服务, 如果是单点的话,遇到故障就是毁灭性的, 在一个分布式系统中,服务注册中心是最重要的基础部分, 理应随时处于可以提供服务的状态, 为了维持其可用性, 使用集群是很好的解决方案,Eureka通过互相注册的方式来实现高可用的部署, 所以我们只需要将Eureka Server配置其他可用的serviceUrl就能实现高可用部署

双节点注册中心

首先我们尝试一下双节点的注册中心的搭建

–1 创建application-peer1.properties, 作为peer1服务中心的配置, 并将serviceUrl指向peer2
spring.application.name=spring-cloud-eureka
server.port=8000
eureka.instance.hostname=peer1

eureka.client.serviceUrl.defaultZone=http://peer2:8001/eureka/
–2 创建application-peer2.properties,作为peer2服务中心的配置, 并将serivceUrl指向peer1
spring.application.name=spring-cloud-eureka
server.port=8001
eureka.instance.hostname=peer2

eureka.client.serviceUrl.defaultZone=http://peer1:8000/eureka/
–3 host转换 在hosts文件中加入如下配置
127.0.0.1 peer1  
127.0.0.1 peer2  
–4 打包启动 依次执行下面命令
#打包
mvn clean package
//分别以peer1和peeer2 配置信息启动eureka
java -jar spring-cloud-eureka-0.0.1-SNAPSHOT.jar --spring.profiles.active=peer1
java -jar spring-cloud-eureka-0.0.1-SNAPSHOT.jar --spring.profiles.active=peer2

依次启动完成之后, 浏览器输入:http://localhost:8000/效果图如下
springcloud(二) 注册中心Eureka_第7张图片

根据图可以看出peer1的注册中心DS Replicas已经有了peer2的相关配置信息,并且出现在available-replicas中,我们手动停止peer2来观察,发现peer2就会移动到unavailable-replicas一栏中,表示peer2不可用

到此双节点的配置已完成.

erueka集群的使用

在生产中我们可能需要三台或者大于三台的注册中心来保证服务的稳定性,配置的原理其实都一样,将注册中心分别指向其它的注册中心。这里只介绍三台集群的配置情况,其实和双节点的注册中心类似,每台注册中心分别又指向其它两个节点即可,使用application.yml来配置。

application.yml配置详情如下:

---
spring:
  application:
    name: spring-cloud-eureka
  profiles: peer1
server:
  port: 8000
eureka:
  instance:
    hostname: peer1
  client:
    serviceUrl:
      defaultZone: http://peer2:8001/eureka/,http://peer3:8002/eureka/
---
spring:
  application:
    name: spring-cloud-eureka
  profiles: peer2
server:
  port: 8001
eureka:
  instance:
    hostname: peer2
  client:
    serviceUrl:
      defaultZone: http://peer1:8000/eureka/,http://peer3:8002/eureka/
---
spring:
  application:
    name: spring-cloud-eureka
  profiles: peer3
server:
  port: 8002
eureka:
  instance:
    hostname: peer3
  client:
    serviceUrl:
      defaultZone: http://peer1:8000/eureka/,http://peer2:8001/eureka/

分别以peer1、peer2、peer3的配置参数启动eureka注册中心。

java -jar spring-cloud-eureka-0.0.1-SNAPSHOT.jar --spring.profiles.active=peer1
java -jar spring-cloud-eureka-0.0.1-SNAPSHOT.jar --spring.profiles.active=peer2
java -jar spring-cloud-eureka-0.0.1-SNAPSHOT.jar --spring.profiles.active=peer3

依次启动完成后,浏览器输入:http://localhost:8000/ 效果图如下:
springcloud(二) 注册中心Eureka_第8张图片
可以在peer1中看到了peer2、peer3的相关信息。至此eureka集群也已经完成了

你可能感兴趣的:(SpringCloud)