什麼是SpringBoot?
一、用來簡化spring初始搭建和開發過程使用特定的方式進行配置(properties或者yml文件)
二、建立獨立的spring引用程序main方法運行
三、嵌入Tomcat無需部署war包,直接打成jar包nohup java -jar – & 啓動就好
四、簡化了maven的配置
四、自動配置spring添加對應的starter自動化配置java
SpringBoot經常使用的starter:
一、spring-boot-starter-web(嵌入Tomcat和web開發須要的servlet和jsp支持)
二、spring-boot-starter-data-jpa(數據庫支持)
三、spring-boot-starter-data-Redis(Redis支持)
四、spring-boot-starter-data-solr(solr搜索應用框架支持)
五、mybatis-spring-boot-starter(第三方mybatis集成starter)web
SpringBoot自動配置原理:
一、@EnableAutoConfiguration這個註解會"猜"你將如何配置spring,前提是你已經添加了jar依賴項,若是spring-boot-starter-web已經添加Tomcat和SpringMVC,這個註釋就會自動假設您在開發一個web應用程序並添加相應的spring配置,會自動去maven中讀取每一個starter中的spring.factories文件,該文件裏配置了全部須要被建立spring容器中bean
二、在main方法中加上@SpringBootApplication和@EnableAutoConfigurationspring
SpringBoot starter工做原理:
一、SpringBoot在啓動時掃描項目依賴的jar包,尋找包含spring.factories文件的jar
二、根據spring.factories配置加載AutoConfigure
三、根據@Conditional註解的條件,進行自動配置並將bean注入到Spring Context數據庫
SpringBoot的優勢:
一、減小開發、測試時間和努力
二、使用JavaConfig有助於避免使用XML
三、避免大量的maven導入和各類版本衝突
四、提供意見發展方法
五、經過提供默認值快速開始開發
六、沒有單獨的web服務器須要,這就意味着再也不須要啓動Tomcat、Glassfish或其餘任何東西
七、須要更少的配置,由於沒有web.xml文件。只需添加用@Configuration註釋的類,而後添加用@Bean註釋的方法,Spring將自動加載對象並像之前同樣對其進行管理。甚至能夠將@Autowired添加到bean方法中,以使用Spring自動裝入須要的依賴關係中
Springcloud解決那些問題:
配置管理、(註冊中心eureka、zk)、服務發現、服務註冊、斷路器、路由策略、全局鎖、分佈式會話、客戶端調用、接口網關(zuul)、服務管理系統編程
SpringBoot與Springcloud:
1>、SpringBoot簡化了xml配置,快速整合框架
2>、Springcloud是一套微服務解決方案—RPC遠程調用
3>、關係Springcloud依賴與SpringBoot(web組件用的SpringMVC),爲何Springcloud會依賴與SpringBoot?由於Springcloud寫接口就是SpringMVC接口
4>、SpringBootproperties和yml中可使用${random}設置一些隨機值緩存
服務的調用:
rest、feign(均使用httpclient技術),負載均衡ribbon
服務調用的原理:
服務首先註冊到註冊中心eureka中(註冊一個名字經過名字調用)
負載均衡
ribbon,先去註冊中心取到對應的服務,而後交給我ribbon服務器
配置詳解:
1>、eureka.client.register-with-eureka:是否向註冊中心註冊本身,註冊爲true反之爲false
2>、eureka.client.fetch-registry: 是否須要去檢索服務,檢索爲true反之爲false
3>、eureka.client.serviceUrl.defaultZone : 指定服務註冊中心的地址
Eureka:
1>、eureka可分爲三個角色:服務發現者、服務註冊者、註冊發現中心,可是這三個角色並不和實際部署的模型是一對一的關係
2>、全部的網絡通訊都是基於http(s)協議的
3>、Eureka和AWS是緊密結合的,不管是配置仍是源碼,好比Region、zone…,Region能夠經過配置文件進行配置,若是不配置默認使用us-east-1。一樣Zone也能夠配置,若不配置默認使用defaultZone網絡
高可用配置:
Eureka server 的高可用實際上就是將本身做爲服務向其餘服務註冊中心註冊本身,這樣就能夠造成一組互相註冊的服務註冊中心,以實現服務清單的互相同步,達到高可用效果。
微服務:
之前全部的代碼都放在同一個工程中、部署在同一個服務器、同一項目的不一樣模塊不一樣功能互相搶佔資源,微服務就是將工程根據不一樣的業務規則拆分紅微服務,部署在不一樣的服務器上,服務之間相互調用,java中有的微服務有dubbo(只能用來作微服務)、springcloud( 提供了服務的發現、斷路器等)。
微服務的特色:
按業務劃分爲一個獨立運行的程序,即服務單元
服務之間經過HTTP協議相互通訊
自動化部署
能夠用不一樣的編程語言
能夠用不一樣的存儲技術
服務集中化管理
微服務是一個分佈式系統
微服務的優點:
一、將一個複雜的業務拆分爲若干小的業務,將複雜的業務簡單化,新人只須要了解他所接管的服務的代碼,減小了新人的學習成本。
二、因爲微服務是分佈式服務,服務於服務之間沒有任何耦合。微服務系統的微服務單元具備很強的橫向拓展能力。
三、服務於服務之間採用HTTP網絡通訊協議來通訊,單個服務內部高度耦合,服務與服務之間徹底獨立,無耦合。這使得微服務能夠採用任何的開發語言和技術來實現,提升開發效率、下降開發成本。
四、微服務是按照業務進行拆分的,並有堅實的服務邊界,若要重寫某一業務代碼,不需瞭解因此業務,重寫簡單。
五、微服務的每一個服務單元是獨立部署的,即獨立運行在某個進程中,微服務的修改和部署對其餘服務沒有影響。
六、微服務在CAP理論中採用的AP架構,具備高可用分區容錯特色。高可用主要體如今系統7x24不間斷服務,他要求系統有大量的服務器集羣,從而提升系統的負載能力。分區容錯也使得系統更加健壯。
微服務的不足:
一、微服務的複雜度:構建一個微服務比較複雜,服務與服務之間經過HTTP協議或其餘消息傳遞機制通訊,開發者要選出最佳的通訊機制,並解決網絡服務差時帶來的風險。
二、分佈式事物:將事物分紅多階段提交,若是一階段某一節點失敗仍會致使數據不正確。若是事物涉及的節點不少,某一節點的網絡出現異常會致使整個事務處於阻塞狀態,大大下降數據庫的性能。
三、服務劃分:將一個完整的系統拆分紅不少個服務,是一件很是困難的事,由於這涉及了具體的業務場景
四、服務部署:最佳部署容器Docker
微服務和SOA的關係:
微服務相對於和ESB聯繫在一塊兒的SOA輕便敏捷的多,微服務將複雜的業務組件化,也是一種面向服務思想的體現。對於微服務來講,它是SOA的一種體現,可是它比ESB實現的SOA更加輕便、敏捷和簡單。
springcloud如何實現服務註冊與發現?
服務發佈時指定對應的服務名(IP地址和端口號),將服務註冊到註冊中心(eureka和zookeeper),可是這一切是Springcloud自動實現的,只須要在SpringBoot的啓動類上加上@EnableDisscoveryClient註解,同一服務修改端口就能夠啓動多個實例調用方法:傳遞服務名稱經過註冊中心獲取全部的可用實例,經過負載均衡策略(Ribbon和Feign)調用對應的服務mybatis
Ribbon和Feign的區別:
Ribbon添加的maven依賴是spring-starter-ribbon,使用@RibbonClient(value=「服務名稱」)使用RestTemplate調用遠程服務對應的方法,
Feign添加的maven依賴是spring-starter-feign,服務提供方提供對外接口,調用方使用,在接口上使用FeignClient(「指定服務名」),
具體區別:
一、啓動類使用的註解不一樣,Ribbon使用的是@RibbonClient,Feign使用的是@EnableFeignClients
二、服務的指定位置不一樣,Ribbon是在@RibbonClient註解上聲明,Feign則是在定義抽象方法的接口中使用@FeignClient聲明
三、調用方式不一樣,Ribbon須要本身構建http請求,模擬http請求而後使用RestTemplate發送給其餘服務,步驟比較繁瑣。Feign則是在Ribbon的基礎上進行了一次改進,採用接口調用的方式,將須要調用的其餘服務的方法定義成抽象方法便可,不須要本身構建http請求,不過要注意的是抽象方法的註解、方法簽名要和提供方的徹底一致。架構
雪崩效應:
分佈式系統中的服務通訊依賴於網絡,網絡很差,必然會對分佈式系統帶來很大的影響。在分佈式系統中,服務之間相互依賴,若是一個服務之間出現了故障或者網絡延遲,在高併發的狀況下,會致使線程阻塞,在很短的時間內該服務的線程資源會消耗殆盡,最終使得該服務不可用。因爲服務的相互依賴,可能會致使整個系統的不可用,這就是「雪崩效應」。爲了防止此類事件的發生,分佈式系統必然要採起相應的措施,如熔斷機制(Springcloud採用的是Hystrix)
熔斷機制:
一、當一個服務出現故障時,請求失敗次數超過設定的閥值(默認50)以後,該服務就會開啓熔斷器,以後該服務就不進行任何業務邏輯操做,執行快速失敗,直接返回請求失敗的信息。其餘依賴於該服務的服務就不會由於得不到響應而形成線程阻塞,這是除了該服務和依賴於該服務的部分功能不可用外,其餘功能正常。
二、熔斷器還有一個自我修復機制,當一個服務熔斷後,通過一段時間(5s)半打開熔斷器。半打開的熔斷器會檢查一部分請求(只能有一個請求)是否正常,其餘請求執行快速失敗,檢查的請求若是響應成功,則可判斷該服務正常了,就可關閉該服務的熔斷器,反之則繼續打開熔斷器。這種自我熔斷機制和自我修復機制可使程序更加健壯、也能夠爲開發和運維減小不少沒必要要的工做。
三、熔斷組件每每會提供一系列的監控,如:服務可用與否、熔斷器是否被打開、目前的吞吐量、網絡延遲狀態的監控等,從而可讓開發人員和運維人員的瞭解服務的情況。
Eureka基礎架構:
1>、服務註冊中心:Eureka提供的服務端,提供服務註冊與發現的功能
1>>、失效剔除:對於那些非正常下線的服務實例(內存溢出、網絡故障致使的),服務註冊中心不能收到「服務下線」的請求,爲了將這些沒法提供服務的實例從服務列表中剔除,Eureka Server在啓動的時候會建立一個定時任務,默認每隔一段時間(默認60s)將當前清單中超時(默認90s)沒有續約的服務剔除出去。
2>>、自我保護:Eureka Server 在運行期間,會統計心跳失敗的比例在15分鐘以內是否低於85%,若是出現低於的狀況(生產環境因爲網絡不穩定會致使),Eureka Server會降當前的實例註冊信息保護起來,讓這些實例不過時,儘量保護這些註冊信息,可是在這保護期間內實例出現問題,那麼客戶端就很容易拿到實際上已經不存在的服務實例,會出現調用失敗的狀況,因此客戶端必須有容錯機制,好比可使用請求重試、斷路器等機制。
在本地進行開發時可使用 eureka.server.enable-self-preseervation=false參數來關閉保護機制,以確保註冊中心能夠將不可用的實例剔除。
2>、服務提供者:提供服務的應用,能夠是SpringBoot應用也能夠是其餘的技術平臺且遵循Eureka通訊機制的應用。他將本身提供的服務註冊到Eureka,以供其餘應用發現,(如:service層)
1>>、服務註冊:服務提供者在啓動的時候會經過發送Rest請求的方式將本身註冊到Eureka Server(服務註冊中心)中,同時帶上自身服務的一些元數據,Eureka Server 接收到這個Rest請求後,將元數據存儲在一個雙層結構Map中,第一層的key是服務名,第二層key是具體服務的實例名
2>>、服務同步:如有兩個或兩個以上的Eureka Server(服務註冊中心)時,他們之間是互相註冊的,當服務提供者發送註冊請求到一個服務註冊中心時,它會將該請求轉發到集羣中相連的其餘註冊中心,從而實現註冊中心間的服務同步,這樣服務提供者的服務信息能夠經過任意一臺服務中心獲取到
3>>、服務續約:在註冊完服務以後,服務提供者會維護一個心跳來持續告訴Eureka Server:「我還活着」,以防止Eureka Server的「剔除任務」將該服務實例從服務列表中排除出去。配置:eureka.instance.lease-renewal-in-seconds=30(續約任務的調用間隔時間,默認30秒,也就是每隔30秒向服務端發送一次心跳,證實本身依然存活),eureka.instance.lease-expiration-duration-in-seconds=90(服務失效時間,默認90秒,也就是告訴服務端,若是90秒以內沒有給你發送心跳就證實我「死」了,將我剔除)
3>、服務消費者:消費者應用從服務註冊中心獲取服務列表,從而使消費者能夠知道去何處調用其所須要的服務,如:Ribbon實現消費方式、Feign實現消費方式
1>>、獲取服務:當啓動服務消費者的時候,它會發送一個Rest請求給註冊中心,獲取上面註冊的服務清單,Eureka Server會維護一份只讀的服務清單來返回給客戶端,而且每三十秒更新一次
2>>、服務調用:在服務消費者獲取到服務清單後,經過服務名能夠得到具體提供服務的實例名和該實例的元信息,採用Ribbon實現負載均衡
3>>、服務下線:當服務實例進行正常的關閉操做時,它會觸發一個服務下線的Rest請求給Eureka Server,告訴服務註冊中心「我要下線了」。服務端接收到請求以後,將該服務狀態設置爲下線,並把下線時間傳播出去。
Eureka和zookeeper均可以提供服務註冊與發現的功能,二者的區別:
Zookeeper保證了CP(C:一致性,P:分區容錯性),Eureka保證了AP(A:高可用,P:分區容錯)
一、Zookeeper-----當向註冊中心查詢服務列表時,咱們能夠容忍註冊中心返回的是幾分鐘之前的信息,但不能容忍直接down掉不可用的。也就是說服務註冊功能對高可用性要求比較高,可是zk會出現這樣的一種狀況,當master節點由於網絡故障與其餘節點失去聯繫時,剩餘的節點會從新選leader。問題在於,選取leader的時間過長(30~120s),且選取期間zk集羣都不可用,這樣就會致使選取期間註冊服務癱瘓。在雲部署的環境下,因網絡問題使得zk集羣失去master節點是較大機率會發生的事,雖然服務最終恢復,可是漫長的選擇時間致使的註冊長期不可用是不能容忍的
二、Eureka則看明白這一點,所以再設計的優先保證了高可用性。Eureka各個節點都是平等的,幾個節點掛掉不會影響到正常節點的工做,剩餘的節點依然能夠提供註冊和查詢服務。而Eureka的客戶端再向某個Eureka註冊時若是發現鏈接失敗,則會自動切換至其餘節點,只要有一臺Eureka還在,就能保證註冊服務的可用(保證可用性),只不過查到的信息可能不是最新的(不保證一致性)。除此以外Eureka還有一種自我保護機制,若是在15分鐘內超過85%的節點都沒有正常心跳,那麼Eureka就認爲客戶端與註冊中心出現了網絡故障,此時就會出現如下幾種狀況:
1>、Eureka再也不從註冊列表移除由於長時間沒收到心跳而應該過時的服務
2>、Eureka仍然可以接受新服務的註冊和查詢請求,可是不會被同步到其它節點上(保證當前節點可用)
3>、當網絡穩定時,當前實例新的註冊信息會被同步到其它節點中
Eureka還有客戶端緩存功能(Eureka分爲客戶端程序和服務器端程序兩個部分,客戶端程序負責向外提供註冊與發現服務接口)。因此即使Eureka集羣中全部節點都失效,或者發生網絡分隔故障致使客戶端不能訪問任何一臺Eureka服務器;Eureka服務的消費者任然能夠經過Eureka客戶端緩存來獲取全部的服務註冊信息。甚至最極端的環境下,全部正常的Eureka節點都不對請求產生響應也沒有更好的服務器解決方案來解決這種問題時;得益於Eureka的客戶端緩存技術,消費者服務仍然能夠經過Eureka客戶端查詢與獲取註冊服務信息,這點很重要,所以Eureka能夠很好的應對網絡故障致使部分節點失去聯繫的狀況,而不像Zookeeper那樣使整個註冊服務癱瘓。
CAP理論:
一、Consistency:指數據的強一致性。若是寫入某個數據成功,以後讀取,讀到的都是新寫入的數據;若是寫入失敗,讀到的都不是寫入失敗的數據。
二、Availability:指服務的可用性
三、Partition-tolerance:指分區容錯
Ribbon和Nginx的區別:
Nginx性能好,但Ribbon能夠剔除不健康節點,Nginx剔除比較麻煩,Ribbon是客戶端負載均衡,Nginx是服務端負載均衡
服務註冊與發現:
服務註冊就是向服務註冊中心註冊一個服務實例,服務提供者將本身的服務信息(服務名、IP地址等)告知註冊中心。服務發現是服務消費另外一個服務時,註冊中心將服務的實例返回給服務消費者,一個服務既是服務提供者又是服務消費者。
服務註冊中心健康檢查機制,當一個服務實例註冊成功之後,會定時向註冊中心發送一個心跳證實本身可用,若中止發送心跳證實服務不可用將會別剔除。若過段時間繼續想註冊中心提供心跳,將會從新加入服務註冊中心列表中。
服務的負載均衡:
爲何要用:微服務是將業務代碼拆分爲不少小的服務單元,服務之間的相互調用經過HTTP協議來調用,爲了保證服務的高可用,服務單元每每都是集羣化部署的,那麼消費者該調用那個服務提供者的實例呢?
介紹:服務消費者集成負載均衡組件,該組件會向服務消費者獲取服務註冊列表信息,並隔一段時間從新刷新獲取列表。當服務消費者消費服務時,負載均衡組件獲取服務提供者全部實例的註冊信息,並經過必定的負載均衡策略(能夠本身配置)選擇一個服務提供者實例,向該實例進行服務消費,這樣就實現了負載均衡。