微服務框架

1:Spring Cloud

  • Spring Cloud Config :配置管理工具,支持git存儲配置內(nèi)容俗扇,可以使用它實現(xiàn)應用配置的外部華存儲举畸,并支持客戶的配置信息刷新、加密躯舔、解密配置內(nèi)容等驴剔。
  • Spring Cloud netflix: 核心組件,對多個Netflix OSS 開源套件進行整合粥庄。

    Eureka:服務治理組件仔拟,包含服務注冊中心,服務注冊于發(fā)現(xiàn)機制的實現(xiàn)飒赃。
    Hystrix:容錯管理組件利花,實現(xiàn)斷路器模式,幫助服務以來中出現(xiàn)的延遲和為故障提供強大的容錯能力载佳。
    Ribbon:客戶的負載均衡的服務調(diào)用組件炒事。
    Feign:基于Ribbon 和 Hystrix的生命是服務調(diào)用組件
    Zuul:網(wǎng)關組件,提供智能路由蔫慧,訪問過濾等功能挠乳。
    Archaius:外部化配置組件。

  • Spring Cloud Bus:事件姑躲、消息中線睡扬,用于傳播集群中的狀態(tài)變化或事件,以出發(fā)后續(xù)的處理黍析,比如用來動態(tài)刷新配置等卖怜。
  • Spring Cloud Cluster:針對ZoonKeeper、Redis阐枣、Hazelcast马靠、Consul的選舉算法和通用狀態(tài)模式的實現(xiàn)奄抽。
  • Spring Cloud Cloudfoundry: 與Pivotal Cloudfoundry的整合支持。
  • Spring Cloud Consul:服務發(fā)現(xiàn)與配置管理工具甩鳄。
  • Spring Cloud Stream:通過Redis逞度、Rabbit或者Kafka實現(xiàn)消費微服務,可以通過簡單的聲明式模型來發(fā)送和接收消息妙啃。
  • Spring Cloud Zookeeper:基于ZooKeeper的服務發(fā)現(xiàn)與配置管理組件档泽。
  • Spring Cloud Starters:Spring Cloud的基礎組件,它是基于Spring Boot 風格項目的基礎依賴模塊揖赴。

2:Spring Cloud的構(gòu)建是基于Spring Boot實現(xiàn)馆匿。

3:問題,Spring Boot 打包成jar來部署储笑,通過 java -jar的命令來直接啟動一個標準的Web應用甜熔,為什么可以這樣呢圆恤?

4:多環(huán)境配置

在SpringBoot中突倍,多環(huán)境配置的文件名需滿足application-{profile}.properties的格式,其中{profile}對應你的環(huán)境標識

  • application-dev.properties :開發(fā)環(huán)境盆昙,這里包含常用的配置羽历,比如數(shù)據(jù)庫配置信息等
  • application-test.properties :測試環(huán)境,......
  • application-prod.properties :生產(chǎn)環(huán)境淡喜,......

至于哪個配置文件會被加載秕磷,需要在application.properties文件中通過spring.profiles.active屬性來設置,其值對應配置文件中的{profile}的值炼团。如spring.profiles.active=test就會加載application-test.properties配置文件的內(nèi)容

上面的配置方式澎嚣,是基于開發(fā)人員來配置的,但是到后期如果運維人員要來修改這個properties文件就顯得復雜了瘟芝,運維人員需要獲取這個代碼里面的properties文件來修改易桃,顯然這是不合理的。所以锌俱,就出現(xiàn)了很多將配置內(nèi)容外部化的框架和工具晤郑,比如 Spring Cloud Config,百度的disconf等

4:監(jiān)控與管理

Spring Boot 提供了一個特殊的依賴, spring-boot-starter-actuator,引入該模塊能夠自動為Spring Boot構(gòu)建的應用提供一系列用于監(jiān)控的端點贸宏。

