查漏補缺:2020年搞定SpringCloud面試(含答案和思惟導圖)

前言

Spring Cloud是一系列框架的有序集合。它利用Spring Boot的開發便利性巧妙地簡化了分佈式系統基礎設施的開發,如服務發現註冊、配置中心、消息總線、負載均衡、斷路器、數據監控等,均可以用Spring Boot的開發風格作到一鍵啓動和部署。Spring Cloud並無重複製造輪子,它只是將各家公司開發的比較成熟、經得起實際考驗的服務框架組合起來,經過Spring Boot風格進行再封裝屏蔽掉了複雜的配置和實現原理,最終給開發者留出了一套簡單易懂、易部署和易維護的分佈式系統開發工具包。

Spring Cloud有如下特色:

  • 約定優於配置;
  • 適用於各類環境。開發、部署PC Server或各類雲環境(例如阿里雲、AWS等)都可;
  • 隱藏了組件的複雜性,並提供聲明式、無xml的配置方式;
  • 開箱即用,快速啓動;
  • 輕量級的組件。Spring Cloud整合的組件大多比較輕量。例如Eureka、Zuul等,都是各自領域輕量級的實現;
  • 組件豐富,功能齊全。Spring Cloud 爲微服務架構提供了很是完整的支持。例如、配置管理、服務發現、斷路器、微服務網關等;
  • 選型中立、豐富。例如,Spring Cloud支持使用Eureka、Zookeeper或Consul實現服務發現;
  • 靈活。Spring Cloud的組成部分是解耦的,開發人員能夠按需靈活挑選技術選型。

關於Spring Cloud微服務架構的知識總結了個思惟導圖分享給你們

Spring Cloud面試題

一、什麼是 Spring Cloud?
二、使用 Spring Cloud 有什麼優點?
三、服務註冊和發現是什麼意思?Spring Cloud 如何實現?
四、Spring Cloud 和dubbo區別?
五、SpringBoot和SpringCloud的區別?
六、負載平衡的意義什麼?
七、什麼是 Hystrix?它如何實現容錯?
八、什麼是 Hystrix 斷路器?咱們須要它嗎?
九、什麼是 Netflix Feign?它的優勢是什麼?
十、什麼是 Spring Cloud Bus?咱們須要它嗎?
十一、Spring Cloud斷路器的做用
十二、什麼是SpringCloudConfig?
1三、Spring Cloud Gateway?

一、什麼是 Spring Cloud?

Spring cloud 流應用程序啓動器是基於 Spring Boot 的 Spring 集成應用程序,提供與外部系統的集成。Spring cloud Task,一個生命週期短暫的微服務框架,用於快速構建執行有限數據處理的應用程序。

二、使用 Spring Cloud 有什麼優點?

使用 Spring Boot 開發分佈式微服務時,咱們面臨如下問題
(1)與分佈式系統相關的複雜性-這種開銷包括網絡問題,延遲開銷,帶寬問題,安全問題。
(2)服務發現-服務發現工具管理羣集中的流程和服務如何查找和互相交談。它涉及一個服務目錄,在該目錄中註冊服務,而後可以查找並鏈接到該目錄中的服務。
(3)冗餘-分佈式系統中的冗餘問題。
(4)負載平衡 --負載平衡改善跨多個計算資源的工做負荷,諸如計算機,計算機集羣,網絡鏈路,中央處理單元,或磁盤驅動器的分佈。
(5)性能-問題 因爲各類運營開銷致使的性能問題。
(6)部署複雜性-Devops 技能的要求。

三、服務註冊和發現是什麼意思?Spring Cloud 如何實現?

當咱們開始一個項目時,咱們一般在屬性文件中進行全部的配置。隨着愈來愈多的服務開發和部署,添加和修改這些屬性變得更加複雜。有些服務可能會降低,而某些位置可能會發生變化。手動更改屬性可能會產生問題。 Eureka 服務註冊和發現能夠在這種狀況下提供幫助。因爲全部服務都在 Eureka 服務器上註冊並經過調用 Eureka 服務器完成查找,所以無需處理服務地點的任何更改和處理。

四、Spring Cloud 和dubbo區別?

