Spring Cloud学习总结之 Eureka

什么是Eureka?

Eureka是由netflix出台的服务治理组件,是在分布式系统中管理各个分布式节点之间的通信,注册的一个组件。譬如当我们打开手机登录微信的时候,我们的手机会给分布式系统发消息通知客户端微信已经开启了,实际上完成的是服务注册过程,同时我们需要获取好友列表,实际上完成的是分布式结点之间的发现过程。这两个过程的实施,都需要Eureka这样的服务治理组件的帮助。
Eureka由服务器和客户端组件组成。Eureka服务器端会维护一张注册表,服务器组件将所有微服务注册在这张服务清单中,包含主机与端口号,版本号以及通信协议。微服务将使用Eureka客户端进行注册与服务发现。客户端在应用初始化阶段注册服务,随后通过发送一定频率的报文(心跳)来维持与服务端的连接,如果心跳长时间连接不上,Eureka会默认服务器故障,并踢出管理范围。但是如果是Eureka故障或者网络故障而导致大面积的服务连接不上,这种方法会起到反作用,所以Netflix设置如果Eureka丢失大量微服务连接会进入到保护模式,在保护模式下丢失的微服务结点不会被踢出Eureka的管理范围中。
在这里插入图片描述

Eureka的优势是什么,为什么我们使用他?

  1. 集成在Spring Cloud 中, 可以轻松导入Maven项目中。
  2. 相比起zookeeper他的容错率更高,一台服务器的故障不会影响整个分布式系统的模式,eureka在一台服务器宕机的情况下,不会再进行选举,更符合微服务使用的实际情况。

Eureka的基础架构

Eureka架构是由三个基础组件构成:

  1. 服务注册中心: 服务注册中心部署在Eureka 的服务端中,它是由一张清单列表构成,提供服务注册和发现的功能。服务注册已在前文中提及,对于服务发现,他通过这张表的 “联系方式”中这个服务所依赖的其他服务,然后对这些服务进行调取。
  2. 服务提供者,也就是客户端,他负责通过yml或者properties文件的形式标注自己为可提供服务的对象,他会在服务注册中心中注册从而使得他的服务被其他结点可见。服务注册中心同时也可以是服务提供者,实现服务高可用。
  3. 服务消费者: 他通过服务注册中心发现服务,然后执行服务完成自己的任务。在Spring Cloud中服务消费者的任务由Ribbon或者Feign来完成,Ribbon是一个负载均衡器,他通过轮询算法处理提供者的服务。

Eureka服务搭建

1.首先在pom.xml中增加插件

<dependency>
            <groupId>org.springframework.cloud</groupId>
            <artifactId>spring-cloud-starter-eureka-server</artifactId>
</dependency>
<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>
  1. 在主函数上使用@EnableEurekaServer启动Eureka服务
@EnableEurekaServer
@SpringBootApplication
public class SpringCloudServiceRegistrationEurekaServerApplication {
 	
 	@LoadBalanced
 	@Autowired
    RestTemplate restTemplate;
    public static void main(String[] args) {
        SpringApplication.run(Application.class, args);
    }
}
  1. 添加客户端
server.port = 8060
spring.application.name = String-service
eureka.client.serviceUrl.defaultZone = http://localhost:8080/eureka/
@RestController
public class HelloController{
	
	@RequestMapping(Value = "/hello", method = RequestMethod.Get)
	public String show(){
		return "Hello"; 
	}
}

4.配置消费者

@RestController
public class consumerController{
	
	@RequestMapping(Value = "/consumer", method = RequestMethod.Get)
	@ResponseBody
    public String consumer() {
        return restTemplate.getForEntity("http://String-service/hello", String.class);
        
    }
}
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值