2019年必須掌握的29個微服務面試問題(含答案解析)

程式設計如風發表於2019-07-08

這29個微服務面試題基本涵蓋了方方面,希望對你有所幫助!

一、什麼是Spring Cloud?

在微服務中,SpringCloud是一個提供與外部系統整合的系統。它是一個敏捷的框架,可以短平快構建應用程式。與有限數量的資料處理相關聯,它在微服務體系結構中起著非常重要的作用。
以下為 Spring Cloud 的核心特性:

  1. 版本化/分散式配置。
  2. 服務註冊和發現。
  3. 服務和服務之間的呼叫。
  4. 路由。
  5. 斷路器和負載平衡。
  6. 分散式訊息傳遞。

二、什麼是Spring Boot?

Spring boot是微服務面試問題的主要話題。
隨著新功能的加入,Spring變得越來越複雜。無論何時啟動新專案,都必須新增新的構建路徑或Maven依賴項。簡而言之,你需要從頭開始做每件事。Spring Boot是一種幫助您避免所有程式碼配置的解決方案。

三、如何覆蓋Spring Boot專案的預設屬性?

這可以通過在application.properties檔案中指定屬性來完成。
例如,在Spring MVC應用程式中,您必須指定字尾和字首。這可以通過在application.properties檔案中輸入下面提到的屬性來完成。

  • 對於字尾 - spring.mvc.view.suffix: .jsp
  • 對於字首 - spring.mvc.view.prefix: /WEB-INF/

四、Actuator在Spring Boot中的作用

它是最重要的功能之一,可幫助您訪問在生產環境中執行的應用程式的當前狀態。有多個指標可用於檢查當前狀態。它們還為RESTful Web服務提供端點,可以簡單地用於檢查不同的度量標準。

五、如何在Spring Boot應用程式中實現Spring安全性?

實施需要最少的配置。您需要做的就是spring-boot-starter-security在pom.xml檔案中新增starter。您還需要建立一個Spring配置類,它將覆蓋所需的方法,同時擴充套件 WebSecurityConfigurerAdapter 應用程式中的安全性。這是一些示例程式碼:

package com.gkatzioura.security.securityendpoints.config; 
import org.springframework.context.annotation.Configuration; 
import org.springframework.security.config.annotation.web.builders.HttpSecurity; 
import org.springframework.security.config.annotation.web.configuration.WebSecurityConfigurerAdapter; 
@Configuration 
public class SecurityConfig extends WebSecurityConfigurerAdapter {     
@Override     
protected void configure(HttpSecurity http) throws Exception {         
http.authorizeRequests()             
.antMatchers("/welcome").permitAll()             
.anyRequest().authenticated()             
.and()             
.formLogin()             
.permitAll()             
.and()             
.logout()             
.permitAll();     
} 
}

六、Spring Boot支援哪些嵌入式容器?

無論何時建立Java應用程式,都可以通過兩種方法進行部署:
使用外部的應用程式容器。
將容器嵌入jar檔案中。
Spring Boot包含Jetty,Tomcat和Undertow伺服器,所有伺服器都是嵌入式的。
Jetty - 用於大量專案,Eclipse Jetty可以嵌入到框架,應用程式伺服器,工具和叢集中。
Tomcat - Apache Tomcat是一個開源JavaServer Pages實現,可以很好地與嵌入式系統配合使用。
Undertow - 一個靈活而突出的Web伺服器,它使用小型單一處理程式來開發Web伺服器。

七、微服務的端到端測試意味著什麼?

端到端測試 驗證工作流中的所有流程,以檢查一切是否按預期工作。它還確保系統以統一的方式工作,從而滿足業務需求。

八、什麼是Semantic監控?

它結合了對整個應用程式的監控以及自動化測試。語義監控的主要好處是找出對您的業務更有利可圖的因素。
從業務角度來看,語義監控以及服務層監控可以監控微服務。一旦檢測到問題,它們就可以實現更快的隔離和 錯誤分類,從而減少修復所需的主要時間。它對服務層和事務層進行分類,以確定受可用性或效能不佳影響的事務。

九如何設定服務發現?

有多種方法可以設定服務發現。我將選擇我認為效率最高的那個,Netflix的Eureka。這是一個簡單的程式,不會對應用程式造成太大影響。此外,它支援多種型別的Web應用程式。
Eureka配置包括兩個步驟 - 客戶端配置和伺服器配置。