引入actuator之后造寝,模塊中已經(jīng)實現(xiàn)的原生端點,可以分為三大類

  • 應用配置類: 獲取應用程序中加載的應用配置吭练,環(huán)境變量诫龙,自動化配置報告等與Spring Boot 應用密切相關的配置類信息。

    http://localhost:8080/autoconfig
    http://localhost:8080/beans
    http://localhost:8080/configprops
    http://localhost:8080/env
    http://localhost:8080/mappings
    http://localhost:8080/info
    

上面這些信息需要用到的時候再去查詢鲫咽,可以說這些是生成的一個靜態(tài)報告赐稽,系統(tǒng)一旦啟動這些信息就基本決定了叫榕。接下來,我們討論另外一個度量標準

  • 度量指標類

度量指標提供的是一些動態(tài)信息姊舵,比如內(nèi)存使用情況晰绎,Http請求統(tǒng)計,外部資源指標等括丁,這些信息對于我們監(jiān)控微服務架構(gòu)監(jiān)控非常有意義荞下。

http://localhost:8080/metrics : 該端點用來返回當前應用的各類重要度量指標, 比如內(nèi)存信息史飞,  線程信息尖昏,垃圾回收信息等。
http://localhost:8080/health
  • 操作控制類: 提供了對應用的關閉等操作功能构资。

5:服務治理

  • 構(gòu)建服務注冊中心
  • 服務注冊于服務發(fā)現(xiàn)
  • Eureka的基礎架構(gòu)
  • Eureka的服務治理機制
  • Eureka的配置

服務治理 包括 服務注冊 和 服務發(fā)現(xiàn)

注冊中心
需要維護類似下面的一個服務清單抽诉。服務中心還需要以心跳的方式去監(jiān)測清單中的服務是否可用,若不可用需要從服務中心剔除吐绵,達到排出故障服務的效果迹淌。


image.png

服務發(fā)現(xiàn)
由于在服務治理框架下運作,服務間的調(diào)用不再通過指定具體的示例地址來調(diào)用己单,而是通過服務名發(fā)起請求調(diào)用實現(xiàn)唉窃。服務調(diào)用方向注冊中心請求,注冊中心返回實例給調(diào)用方纹笼。

Spring Cloud Eureka,使用Netflix Eureka來實現(xiàn)服務注冊于發(fā)現(xiàn)纹份。包含了服務端和客戶端。服務端和客戶端都用java來寫的廷痘。如果是其他語言蔓涧,需要自己實現(xiàn)響應語言的客戶端,比如我們項目中的golang笋额。

