在上一篇博文中简单实现了eureka-server以及eureka-provider,后面会实现eureka-cosumer,现在针对eureka做进一步的详解。
微服务整体架构
文字再美也没有图片直观,下面通过一张图来说明微服务的整体架构以及调用过程,如下:
服务注册中心-1和服务注册中心-2互相组成了高可用集群;
服务提供者启动了两个实例,一个注册到服务注册中心-1上,另外一个注册到服务注册中心-2上;
两个服务消费者,也都分别指向了一个注册中心。
服务提供者
1、服务注册
服务提供者在启动的时候发送rest请求将自己注册到eureka-server上,包括自己的元数据,eureka-server会将相关数据存为两层map,第一层的key为服务名,第二层的key则为具体服务的实例名。
2、服务同步
两个服务提供者分别注册到了两个不同的服务注册中心上,并且这两个服务注册中心互相注册,因此当服务提供者发送注册请求到一个服务注册中心时,它会将该请求转发到集群中相连的其他注册中心,从而实现服务同步。
3、服务续约
当服务提供者注册到服务注册中心之后,服务提供者会维护一个心跳,需要定期的告诉注册中心,我是有效的,没有挂掉。否则不续约的话,注册中心就会将服务提供者干掉。
# 定义服务续约任务的调用间隔时间,默认30秒 eureka.instance.lease-renewal-interval-in-seconds=30 # 定义服务失效的时间,默认90秒 eureka.instance.lease-expiration-duration-in-seconds=90
服务消费者
在微服务架构中,业务都会被拆分成一个独立的服务,服务与服务的通讯是基于http restful的。Spring cloud有两种服务调用方式,一种是ribbon+restTemplate,另一种是feign。
1、ribbon
ribbon是一个负载均衡客户端,可以很好的控制http和tcp的一些行为。Feign默认集成了ribbon。
2、新建一个eureka-consumer工程
pom.xml文件:
<?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.4.RELEASE</version> <relativePath/> <!-- lookup parent from repository --> </parent> <groupId>com.ty</groupId> <artifactId>eureka-consumer</artifactId> <version>0.0.1-SNAPSHOT</version> <name>eureka-consumer</name> <description>Demo project for Spring Boot</description> <properties> <java.version>1.8</java.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.cloud</groupId> <artifactId>spring-cloud-starter-netflix-eureka-client</artifactId> <version>2.1.1.RELEASE</version> </dependency> <dependency> <groupId>org.springframework.boot</groupId> <artifactId>spring-boot-starter-web</artifactId> </dependency> <dependency> <groupId>org.springframework.cloud</groupId> <artifactId>spring-cloud-starter-netflix-ribbon</artifactId> <version>2.1.1.RELEASE</version> </dependency> </dependencies> <dependencyManagement> <dependencies> <dependency> <groupId>org.springframework.cloud</groupId> <artifactId>spring-cloud-dependencies</artifactId> <version>Finchley.RELEASE</version> <type>pom</type> </dependency> </dependencies> </dependencyManagement> <build> <plugins> <plugin> <groupId>org.springframework.boot</groupId> <artifactId>spring-boot-maven-plugin</artifactId> </plugin> </plugins> </build> </project>
运行主类:
package com.ty.eurekaconsumer; import org.springframework.boot.SpringApplication; import org.springframework.boot.autoconfigure.SpringBootApplication; import org.springframework.cloud.netflix.eureka.EnableEurekaClient;
//这里注意另外一个注解:@EnableDiscoveryClient,@EnableEurekaClient只能往eureka注册中心注册,而前者可以用于其他注册中心,例如consul @EnableEurekaClient @SpringBootApplication public class EurekaConsumerApplication { public static void main(String[] args) { SpringApplication.run(EurekaConsumerApplication.class, args); } }
application.properties
# 服务名称 spring.application.name=eureka-consumer # 端口号 server.port=3001 # 服务注册中心地址 eureka.client.serviceUrl.defaultZone=http://localhost:1001/eureka/
controller:
package com.ty.eurekaconsumer.controller; import com.ty.eurekaconsumer.service.RibbonService; import org.springframework.beans.factory.annotation.Autowired; import org.springframework.web.bind.annotation.GetMapping; import org.springframework.web.bind.annotation.RequestParam; import org.springframework.web.bind.annotation.RestController; @RestController public class RibbonController { @Autowired RibbonService ribbonService; @GetMapping("/ribbonService") public String hi(@RequestParam String name) { return ribbonService.hiService( name ); } }
service:
package com.ty.eurekaconsumer.service; import org.springframework.beans.factory.annotation.Autowired; import org.springframework.stereotype.Service; import org.springframework.web.bind.annotation.GetMapping; import org.springframework.web.client.RestTemplate; @Service public class RibbonService { @Autowired private RestTemplate restTemplate; public String hiService(String name) { return restTemplate.getForObject("http://eureka-provider/firstCall?name="+name, String.class); } }
运行效果:
浏览器中输入:http://localhost:3001/ribbonService?name=马云
本人已将eureka-server、eureka-provider、eureka-consumer代码上传到github中,地址如下:
eureka-server地址:https://github.com/ali-mayun/eureka-server
eureka-provider地址: https://github.com/ali-mayun/eureka-provider
eureka-consumer地址:https://github.com/ali-mayun/eureka-consumer
有需要的可以自行下载,另外方便的话,给个小星星哦!!!