参考博客:https://www.cnblogs.com/ityouknow/p/6854805.htmlhtml
Eureka是Netflix开源的一款提供服务注册和发现的产品,它提供了完整的Service Registry和Service Discovery实现。也是springcloud体系中最重要最核心的组件之一。java
RPC远程调用框架的核心设计思想:在于注册中心,由于注册中心是管理每一个服务与服务之间的一种依赖关系(服务治理的概念)。spring
什么是服务治理?apache
服务中心:后端
服务中心又称注册中心,管理各类服务功能包括服务的注册、发现、熔断、负载、降级等,好比dubbo admin后台的各类功能。有了服务中心调用关系会有什么变化,画几个简图来帮忙理解:浏览器
一、项目A调用项目B缓存
正常调用项目A请求项目B:springboot
有了服务中心以后,任何一个服务都不能直接去掉用,都须要经过服务中心来调用:服务器
二、项目A调用项目B,项目B在调用项目C架构
这时候调用的步骤就会为两步:第一步,项目A首先从服务中心请求项目B服务器,而后项目B在从服务中心请求项目C服务。
上面的项目只是两三个相互之间的简单调用,可是若是项目超过20个30个呢,在15年末的时候我司分布式的项目就达到了二十几个,画一张图来描述几十个项目之间的相互调用关系全是线条,任何其中的一个项目改动,就会牵连好几个项目跟着重启,巨麻烦并且容易出错。经过服务中心来获取服务你不须要关注你调用的项目IP地址,由几台服务器组成,每次直接去服务中心获取可使用的服务去调用既可。
因为各类服务都注册到了服务中心,就有了去作不少高级功能条件。好比几台服务提供相同服务来作均衡负载;监控服务器调用成功率来作熔断,移除服务列表中的故障点;监控服务调用时间来对不一样的服务器设置不一样的权重等等。
Spring Cloud 封装了 Netflix 公司开发的 Eureka 模块来实现服务注册和发现。Eureka 采用了 C-S 的设计架构。Eureka Server 做为服务注册功能的服务器,它是服务注册中心。而系统中的其余微服务,使用 Eureka 的客户端链接到 Eureka Server,并维持心跳链接。这样系统的维护人员就能够经过 Eureka Server 来监控系统中各个微服务是否正常运行。Spring Cloud 的一些其余模块(好比Zuul)就能够经过 Eureka Server 来发现系统中的其余微服务,并执行相关的逻辑。
Eureka由两个组件组成:Eureka服务器和Eureka客户端。Eureka服务器用做服务注册服务器。Eureka客户端是一个java客户端,用来简化与服务器的交互、做为轮询负载均衡器,并提供服务的故障切换支持。Netflix在其生产环境中使用的是另外的客户端,它提供基于流量、资源利用率以及出错状态的加权负载均衡。
上图简要描述了Eureka的基本架构,由3个角色组成:
一、Eureka Server
二、Service Provider
三、Service Consumer
Spring Cloud官网的定义比较抽象,咱们能够从简单的东西开始。Spring Cloud是基于Spring Boot的, 最适合用于管理Spring Boot建立的各个微服务应用。要管理分布式环境下的各个Spring Boot微服务,必然存在服务的注册问题。因此咱们先从服务的注册谈起。既然是注册,必然有个管理注册中心的服务器,各个在Spring Cloud管理下的Spring Boot应用就是须要注册的client。
Spring Cloud使用erureka server, 而后全部须要访问配置文件的应用都做为一个erureka client注册上去。eureka是一个高可用的组件,它没有后端缓存,每个实例注册以后须要向注册中心发送心跳,在默认状况下erureka server也是一个eureka client ,必需要指定一个 server。
项目架构:
一、 建立Eureka Server
(1)、工程的maven依赖(建立工程时候选中Eureka后,自动关联)
<?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.2.RELEASE</version> <relativePath/> <!-- lookup parent from repository --> </parent> <groupId>com.dyh</groupId> <artifactId>springcloud_eurekaclient</artifactId> <version>0.0.1-SNAPSHOT</version> <name>springcloud_eurekaclient</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.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,这个注解须要在springboot工程的启动application类上加:
@EnableEurekaServer @SpringBootApplication public class SpringcloudOneApplication { public static void main(String[] args) { SpringApplication.run(SpringcloudOneApplication.class, args); } }
(3)、eureka是一个高可用的组件,它没有后端缓存,每个实例注册以后须要向注册中心发送心跳(所以能够在内存中完成),在默认状况下erureka server也是一个eureka client ,必需要指定一个 server。eureka server的配置文件application.yml
server: port: 8761 eureka: instance: hostname: localhost client: registerWithEureka: false fetchRegistry: false serviceUrl: defaultZone: http://${eureka.instance.hostname}:${server.port}/eureka/
配置文件简介:
register-with-eureka
:表示是否将本身注册到Eureka Server,默认为true。fetch-registry
:表示是否从Eureka Server获取注册信息,默认为true。注意:只有上面两个属性都设置为false,才能是Eureka service。
serviceUrl.defaultZone
:设置与Eureka Server交互的地址,查询服务和注册服务都须要依赖这个地址。默认是http://localhost:8761/eureka ;多个地址可以使用 , 分隔。 (4)、eureka server 是有界面的,启动工程,打开浏览器访问:http://localhost:8761,界面以下:因为尚未注册服务,因此没有发现服务。
二、建立Eureka Client(当client向server注册时,它会提供一些元数据,例如主机和端口,URL,主页等。Eureka server 从每一个client实例接收心跳消息。 若是心跳超时,则一般将该实例从注册server中删除。)
(1)、工程的maven依赖(建立工程后自动生成)
<?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.2.RELEASE</version> <relativePath/> <!-- lookup parent from repository --> </parent> <groupId>com.dyh</groupId> <artifactId>springcloud_eurekaclient</artifactId> <version>0.0.1-SNAPSHOT</version> <name>springcloud_eurekaclient</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.cloud</groupId> <artifactId>spring-cloud-starter-netflix-eureka-client</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)、经过注解@EnableEurekaClient 代表本身是一个eurekaclient。
@EnableEurekaClient @SpringBootApplication @RestController public class SpringcloudEurekaclientApplication { public static void main(String[] args) { SpringApplication.run(SpringcloudEurekaclientApplication.class, args); } @Value("${server.port}") String port; @RequestMapping("/hi") public String home(@RequestParam String name) { return "hi "+name+",i am from port:" +port; } }
(3)、仅仅@EnableEurekaClient是不够的,还须要在配置文件中注明本身的服务注册中心的地址,application.yml配置文件以下:
注意:须要指明spring.application.name,这个很重要,这在之后的服务与服务之间相互调用通常都是根据这个name 。
eureka: client: serviceUrl: defaultZone: http://localhost:8761/eureka/ server: port: 8762 spring: application: name: service-hi
启动工程,打开http://localhost:8761 ,即eureka server 的网址:
能够看到,发现了一个服务注册到了服务上了(首先这个服务必须是运行的)。
这时打开 http://localhost:8762/hi?name=forezp ,你会在浏览器上看到 :
注册中心这么关键的服务,若是是单点话,遇到故障就是毁灭性的。在一个分布式系统中,服务注册中心是最重要的基础部分,理应随时处于能够提供服务的状态。为了维持其可用性,使用集群是很好的解决方案。Eureka经过互相注册的方式来实现高可用的部署,因此咱们只须要将Eureke Server配置其余可用的serviceUrl就能实现高可用部署。
一、高可用配置是“你中有我,我中有你”,最重要是配置时候名字必须相同。
二、集群配置
在注册过程当中,保证只有一台注册中心服务,有对应服务信息数据,当高可用的服务挂掉,对应的服务信息数据,会转移同步到另外高可用的服务器上。
参考博客:https://www.jianshu.com/p/ee4785a212f6
一下是Server与Client端的配置(关闭自我保护机制,默认是开启的)