使用屬性檔案可以輕鬆完成客戶端配置。在clas spath中,Eureka搜尋一個eureka-client.properties檔案。它還搜尋由特定於環境的屬性檔案中的環境引起的覆蓋。

對於伺服器配置,您必須首先配置客戶端。完成後,伺服器啟動一個客戶端,該客戶端用於查詢其他伺服器。。預設情況下,Eureka伺服器使用客戶端配置來查詢對等伺服器。

十、為什麼要選擇微服務架構?

這是一個非常常見的微服務面試問題,你應該準備好了!微服務架構提供了許多優點。這裡有幾個:

  1. 微服務可以輕鬆適應其他框架或技術。
  2. 單個程式的失敗不會影響整個系統。
  3. 為大企業和小型團隊提供支援。
  4. 可以在相對較短的時間內獨立部署。

十一、為什麼在微服務中需要Reports報告和Dashboards儀表板?

報告和儀表板主要用於監視和維護微服務。有多種工具可以幫助實現此目的。報告 和儀表板可用於:
找出哪些微服務公開了哪些資源。
找出元件發生變化時受影響的服務。
提供一個簡單的點,只要需要文件,就可以訪問它。
部署的元件的版本。

十二、為什麼人們會猶豫使用微服務?

我見過許多開發者在這個問題上摸索。畢竟,在面試微服務架構師角色時,他們會被問到這個問題,所以承認它的缺點可能有點棘手。以下是一些很好的答案:

它們需要大量協作 - 微服務需要大量的合作。不同的微服務模組,可能分散在不同的團隊,團隊之間需要始終保持良好的同步。

他們需要建立繁重的架構 - 系統是分散式的,架構涉及很多。
他們需要過多的計劃來處理操作開銷 - 如果您計劃使用微服務架構,則需要為操作開銷做好準備。
需要熟練的專業人員,他們可以支援異構分佈的微服務。

十三、PACT如何運作?

PACT是一個開源工具。它有助於測試消費者和服務提供商之間的互動。消費者服務開發人員首先編寫一個測試,該測試定義了與服務提供者的互動模式。測試包括提供者的狀態,請求正文和預期的響應。基於此,PACT建立了一個針對其執行測試的存根。輸出儲存在JSON檔案中。

十四、談一下領域驅動設計

主要關注核心領域邏輯。基於領域的模型檢測複雜設計。這涉及與公司層面領域方面的專家定期合作,以解決與領域相關的問題並改進應用程式的模型。在回答這個微服務面試問題時,您還需要提及DDD的核心基礎知識。他們是:

  • DDD主要關注領域邏輯和領域本身。
  • 複雜的設計完全基於領域的模型。
  • 為了改進模型的設計並解決任何新出現的問題,DDD不斷與公司領域方面的專家合作。

十五、什麼是耦合和凝聚力?

元件之間依賴關係強度的度量被認為是耦合。一個好的設計總是被認為具有高內聚力和低耦合性。
面試官經常會問起凝聚力。它也是另一個測量單位。更像是一個模組內部的元素保持結合的程度。
必須記住,設計微服務的一個重要關鍵是低耦合和高內聚的組合。當低耦合時,服務對其他服務的依賴很少。這樣可以保持服務的完整性。在高內聚性中,將所有相關邏輯儲存在服務中成為可能。否則,服務將嘗試彼此通訊,從而影響整體效能。

十六、什麼是Oauth?

開放授權協議,這允許通過在HTTP服務上啟用客戶端應用程式(例如第三方提供商Facebook,GitHub等)來訪問資源所有者的資源。因此,您可以在不使用其憑據的情況下與另一個站點共享儲存在一個站點上的資源。

OAuth允許像Facebook這樣的第三方使用終端使用者的帳戶資訊,同時保證其安全(不使用或暴露使用者的密碼)。它更像是代表使用者的中介,同時為伺服器提供訪問所需資訊的令牌。

十七、為什麼我們需要微服務容器?

要管理基於微服務的應用程式,容器是最簡單的選擇。它幫助使用者單獨部署和開發。您還可以使用Docker將微服務封裝到容器的映象中。沒有任何額外的依賴或工作,微服務可以使用這些元素。

十八、訪問RESTful微服務的方法是什麼?

另一個經常被問到的微服務面試問題是如何訪問RESTful微服務?你可以通過兩種方法做到這一點:

  • 使用負載平衡的REST模板。
  • 使用多個微服務。

十九、微服務測試的主要障礙是什麼?

