认识Eureka (F版)
Spring Cloud为开发者提供了在分布式系统中的一些常用的组件(例如配置管理,服务发现,断路器,智能路由,微代理,控制总线,一次性令牌,全局锁定,决策竞选,分布式会话集群状态)。使用Spring Cloud开发人员可以快速地完成实现这些模式的服务和应用程序。它们在任何分布式环境中都能很好地工作
Eureka
学过 Dubbo 的一定不会陌生 ZooKeeper ,那么学 Spring Cloud 的就不能陌生 Eureka。它是 Netflix 开源的一款基于REST(Representational State Transfer)风格的服务发现框架,目前已被 Spring Cloud 集成在其子项目 spring-cloud-netflix 中,用于 Spring Cloud 的服务注册发现功能。
- 纯正的
Servlet应用,jar/war 包部署 - 使用
Jersey框架实现自身的RESTful HTTP接口 - peer 之间的同步与服务的注册全部通过 HTTP 协议实现
- 利用
JDK Timer实现 心跳检测、定时清理过期服务、节点同步等功能(动态添加删除节点、弹性) - 使用
Google的guava包管理内存缓存 - 目前 2.0 已经停止开源,但在
Finchley版中Spring Cloud所采用的是 1.9.x 版本(持续维护),所以完全不用担心,同时Spring Cloud还提供了Eureka、Consul、ZooKeeper、Etcd等多款服务注册发现功能的框架,完全不用担心会在一棵树上吊死
Eureka 的 Server 与 Client
Eureka Server:提供服务注册与发现,Client节点启动后,会向Eureka Server发送注册事件,Eureka Server注册表中将会存储所有可用服务节点的信息,服务节点的信息可以在界面中直观的看到。基于Jersey框架实现自身的RESTful HTTP接口,只要满足规范任何语言程序都能向其进行注册Eureka Client:任何形式的客户端,只要满足Eureka Server订制的注册标准。
你好 Eureka Server
搭建一个 Eureka Server 是最为容易的,只需要一个依赖即可完成。在 Finchley 版本中 artifactId 与早期的有所差异,所以大家在使用 Spring Cloud 一定要注意自己所使用的版本,如果询问它人相关问题,也应该告知对方你所采用的版本
依赖
1 |
<!-- 此处我只给出了 Eureka Server 需要用到的包依赖, |
配置文件
在 src/main/resources 目录下创建一个 bootstrap.yml 的文件,文中我已经将部分需要注意的配置项罗列出来,并附写好相关说明,更多配置可以参考 EurekaInstanceConfigBean 、 EurekaClientConfigBean 、 EurekaServerConfigBean 。绝大多数情况下对于 Eureka Server 只需了解每个配置的作用及其意义即可,因为错误的配置反而会破坏原有的保护特性
1 |
server: |
主函数
与往常 Spring Boot 启动类类似,不同的是多了一个 @EnableEurekaServer 注解,用来标识当前工程是Eureka Server,到此我们 Server 就算是搭建完成了。
1 |
package com.battcn; import org.springframework.boot.SpringApplication; |
访问 http://localhost:7071/ 能看到如下内容就代表项目搭建成功,图中红色的表示我们关闭了 Eureka 保护模式,在网络波动的情况下 Eureka Server 可能无法及时的保护客户端实例
Eureka Server UI
你好 Eureka Client
搭建一个 Eureka Client 也是相当容易的,只需要两个小小的依赖即可完成。
依赖
1 |
<!-- 此处我只给出了 Eureka Server 需要用到的包依赖, |
配置文件
下面罗列一部分需要注意的配置项,需要注意的都已经写好相关说明,更多配置可以参考 EurekaInstanceConfigBean 、 EurekaClientConfigBean 、 InetUtilsProperties 以下配置适用于大部分情况
1 |
server: |
扩展知识
如果你觉得 Eureka Server UI 中默认显示的 instance-id 让你看着不爽,你可以试着在根目录下创建一个 application.properties 填写如下内容,因为Spring Cloud 和 Spring Boot 启动装载的配置有优先级之分,bootstrap 文件优先于 application 文件之前装载,所以一些配置只在 application 中生效
1 |
# 默认值:XB-201704242009:eureka-client:7072 |
主函数
与往常 Spring Boot 启动类类似,不同的是多了一个 @EnableDiscoveryClient 注解,用来标识当前工程是Discovery Client。因为 Spring Cloud 提供了非常多的服务注册发现的组件,如 euerka、zookeeper、consul、etcd、所以为统一标识客户端身份,所以它用的是 @EnableDiscoveryClient 注解
1 |
package com.battcn; import org.springframework.boot.SpringApplication; |
Eureka Server UI
认识Eureka (F版)的更多相关文章
- 基于Ubuntu12.04-server版的openstack F版搭建步骤
本文为双节点搭建,分为计算(IP1)和控制节点(IP2) 说明: 计算节点组件: 1.mysql 2.keystone 3.Nova 4.glance 5.rabbitmq 控制节点组件: 1.cin ...
- 趣味编程:CPS风格代码(C#,F#版)
CPS风格代码(C#版) using System; namespace fp { class CPS { static int add(int x, int y) => x + y; stat ...
- Feign拦截器应用 (F版)
Spring Cloud 为开发者提供了在分布式系统中的一些常用的组件(例如配置管理,服务发现,断路器,智能路由,微代理,控制总线,一次性令牌,全局锁定,决策竞选,分布式会话集群状态).使用Sprin ...
- 注解式HTTP请求Feign (F版)
Spring Cloud 为开发者提供了在分布式系统中的一些常用的组件(例如配置管理,服务发现,断路器,智能路由,微代理,控制总线,一次性令牌,全局锁定,决策竞选,分布式会话集群状态).使用Sprin ...
- Ribbon软负载 (F版)
Spring Cloud 为开发者提供了在分布式系统中的一些常用的组件(例如配置管理,服务发现,断路器,智能路由,微代理,控制总线,一次性令牌,全局锁定,决策竞选,分布式会话集群状态).使用Sprin ...
- Spring cloud Eureka错误锦集(二)
最近学习spring cloud,在测试Eureka作为服务注册中心的时候碰到了问题,错误提示如下: "D:\Program\Java\JDK1.8\bin\java" -XX:T ...
- 白话SpringCloud | 第二章:服务注册与发现(Eureka)-上
前言 从本章节开始,正式进入SpringCloud的基础教程.从第一章<什么是SpringCloud>中我们可以知道,一个微服务框架覆盖的东西是很多的,而如何去管理这些服务或者说API接口 ...
- SpringCloud学习笔记-Eureka基础
Spring Cloud Eureka是Spring Cloud Netflix微服务套件中的一部分,它基于Netflix Eureka做了二次封装,主要负责完成微服务架构中的微服务治理功能. 服务端 ...
- OpenStack G版以后的Availability Zone与Aggregate Hosts
关于Availability Zone与Aggregate Hosts的概念解析,可以参考这篇文章:http://blog.chinaunix.net/uid-20940095-id-3875022. ...
随机推荐
- Java实现 LeetCode 442 数组中重复的数据
442. 数组中重复的数据 给定一个整数数组 a,其中1 ≤ a[i] ≤ n (n为数组长度), 其中有些元素出现两次而其他元素出现一次. 找到所有出现两次的元素. 你可以不用到任何额外空间并在O( ...
- Java实现 LeetCode 232 用栈实现队列
232. 用栈实现队列 使用栈实现队列的下列操作: push(x) – 将一个元素放入队列的尾部. pop() – 从队列首部移除元素. peek() – 返回队列首部的元素. empty() – 返 ...
- Android中如何使用对话框(单选对话框和多选对话框)
在主XML中声明两个Button,声明Id package com.example.myapplication; import androidx.appcompat.app.AlertDialog; ...
- java实现文件管理
** 文件管理** 显示"DaSai"目录下以"Ex"开头的文件和目录,写了如下代码,请完善之: import java.io.*; class JavaFil ...
- 聊一聊高并发高可用那些事 - Kafka篇
目录 为什么需要消息队列 1.异步 :一个下单流程,你需要扣积分,扣优惠卷,发短信等,有些耗时又不需要立即处理的事,可以丢到队列里异步处理. 2.削峰 :按平常的流量,服务器刚好可以正常负载.偶尔推出 ...
- 创建使用mysql表
1.展示所有数据库 show databases;2.选中数据库 use database_name(;)3.创建数据库 create database database_name;4.使用2选中数据 ...
- 在CentOS下利用Docker一键安装seafile
https://cloud.seafile.com/published/seafile-manual-cn/docker/pro-edition/%E7%94%A8Docker%E9%83%A8%E7 ...
- 2019-02-02 Python学习——生成器杨辉三角,迭代器与可迭代对象的区别
练习 杨辉三角定义如下: 1 / \ 1 1 / \ / \ 1 2 1 / \ / \ / \ 1 3 3 1 / \ / \ / \ / \ 1 4 6 4 1 / \ / \ / \ / \ / ...
- Excel常用公式大全
公式是单个或多个函数的结合运用. AND “与”运算,返回逻辑值,仅当有参数的结果均为逻辑“真(TRUE)”时返回逻辑“真(TRUE)”,反之返回逻辑“假(FALSE)”. 条件判断 AVERAGE ...
- Python绘图之Turtle库详解(1)
Turtle库是Python语言中一个很流行的绘制图像的函数库,想象一个小乌龟,在一个横轴为x.纵轴为y的坐标系原点,(0,0)位置开始,它根据一组函数指令的控制,在这个平面坐标系中移动,从而在它爬行 ...