即將到來的金三銀四,這10道springboot常見面試題你須要瞭解下

1.什麼是Spring Boot?web

多年來,隨着新功能的增長,spring變得愈來愈複雜。只需訪問https://spring.io/projects頁面,咱們就會看到能夠在咱們的應用程序中使用的全部Spring項目的不一樣功能。spring

若是必須啓動一個新的Spring項目,咱們必須添加構建路徑或添加Maven依賴關係,配置應用程序服務器,添加spring配置。數據庫

所以,開始一個新的spring項目須要不少努力,由於咱們如今必須從頭開始作全部事情。tomcat

Spring Boot是解決這個問題的方法。Spring Boot已經創建在現有spring框架之上。使用spring啓動,咱們避免了以前咱們必須作的全部樣板代碼和配置。安全

所以,Spring Boot能夠幫助咱們以最少的工做量,更加健壯地使用現有的Spring功能。服務器

2.Spring Boot有哪些優勢?app

     ·   減小開發,測試時間和努力。框架

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

     ·   避免大量的Maven導入和各類版本衝突。spring-boot

     ·   提供意見發展方法。

     ·   經過提供默認值快速開始開發。

     ·   沒有單獨的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數據庫控制檯以更好地測試應用程序。

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傳遞給存儲庫方法。

相關文章
相關標籤/搜索