新一期Spring Boot 面試題

程式設計師生態圈發表於2018-08-14

問題一

什麼是Spring Boot?

多年來,隨著新功能的增加,spring變得越來越複雜。只需訪問https://spring.io/projects頁面,我們就會看到可以在我們的應用程式中使用的所有Spring專案的不同功能。如果必須啟動一個新的Spring專案,我們必須新增構建路徑或新增Maven依賴關係,配置應用程式伺服器,新增spring配置。因此,開始一個新的spring專案需要很多努力,因為我們現在必須從頭開始做所有事情。

Spring Boot是解決這個問題的方法。Spring Boot已經建立在現有spring框架之上。使用spring啟動,我們避免了之前我們必須做的所有樣板程式碼和配置。因此,Spring Boot可以幫助我們以最少的工作量,更加健壯地使用現有的Spring功能。

 

問題二

Spring Boot有哪些優點?

Spring Boot的優點有:

減少開發,測試時間和努力。

使用JavaConfig有助於避免使用XML。

避免大量的Maven匯入和各種版本衝突。

提供意見發展方法。

通過提供預設值快速開始開發。

沒有單獨的Web伺服器需要。這意味著你不再需要啟動Tomcat,Glassfish或其他任何東西。

需要更少的配置 因為沒有web.xml檔案。只需新增用@ Configuration註釋的類,然後新增用@Bean註釋的方法,Spring將自動載入物件並像以前一樣對其進行管理。您甚至可以將@Autowired新增到bean方法中,以使Spring自動裝入需要的依賴關係中。

基於環境的配置 使用這些屬性,您可以將您正在使用的環境傳遞到應用程式:-Dspring.profiles.active = {enviornment}。在載入主應用程式屬性檔案後,Spring將在(application{environment} .properties)中載入後續的應用程式屬性檔案。

 

問題三

什麼是JavaConfig?

Spring JavaConfig是Spring社群的產品,它提供了配置Spring IoC容器的純Java方法。因此它有助於避免使用XML配置。使用JavaConfig的優點在於:

物件導向的配置。由於配置被定義為JavaConfig中的類,因此使用者可以充分利用Java中的物件導向功能。一個配置類可以繼承另一個,重寫它的@Bean方法等。

減少或消除XML配置。基於依賴注入原則的外化配置的好處已被證明。但是,許多開發人員不希望在XML和Java之間來回切換。JavaConfig為開發人員提供了一種純Java方法來配置與XML配置概念相似的Spring容器。從技術角度來講,只使用JavaConfig配置類來配置容器是可行的,但實際上很多人認為將JavaConfig與XML混合匹配是理想的。

型別安全和重構友好。JavaConfig提供了一種型別安全的方法來配置Spring容器。由於Java 5.0對泛型的支援,現在可以按型別而不是按名稱檢索bean,不需要任何強制轉換或基於字串的查詢。

 

問題四

如何重新載入Spring Boot上的更改,而無需重新啟動伺服器?

這可以使用DEV工具來實現。通過這種依賴關係,您可以節省任何更改,嵌入式tomcat將重新啟動。Spring Boot有一個開發工具(DevTools)模組,它有助於提高開發人員的生產力。Java開發人員面臨的一個主要挑戰是將檔案更改自動部署到伺服器並自動重啟伺服器。開發人員可以重新載入Spring Boot上的更改,而無需重新啟動伺服器。這將消除每次手動部署更改的需要。Spring Boot在釋出它的第一個版本時沒有這個功能。這是開發人員最需要的功能。DevTools模組完全滿足開發人員的需求。該模組將在生產環境中被禁用。它還提供H2資料庫控制檯以更好地測試應用程式。

org.springframework.boot

spring-boot-devtools

true

 

問題五

Spring Boot中的監視器是什麼?

Spring boot actuator是spring啟動框架中的重要功能之一。Spring boot監視器可幫助您訪問生產環境中正在執行的應用程式的當前狀態。有幾個指標必須在生產環境中進行檢查和監控。即使一些外部應用程式可能正在使用這些服務來向相關人員觸發警報訊息。監視器模組公開了一組可直接作為HTTP URL訪問的REST端點來檢查狀態。

 

問題六

如何在Spring Boot中禁用Actuator端點安全性?

預設情況下,所有敏感的HTTP端點都是安全的,只有具有ACTUATOR角色的使用者才能訪問它們。安全性是使用標準的HttpServletRequest.isUserInRole方法實施的。 我們可以使用

management.security.enabled = false

來禁用安全性。只有在執行機構端點在防火牆後訪問時,才建議禁用安全性。

 

問題七

如何在自定義埠上執行Spring Boot應用程式?

為了在自定義埠上執行Spring Boot應用程式,您可以在application.properties中指定埠。

server.port = 8090

 

問題八

什麼是YAML?

YAML是一種人類可讀的資料序列化語言。它通常用於配置檔案。

與屬性檔案相比,如果我們想要在配置檔案中新增複雜的屬性,YAML檔案就更加結構化,而且更少混淆。可以看出YAML具有分層配置資料。

 

問題九

如何實現Spring Boot應用程式的安全性?

為了實現Spring Boot的安全性,我們使用 spring-boot-starter-security依賴項,並且必須新增安全配置。它只需要很少的程式碼。配置類將必須擴充套件WebSecurityConfigurerAdapter並覆蓋其方法。