(1)服務調用方式 dubbo是RPC springcloud Rest Api
(2)註冊中心,dubbo 是zookeeper springcloud是eureka,也能夠是zookeeper
(3)服務網關,dubbo自己沒有實現,只能經過其餘第三方技術整合,springcloud有Zuul路由網關,做爲路由服務器,進行消費者的請求分發,springcloud支持斷路器,與git完美集成配置文件支持版本控制,事物總線實現配置文件的更新與服務自動裝配等等一系列的微服務架構要素。

五、SpringBoot和SpringCloud的區別?

SpringBoot專一於快速方便的開發單個個體微服務。
SpringCloud是關注全局的微服務協調整理治理框架,它將SpringBoot開發的一個個單體微服務整合並管理起來,
爲各個微服務之間提供,配置管理、服務發現、斷路器、路由、微代理、事件總線、全局鎖、決策競選、分佈式會話等等集成服務
SpringBoot能夠離開SpringCloud獨立使用開發項目, 可是SpringCloud離不開SpringBoot ,屬於依賴的關係.
SpringBoot專一於快速、方便的開發單個微服務個體,SpringCloud關注全局的服務治理框架。

六、負載平衡的意義什麼?

在計算中,負載平衡能夠改善跨計算機,計算機集羣,網絡連接,中央處理單元或磁盤驅動器等多種計算資源的工做負載分佈。負載平衡旨在優化資源使用,最大化吞吐量,最小化響應時間並避免任何單一資源的過載。使用多個組件進行負載平衡而不是單個組件可能會經過冗餘來提升可靠性和可用性。負載平衡一般涉及專用軟件或硬件,例如多層交換機或域名系統服務器進程。

七、什麼是 Hystrix?它如何實現容錯?

Hystrix 是一個延遲和容錯庫,旨在隔離遠程系統,服務和第三方庫的訪問點,當出現故障是不可避免的故障時,中止級聯故障並在複雜的分佈式系統中實現彈性。
一般對於使用微服務架構開發的系統,涉及到許多微服務。這些微服務彼此協做。
思考如下微服務
假設若是上圖中的微服務 9 失敗了,那麼使用傳統方法咱們將傳播一個異常。但這仍然會致使整個系統崩潰。
隨着微服務數量的增長,這個問題變得更加複雜。微服務的數量能夠高達 1000.這是 hystrix 出現的地方 咱們將使用 Hystrix 在這種狀況下的 Fallback 方法功能。咱們有兩個服務 employee-consumer 使用由 employee-consumer 公開的服務。
簡化圖以下所示
如今假設因爲某種緣由,employee-producer 公開的服務會拋出異常。咱們在這種狀況下使用 Hystrix 定義了一個回退方法。這種後備方法應該具備與公開服務相同的返回類型。若是暴露服務中出現異常,則回退方法將返回一些值。

八、什麼是 Hystrix 斷路器?咱們須要它嗎?

因爲某些緣由,employee-consumer 公開服務會引起異常。在這種狀況下使用Hystrix 咱們定義了一個回退方法。若是在公開服務中發生異常,則回退方法返回一些默認值。
若是 firstPage method() 中的異常繼續發生,則 Hystrix 電路將中斷,而且員工使用者將一塊兒跳過 firtsPage 方法,並直接調用回退方法。 斷路器的目的是給第一頁方法或第一頁方法可能調用的其餘方法留出時間,並致使異常恢復。可能發生的狀況是,在負載較小的狀況下,致使異常的問題有更好的恢復機會 。

九、什麼是 Netflix Feign?它的優勢是什麼?