Eureka 服務端元暴,我們也稱為服務注冊中心。
Eureka客戶端鳞陨,主要處理服務的注冊于發(fā)現(xiàn)昨寞。客戶端通過注解和參數(shù)配置的方式厦滤,嵌入在客戶端應用程序的代碼中援岩,在應用程序運行時,Eureka客戶端向注冊中心注冊自身提供的服務并周期性的發(fā)送心跳來更新它的服務租約掏导。同時享怀,它也能從服務端查詢當前注冊的服務信息并把它們緩存到本地周期性的刷新服務狀態(tài)。
最后編輯于
?著作權歸作者所有,轉(zhuǎn)載或內(nèi)容合作請聯(lián)系作者
  • 序言:七十年代末趟咆,一起剝皮案震驚了整個濱河市添瓷,隨后出現(xiàn)的幾起案子梅屉,更是在濱河造成了極大的恐慌,老刑警劉巖鳞贷,帶你破解...
    沈念sama閱讀 218,525評論 6 507
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件坯汤,死亡現(xiàn)場離奇詭異,居然都是意外死亡搀愧,警方通過查閱死者的電腦和手機惰聂,發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 93,203評論 3 395
  • 文/潘曉璐 我一進店門,熙熙樓的掌柜王于貴愁眉苦臉地迎上來咱筛,“玉大人搓幌,你說我怎么就攤上這事⊙嘎幔” “怎么了溉愁?”我有些...
    開封第一講書人閱讀 164,862評論 0 354
  • 文/不壞的土叔 我叫張陵,是天一觀的道長饲趋。 經(jīng)常有香客問我拐揭,道長,這世上最難降的妖魔是什么篙贸? 我笑而不...
    開封第一講書人閱讀 58,728評論 1 294
  • 正文 為了忘掉前任投队,我火速辦了婚禮枫疆,結(jié)果婚禮上爵川,老公的妹妹穿的比我還像新娘。我一直安慰自己息楔,他們只是感情好寝贡,可當我...
    茶點故事閱讀 67,743評論 6 392
  • 文/花漫 我一把揭開白布。 她就那樣靜靜地躺著值依,像睡著了一般圃泡。 火紅的嫁衣襯著肌膚如雪。 梳的紋絲不亂的頭發(fā)上愿险,一...
    開封第一講書人閱讀 51,590評論 1 305
  • 那天颇蜡,我揣著相機與錄音,去河邊找鬼辆亏。 笑死风秤,一個胖子當著我的面吹牛,可吹牛的內(nèi)容都是我干的扮叨。 我是一名探鬼主播缤弦,決...
    沈念sama閱讀 40,330評論 3 418
  • 文/蒼蘭香墨 我猛地睜開眼,長吁一口氣:“原來是場噩夢啊……” “哼彻磁!你這毒婦竟也來了碍沐?” 一聲冷哼從身側(cè)響起狸捅,我...
    開封第一講書人閱讀 39,244評論 0 276
  • 序言:老撾萬榮一對情侶失蹤,失蹤者是張志新(化名)和其女友劉穎累提,沒想到半個月后尘喝,有當?shù)厝嗽跇淞掷锇l(fā)現(xiàn)了一具尸體,經(jīng)...
    沈念sama閱讀 45,693評論 1 314
  • 正文 獨居荒郊野嶺守林人離奇死亡斋陪,尸身上長有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點故事閱讀 37,885評論 3 336
  • 正文 我和宋清朗相戀三年瞧省,在試婚紗的時候發(fā)現(xiàn)自己被綠了。 大學時的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片鳍贾。...
    茶點故事閱讀 40,001評論 1 348
  • 序言:一個原本活蹦亂跳的男人離奇死亡鞍匾,死狀恐怖,靈堂內(nèi)的尸體忽然破棺而出骑科,到底是詐尸還是另有隱情橡淑,我是刑警寧澤,帶...
    沈念sama閱讀 35,723評論 5 346
  • 正文 年R本政府宣布咆爽,位于F島的核電站梁棠,受9級特大地震影響,放射性物質(zhì)發(fā)生泄漏斗埂。R本人自食惡果不足惜符糊,卻給世界環(huán)境...
    茶點故事閱讀 41,343評論 3 330
  • 文/蒙蒙 一扳炬、第九天 我趴在偏房一處隱蔽的房頂上張望馆类。 院中可真熱鬧,春花似錦十艾、人聲如沸漾稀。這莊子的主人今日做“春日...
    開封第一講書人閱讀 31,919評論 0 22
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽崭捍。三九已至尸折,卻和暖如春,著一層夾襖步出監(jiān)牢的瞬間殷蛇,已是汗流浹背实夹。 一陣腳步聲響...
    開封第一講書人閱讀 33,042評論 1 270
  • 我被黑心中介騙來泰國打工, 沒想到剛下飛機就差點兒被人妖公主榨干…… 1. 我叫王不留粒梦,地道東北人亮航。 一個月前我還...
    沈念sama閱讀 48,191評論 3 370
  • 正文 我出身青樓,卻偏偏與公主長得像谍倦,于是被迫代替她去往敵國和親塞赂。 傳聞我的和親對象是個殘疾皇子,可洞房花燭夜當晚...
    茶點故事閱讀 44,955評論 2 355

推薦閱讀更多精彩內(nèi)容