微服務構架須要使用場景:spring
1.能夠將一個系統拆分紅幾個系統。
數據庫
2.每一個子系統能夠部署多個應用,多個應用之間可使用負載均衡。安全
3.須要一個服務註冊中心,全部的服務都在一個註冊中心註冊,負載均衡也是經過在註冊中心註冊的服務來使用必定的策略來實現。服務器
4.服務之間也須要相互進行訪問。app
5.須要一個斷路器,及時處理服務調用時的超時和錯誤,爲了防止一個服務問題,而致使總體系統的癱瘓。負載均衡
6.還須要一個監控功能,爲了監控每個服務調用花費的時間。框架
子項目包括:
微服務
1.Spring Cloud Config:配置管理開發工具包,可讓你把配置放到遠程服務器,目前支持本地存儲、Git以及Subversion。工具
2. Spring Cloud Bus:事件、消息總線,用於在集羣(例如,配置變化事件)中傳播狀態變化,可與Spring Cloud Config聯合實現熱部署。開發工具
3.Spring Cloud Netflix:針對多種Netflix組件提供的開發工具包,其中包括Eureka、Hystrix、Zuul、Archaius等。
4. Netflix Eureka:雲端負載均衡,一個基於 REST 的服務,用於定位服務,以實現雲端的負載均衡和中間層服務器的故障轉移。
5.Netflix Hystrix:容錯管理工具,旨在經過控制服務和第三方庫的節點,從而對延遲和故障提供更強大的容錯能力。
6.Netflix Zuul:邊緣服務工具,是提供動態路由,監控,彈性,安全等的邊緣服務。
7. Netflix Archaius:配置管理API,包含一系列配置管理API,提供動態類型化屬性、線程安全配置操做、輪詢框架、回調機制等功能。
8.Spring Cloud for Cloud Foundry:經過Oauth2協議綁定服務到CloudFoundry,CloudFoundry是VMware推出的開源PaaS雲平臺。
9.Spring Cloud Sleuth:日誌收集工具包,封裝了Dapper,Zipkin和HTrace操做。
10.Spring Cloud Data Flow:大數據操做工具,經過命令行方式操做數據流。
11.Spring Cloud Security:安全工具包,爲你的應用程序添加安全控制,主要是指OAuth2。
12.Spring Cloud Consul:封裝了Consul操做,consul是一個服務發現與配置工具,與Docker容器能夠無縫集成。
13. Spring Cloud Zookeeper:操做Zookeeper的工具包,用於使用zookeeper方式的服務註冊和發現。
14.Spring Cloud Stream:數據流操做開發包,封裝了與Redis,Rabbit、Kafka等發送接收消息。
15.Spring Cloud CLI:基於 Spring Boot CLI,可讓你以命令行方式快速創建雲組件。
restTemplate 這個是服務器之間的通信,做用和httpClient 相同。是spring封裝的一個工具,若是加上@LoadBalanced 註解,就會實現客戶端的負載均衡(經過ribbon方式)。
若是在包中加入數據庫鏈接,可是項目不須要數據庫的連接,須要在啓動註解中加入,@SpringBootApplication(exclude=
{DataSourceAutoConfiguration.class,HibernateJpaAutoConfiguration.class})