說到缺點,這裡是另一個微服務面試問題,將圍繞測試微服務時面臨的挑戰。

  • 在開始編寫整合測試的測試用例之前,測試人員應該全面瞭解對所有入站和出站過程。
  • 當獨立的團隊正在開發不同的功能時,協作可能會被證明是一項非常困難的任務。很難找到空閒時間視窗來執行完整的迴歸測試。
  • 隨著微服務數量的增加,系統的複雜性也隨之增加。
  • 在從單片架構過渡期間,測試人員必須確保元件之間的內部通訊沒有中斷。

二十、過渡到微服務時的常見錯誤

不僅在開發上,而且在方面流程也經常發生錯誤。一些常見錯誤是:

  • 通常開發人員無法概述當前的挑戰。
  • 重寫已經存在的程式。
  • 職責、時間線和界限沒有明確定義。
  • 未能從一開始就實施和確定自動化的範圍。

二十一、微服務設計的基礎是什麼?

這可能是最常見的微服務面試問題之一。在回答這個問題時,你需要記住以下內容:

  1. 定義範圍。
  2. 結合低耦合和高內聚。
  3. 建立一個有唯一標識的服務,唯一標識將充當識別源,非常像資料庫表中的唯一鍵。
  4. 建立正確的API並在整合過程中特別注意。
  5. 限制對資料的訪問並將其限制到所需級別。
  6. 在請求和響應之間保持順暢的流程。
  7. 自動化大多數流程,以減少時間複雜性。
  8. 將表的數量保持在最低水平,以減少空間複雜性。
  9. 不斷監控架構,發現缺陷及時修復。
  10. 每個微服務的資料儲存應該分開。
  11. 對於每個微服務,都應該有一個獨立的構建。
  12. 將微服務部署到容器中。
  13. 伺服器應被視為無狀態。

**二十二、在Spring MVC應用程式中使用WebMvcTest註釋有什麼用處?

WebMvcTest註釋用於單元測試Spring MVC應用程式。我們只想啟動ToTestController。執行此單元測試時,不會啟動所有其他控制器和對映。

@WebMvcTest(value = ToTestController.class, secure = false):

二十三、什麼是有界上下文?

有界上下文是域驅動設計的核心模式。DDD戰略設計部門的重點是處理大型模型和團隊。DDD通過將大型模型劃分為不同的有界上下文並明確其相互關係來處理大型模型。

二十四、什麼是不同型別的雙因素身份認證?

執行雙因素身份驗證需要三種型別的憑據:

  • 一件你知道的事情——比如密碼、密碼或螢幕鎖定模式。
  • 您擁有的物理憑證,如OTP、電話或ATM卡,換句話說,您在外部或第三方裝置中擁有的任何型別的憑證。
  • 您的物理身份–如語音認證或生物特徵安全,如指紋或眼睛掃描器。

二十五、什麼是客戶證照?

客戶端系統用於向遠端伺服器發出經過身份驗證的請求的一種數字證照稱為客戶端證照。客戶端證照在許多相互認證設計中起著非常重要的作用,為請求者的身份提供了強有力的保證。

二十六、康威定律是什麼?

康威定律指出,“設計系統的組織,其產生的設計等同於組織之內、組織之間的溝通結構。”
面試官可能會問反微服務面試問題,比如康威定律與微服務的關係。一些鬆散耦合的api形成了微服務的體系結構。這種結構非常適合小團隊實現自治元件的方式。這種體系結構使組織在重組其工作流程時更加靈活。

二十七、如何配置Spring Boot應用程式日誌記錄?

Spring Boot附帶了對Log4J2,Java Util Logging和Logback的支援。它通常預先配置為控制檯輸出。可以通過僅在application.properties檔案中指定logging.level來配置它們。

logging.level.spring.framework=Debug

二十八、您將如何在微服務上執行安全測試?

您需要獨立測試各個部分。有三種常見的程式:

  • 程式碼掃描 - 確保任何程式碼行都沒有錯誤並且可以複製。
  • 靈活性 - 安全解決方案應該是靈活的,以便可以根據系統的要求進行調整。
  • 適應性 - 安全協議應該靈活和更新,以應對黑客或安全漏洞的新威脅。

二十九、什麼是冪等性?它是如何使用的?

冪等性指的是這樣一種場景:您重複執行一項任務,但最終結果保持不變或類似。
冪等性主要用作資料來源或遠端服務,當它接收一組以上指令時,它只處理一組指令。

讀者福利、完整面試題【含答案】Java核心筆記,Java架構面試專題整合千道(pdf文件)

免費獲取Java學習筆記,面試,文件以及視訊

 

相關文章