Feign 是受到 Retrofit,JAXRS-2.0 和 WebSocket 啓發的 java 客戶端聯編程序。
Feign 的第一個目標是將約束分母的複雜性統一到 http apis,而不考慮其穩定性。
在 employee-consumer 的例子中,咱們使用了 employee-producer 使用 REST模板公開的 REST 服務。
可是咱們必須編寫大量代碼才能執行如下步驟
(1)使用功能區進行負載平衡。
(2)獲取服務實例,而後獲取基本 URL。
(3)利用 REST 模板來使用服務。 前面的代碼以下
@Controller
public class ConsumerControllerClient {
    @Autowired
    private LoadBalancerClient loadBalancer;
    public void getEmployee() throws RestClientException, IOException {
        ServiceInstance serviceInstance=loadBalancer.choose("employee-producer");
        System.out.println(serviceInstance.getUri());
        String baseUrl=serviceInstance.getUri().toString();
        baseUrl=baseUrl+"/employee";
        RestTemplate restTemplate = new RestTemplate();
        ResponseEntity<String> response=null;
        try{
            response=restTemplate.exchange(baseUrl,
                        HttpMethod.GET, getHeaders(),String.class);
        }
        catch (Exception ex)
            {
            System.out.println(ex);
        }
        System.out.println(response.getBody());
    }複製代碼
以前的代碼,有像 NullPointer 這樣的例外的機會,並非最優的。咱們將看到如何使用 Netflix Feign 使呼叫變得更加輕鬆和清潔。若是 Netflix Ribbon 依賴關係也在類路徑中,那麼 Feign 默認也會負責負載平衡。

十、什麼是 Spring Cloud Bus?咱們須要它嗎?

考慮如下狀況:咱們有多個應用程序使用 Spring Cloud Config 讀取屬性,而Spring Cloud Config 從 GIT 讀取這些屬性。
下面的例子中多個員工生產者模塊從 Employee Config Module 獲取 Eureka 註冊的財產。

若是假設 GIT 中的 Eureka 註冊屬性更改成指向另外一臺 Eureka 服務器,會發生什麼狀況。在這種狀況下,咱們將不得不從新啓動服務以獲取更新的屬性。
還有另外一種使用執行器端點/刷新的方式。可是咱們將不得不爲每一個模塊單獨調用這個 url。例如,若是 Employee Producer1 部署在端口 8080 上,則調用 http:// localhost:8080 / refresh。一樣對於 Employee Producer2 http://localhost:8081 / refresh 等等。這又很麻煩。這就是 Spring Cloud Bus 發揮做用的地方。
Spring Cloud Bus 提供了跨多個實例刷新配置的功能。所以,在上面的示例中,若是咱們刷新 Employee Producer1,則會自動刷新全部其餘必需的模塊。若是咱們有多個微服務啓動並運行,這特別有用。這是經過將全部微服務鏈接到單個消息代理來實現的。不管什麼時候刷新實例,此事件都會訂閱到偵聽此代理的全部微服務,而且它們也會刷新。能夠經過使用端點/總線/刷新來實現對任何單個實例的刷新。

11.springcloud斷路器的做用

當一個服務調用另外一個服務因爲網絡緣由或自身緣由出現問題,調用者就會等待被調用者的響應 當更多的服務請求到這些資源致使更多的請求等待,發生連鎖效應(雪崩效應)
斷路器有徹底打開狀態:一段時間內 達到必定的次數沒法調用 而且屢次監測沒有恢復的跡象 斷路器徹底打開 那麼下次請求就不會請求到該服務
半開:短期內 有恢復跡象 斷路器會將部分請求發給該服務,正常調用時 斷路器關閉
關閉:當服務一直處於正常狀態 能正常調用

十二、什麼是SpringCloudConfig?

在分佈式系統中,因爲服務數量巨多,爲了方便服務配置文件統一管理,實時更新,因此須要分佈式配置中心組件。在Spring Cloud中,有分佈式配置中心組件spring cloud config ,它支持配置服務放在配置服務的內存中(即本地),也支持放在遠程Git倉庫中。在spring cloud config 組件中,分兩個角色,一是config server,二是config client。
使用:
(1)添加pom依賴
(2)配置文件添加相關配置
(3)啓動類添加註解@EnableConfigServer

1三、Spring Cloud Gateway?

Spring Cloud Gateway是Spring Cloud官方推出的第二代網關框架,取代Zuul網關。網關做爲流量的,在微服務系統中有着很是做用,網關常見的功能有路由轉發、權限校驗、限流控制等做用。
使用了一個RouteLocatorBuilder的bean去建立路由,除了建立路由RouteLocatorBuilder可讓你添加各類predicates和filters,predicates斷言的意思,顧名思義就是根據具體的請求的規則,由具體的route去處理,filters是各類過濾器,用來對請求作各類判斷和修改。

歡迎你們關注個人公衆號【程序員追風】,2019年多家公司java面試題整理了1000多道400多頁pdf文檔,文章都會在裏面更新,整理的資料也會放在裏面。java

最後

歡迎你們一塊兒交流,喜歡文章記得關注我點個贊喲,感謝支持!
相關文章
相關標籤/搜索