這10道springboot常見面試題你需要了解下

李紅歐巴發表於2019-03-05

這10道springboot常見面試題你需要了解下

1、什麼是Spring Boot?

多年來,隨著新功能的增加,spring變得越來越複雜。只需訪問https://spring.io/projects頁面,我們就會看到可以在我們的應用程式中使用的所有Spring專案的不同功能。

如果必須啟動一個新的Spring專案,我們必須新增構建路徑或新增Maven依賴關係,配置應用程式伺服器,新增spring配置。

因此,開始一個新的spring專案需要很多努力,因為我們現在必須從頭開始做所有事情。

Spring Boot是解決這個問題的方法。Spring Boot已經建立在現有spring框架之上。使用spring啟動,我們避免了之前我們必須做的所有樣板程式碼和配置。

因此,Spring Boot可以幫助我們以最少的工作量,更加健壯地使用現有的Spring功能。


2、Spring Boot有哪些優點?

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

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

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

  • 提供意見發展方法。

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

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

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

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


3、什麼是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,不需要任何強制轉換或基於字串的查詢。


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

這可以使用DEV工具來實現。通過這種依賴關係,您可以節省任何更改,嵌入式tomcat將重新啟動。

Spring Boot有一個開發工具(DevTools)模組,它有助於提高開發人員的生產力。Java開發人員面臨的一個主要挑戰是將檔案更改自動部署到伺服器並自動重啟伺服器。

開發人員可以重新載入Spring Boot上的更改,而無需重新啟動伺服器。這將消除每次手動部署更改的需要。Spring Boot在釋出它的第一個版本時沒有這個功能。

這是開發人員最需要的功能。DevTools模組完全滿足開發人員的需求。該模組將在生產環境中被禁用。它還提供H2資料庫控制檯以更好地測試應用程式。

這10道springboot常見面試題你需要了解下

5、Spring Boot中的監視器是什麼?

Spring boot actuator是spring啟動框架中的重要功能之一。Spring boot監視器可幫助您訪問生產環境中正在執行的應用程式的當前狀態。

有幾個指標必須在生產環境中進行檢查和監控。即使一些外部應用程式可能正在使用這些服務來向相關人員觸發警報訊息。監視器模組公開了一組可直接作為HTTP URL訪問的REST端點來檢查狀態。


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

預設情況下,所有敏感的HTTP端點都是安全的,只有具有ACTUATOR角色的使用者才能訪問它們。

安全性是使用標準的HttpServletRequest.isUserInRole方法實施的。 我們可以使用management.security.enabled = false 來禁用安全性。只有在執行機構端點在防火牆後訪問時,才建議禁用安全性。

如何在自定義埠上執行Spring Boot應用程式? 為了在自定義埠上執行Spring Boot應用程式,您可以在application.properties中指定埠。 server.port = 8090


7、什麼是YAML?

YAML是一種人類可讀的資料序列化語言。它通常用於配置檔案。 與屬性檔案相比,如果我們想要在配置檔案中新增複雜的屬性,YAML檔案就更加結構化,而且更少混淆。可以看出YAML具有分層配置資料。


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

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


9、如何整合Spring Boot和ActiveMQ?

對於整合Spring Boot和ActiveMQ,我們使用spring-boot-starter-activemq 依賴關係。 它只需要很少的配置,並且不需要樣板程式碼。


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

使用Spring Boot實現分頁非常簡單。使用Spring Data-JPA可以實現將可分頁的org.springframework.data.domain.Pageable傳遞給儲存庫方法。


免費Java資料領取,涵蓋了Java、Redis、MongoDB、MySQL、Zookeeper、Spring Cloud、Dubbo/Kafka、Hadoop、Hbase、Flink等高併發分散式、大資料、機器學習等技術。

傳送門:mp.weixin.qq.com/s/JzddfH-7y…


相關文章