认识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 371 两整数之和
371. 两整数之和 不使用运算符 + 和 - ,计算两整数 a .b 之和. 示例 1: 输入: a = 1, b = 2 输出: 3 示例 2: 输入: ...
- Java实现 LeetCode 61 旋转链表
61. 旋转链表 给定一个链表,旋转链表,将链表每个节点向右移动 k 个位置,其中 k 是非负数. 示例 1: 输入: 1->2->3->4->5->NULL, k = ...
- 第六届蓝桥杯JavaB组国(决)赛真题
解题代码部分来自网友,如果有不对的地方,欢迎各位大佬评论 题目1.分机号 X老板脾气古怪,他们公司的电话分机号都是3位数,老板规定,所有号码必须是降序排列,且不能有重复的数位.比如: 751,520, ...
- Python之Flask框架二
今天接着上一篇继续写一篇关于flask的随笔. 本文大纲: 1.获取请求参数 2.一个函数处理多个请求方式 3.重定向 4.错误响应 5.全局错误处理 6.返回json格式数据 7.自定义返回内容状态 ...
- Windows下虚拟机Linux(CentOS8)扩容设置 - 磁盘扩容中的坑和解决方法
摘要:[原创]转载请注明作者Johnthegreat和本文链接 由于虚拟机空间不足,为了避免重装虚拟机,做了一次无损扩容. 过程中的报错如下: [root@localhost ~]# pvcrea ...
- Android事件传递机制总结
Android中控件的分类 Activity dispatchTouchEvent(MotionEvent e) onTouchEvent(MotionEvent e) ViewGroup(View) ...
- ModelAndView的部分回顾
ModelAndView的部分回顾 //@RestController @Controller //@SessionAttributes("user") //把modelandvi ...
- PCB制图--VCC、VDD、VEE、VSS、VDDA、VSSA
VDDA为所有的模拟电路部分供电,包括: ADC模块,复位电路,PVD(可编程电压监测器),PLL,上电复位(POR)和掉电复位(PDR)模块,控制VBAT切换的开关等.即使不 使用ADC功能,也需要 ...
- Debian安装NVIDIA显卡驱动
1. sudo apt-get install nvidia-detect nvidia-detect 输出信息: Detected NVIDIA GPUs: 01:00.0 VGA compatib ...
- vue2.0+Element UI 表格前端分页和后端分页
之前写过一篇博客,当时对element ui框架还不太了解,分页组件用 html + css 自己写的,比较麻烦,而且只提到了后端分页 (见 https://www.cnblogs.com/zdd20 ...