图个源码系列 · 开端 · eureka项目解构

            目录

1、eureka的项目分析

2、其实,我就是个web工程

eureka,是springCloud生态中的负责构建服务注册与发现的注册中心组件。本文,通过从eureka的项目结构出发,一点点去剖析eureka的源码。

1、eureka的项目分析

既然要看源码一定是先把代码拉到本地,GitHub地址【https://github.com/Netflix/eureka】,本文基于1.7.3版本去分析。基于Gradle一通build之后,我们可以看到项目结构。

先简单分析一下几个要看的项目目录:

eureka-client:eureka客户端相关代码逻辑和配置

eureka-server:eureka服务端,其实就是一些配置文件,重点去分析他的打包配置文件。

eureka-resources:eureka注册中心控制台页面

eureka-examples:eureka的客户端功能的测试例子,可以都跑跑看

eureka-core:eureka封装的一些核心功能,注册中心和服务客户端的交互很多都封装在里面

eureka-core-jersey2&eureka-client-jersey2:eureka是基于jersey2封装的一套用于客户端和注册中心服务端的请求交互的MVC层逻辑。

那我们来看看eureka-server的build.gradle文件,通过观察打包的过程来看看各个module之间的依赖关系。

eureka-server实现依赖了eureka-client模块,这个必须的,毕竟eureka-server本身也可以作为eureka-client去向另外一台eureka-server进行注册,组成集群模式的注册中心。

eureka-core模块也毋庸置疑需要依赖的。很多注册中心相关的核心功能都封装在其中。并且eureka-core也去依赖了eureka-client工程。

然后可以看到依赖了jersey2,一个类似于SpringMVC的MVC框架,对外提供restful请求。基于这个框架,eureka-server就可以将eureka-core中的注册中心功能暴露出去给客户端访问。由此,我们也可以明确eureka是基于http请求通信的。

然后就是把eureka-resources下的一些jsp,js,css文件都打包进去,最终就形成了一个war包。

02 、其实,我就是个web工程

在eureka-server的module中,我们可以看到一个很关键的配置文件,那就是web.xml。我们可以确定eureka-server打成一个war包之后,就和我们平时写的web工程一样。最终交由web容器例如tomcat来运行。所以eureka-server也没有那么神秘,我们慢慢来看eureka的各种配置和操作。

我们先从web.xml文件入手,来看看整个web应用启动的时候都做了什么?

首先映入眼帘的是listener配置,当web容器启动的时候回去加载listener配置的类,这里配置了一个EurekaBootStrap类,这个类可以说很关键,整个eureka的启动初始化都可能在这个类中完成,我们后面的分析也会从这个类展开。

紧接着就是几个filter,StatusFilter,状态过滤器;ServerRequestAuthFilter,请求认证相关的过滤器;RateLimitingFilter,限流过滤器;GzipEncodingEnFocingFilter,解压缩相关的过滤器。这几个过滤器都在core包下面,从下图也可以看出来各个过滤器作用的路径,并且限流过滤器默认是不开的。我们后面可以去一一分析一下他们具体的作用。


还有一个MVC相关的核心过滤器,jersey的核心过滤器,这个一定和其他的MVC框架的核心过滤器一样都会接管所有的请求并处理,如下图,还配置一些参数的初始化。

如下图我们也可以看到整个jersey过滤器拦截了全部的url,而且,我们在这里也可以看到默认的欢迎页面就是status.jsp,也就是我们在eureka控制台页面看到的哪些就是这个jsp提供的。


上面一套配置文件看下来,我们对整个eureka工程就有了大概的了解,后面的解读也能够顺着文中的思路去慢慢分析,一步步去展开eureka的架构设计和原理。谢谢大家阅读,文中有不正确的地方,欢迎留言,指正,批评。

最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 199,064评论 5 466
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 83,606评论 2 376
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 146,011评论 0 328
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 53,550评论 1 269
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 62,465评论 5 359
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 47,919评论 1 275
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 37,428评论 3 390
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 36,075评论 0 254
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 40,208评论 1 294
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 35,185评论 2 317
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 37,191评论 1 328
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 32,914评论 3 316
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 38,482评论 3 302
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 29,585评论 0 19
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 30,825评论 1 255
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 42,194评论 2 344
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 41,703评论 2 339