溫馨提示:程式猿面試交流圈子,853779762

問題十

如何整合Spring Boot和ActiveMQ?

對於整合Spring Boot和ActiveMQ,我們使用

spring-boot-starter-activemq

依賴關係。 它只需要很少的配置,並且不需要樣板程式碼。

 

問題十一

如何使用Spring Boot實現分頁和排序?

使用Spring Boot實現分頁非常簡單。使用Spring Data-JPA可以實現將可分頁的

org.springframework.data.domain.Pageable

傳遞給儲存庫方法。

 

問題十二

什麼是Swagger?你用Spring Boot實現了它嗎?

Swagger廣泛用於視覺化API,使用Swagger UI為前端開發人員提供線上沙箱。Swagger是用於生成RESTful Web服務的視覺化表示的工具,規範和完整框架實現。它使文件能夠以與伺服器相同的速度更新。當通過Swagger正確定義時,消費者可以使用最少量的實現邏輯來理解遠端服務並與其進行互動。因此,Swagger消除了呼叫服務時的猜測。

 

問題十三

什麼是Spring Profiles?

Spring Profiles允許使用者根據配置檔案(dev,test,prod等)來註冊bean。因此,當應用程式在開發中執行時,只有某些bean可以載入,而在PRODUCTION中,某些其他bean可以載入。假設我們的要求是Swagger文件僅適用於QA環境,並且禁用所有其他文件。這可以使用配置檔案來完成。Spring Boot使得使用配置檔案非常簡單。

問題十四

什麼是Spring Batch?

Spring Boot Batch提供可重用的函式,這些函式在處理大量記錄時非常重要,包括日誌/跟蹤,事務管理,作業處理統計資訊,作業重新啟動,跳過和資源管理。它還提供了更先進的技術服務和功能,通過優化和分割槽技術,可以實現極高批量和高效能批處理作業。簡單以及複雜的大批量批處理作業可以高度可擴充套件的方式利用框架處理重要大量的資訊。

問題十五

什麼是FreeMarker模板?

FreeMarker是一個基於Java的模板引擎,最初專注於使用MVC軟體架構進行動態網頁生成。使用Freemarker的主要優點是表示層和業務層的完全分離。程式設計師可以處理應用程式程式碼,而設計人員可以處理html頁面設計。最後使用freemarker可以將這些結合起來,給出最終的輸出頁面。

問題十六

如何使用Spring Boot實現異常處理?

Spring提供了一種使用ControllerAdvice處理異常的非常有用的方法。 我們通過實現一個ControlerAdvice類,來處理控制器類丟擲的所有異常。

問題十七

您使用了哪些starter maven依賴項?

使用了下面的一些依賴項

spring-boot-starter-activemq

spring-boot-starter-security

spring-boot-starter-web

這有助於增加更少的依賴關係,並減少版本的衝突。

溫馨提示:程式猿面試交流圈子,853779762

問題十八

什麼是CSRF攻擊?

CSRF代表跨站請求偽造。這是一種攻擊,迫使終端使用者在當前通過身份驗證的Web應用程式上執行不需要的操作。CSRF攻擊專門針對狀態改變請求,而不是資料竊取,因為攻擊者無法檢視對偽造請求的響應。

問題十九

什麼是WebSockets?

WebSocket是一種計算機通訊協議,通過單個TCP連線提供全雙工通訊通道。

WebSocket是雙向的 -使用WebSocket客戶端或伺服器可以發起訊息傳送。

WebSocket是全雙工的 -客戶端和伺服器通訊是相互獨立的。

單個TCP連線 -初始連線使用HTTP,然後將此連線升級到基於套接字的連線。然後這個單一連線用於所有未來的通訊

Light -與http相比,WebSocket訊息資料交換要輕得多。

問題二十

什麼是AOP?

在軟體開發過程中,跨越應用程式多個點的功能稱為交叉問題。這些交叉問題與應用程式的主要業務邏輯不同。因此,將這些橫切關注與業務邏輯分開是面向方面程式設計(AOP)的地方。

問題二十一

什麼是Apache Kafka?

Apache Kafka是一個分散式釋出 - 訂閱訊息系統。它是一個可擴充套件的,容錯的釋出 - 訂閱訊息系統,它使我們能夠構建分散式應用程式。這是一個Apache頂級專案。Kafka適合離線和線上訊息消費。

溫馨提示:程式猿面試交流圈子,853779762

問題二十二

我們如何監視所有Spring Boot微服務?

Spring Boot提供監視器端點以監控各個微服務的度量。這些端點對於獲取有關應用程式的資訊(如它們是否已啟動)以及它們的元件(如資料庫等)是否正常執行很有幫助。但是,使用監視器的一個主要缺點或困難是,我們必須單獨開啟應用程式的知識點以瞭解其狀態或健康狀況。想象一下涉及50個應用程式的微服務,管理員將不得不擊中所有50個應用程式的執行終端。

為了幫助我們處理這種情況,我們將使用位於

https://github.com/codecentric/spring-boot-admin

的開源專案。 它建立在Spring Boot Actuator之上,它提供了一個Web UI,使我們能夠視覺化多個應用程式的度量。

 

相關文章