微服務(wù)框架之Spring Boot 面試題匯總

問(wèn)題一

什么是Spring Boot?多年來(lái),隨著新功能的增加,spring變得越來(lái)越復(fù)雜。只需訪問(wèn)https://spring.io/projects頁(yè)面,我們就會(huì)看到可以在我們的應(yīng)用程序中使用的所有Spring項(xiàng)目的不同功能。如果必須啟動(dòng)一個(gè)新的Spring項(xiàng)目,我們必須添加構(gòu)建路徑或添加Maven依賴關(guān)系,配置應(yīng)用程序服務(wù)器,添加spring配置。因此,開(kāi)始一個(gè)新的spring項(xiàng)目需要很多努力,因?yàn)槲覀儸F(xiàn)在必須從頭開(kāi)始做所有事情。Spring Boot是解決這個(gè)問(wèn)題的方法。Spring Boot已經(jīng)建立在現(xiàn)有spring框架之上。使用spring啟動(dòng),我們避免了之前我們必須做的所有樣板代碼和配置。因此,Spring Boot可以幫助我們以最少的工作量,更加健壯地使用現(xiàn)有的Spring功能。

問(wèn)題二

Spring Boot有哪些優(yōu)點(diǎn)?Spring Boot的優(yōu)點(diǎn)有:減少開(kāi)發(fā),測(cè)試時(shí)間和努力。使用JavaConfig有助于避免使用XML。避免大量的Maven導(dǎo)入和各種版本沖突。提供意見(jiàn)發(fā)展方法。通過(guò)提供默認(rèn)值快速開(kāi)始開(kāi)發(fā)。沒(méi)有單獨(dú)的Web服務(wù)器需要。這意味著你不再需要啟動(dòng)Tomcat,Glassfish或其他任何東西。需要更少的配置 因?yàn)闆](méi)有web.xml文件。只需添加用@ Configuration注釋的類,然后添加用@Bean注釋的方法,Spring將自動(dòng)加載對(duì)象并像以前一樣對(duì)其進(jìn)行管理。您甚至可以將@Autowired添加到bean方法中,以使Spring自動(dòng)裝入需要的依賴關(guān)系中?;诃h(huán)境的配置 使用這些屬性,您可以將您正在使用的環(huán)境傳遞到應(yīng)用程序:-Dspring.profiles.active = {enviornment}。在加載主應(yīng)用程序?qū)傩晕募?,Spring將在(application{environment} .properties)中加載后續(xù)的應(yīng)用程序?qū)傩晕募?/p>

問(wèn)題三

什么是JavaConfig?Spring JavaConfig是Spring社區(qū)的產(chǎn)品,它提供了配置Spring IoC容器的純Java方法。因此它有助于避免使用XML配置。使用JavaConfig的優(yōu)點(diǎn)在于:面向?qū)ο蟮呐渲?。由于配置被定義為JavaConfig中的類,因此用戶可以充分利用Java中的面向?qū)ο蠊δ?。一個(gè)配置類可以繼承另一個(gè),重寫(xiě)它的@Bean方法等。減少或消除XML配置?;谝蕾囎⑷朐瓌t的外化配置的好處已被證明。但是,許多開(kāi)發(fā)人員不希望在XML和Java之間來(lái)回切換。JavaConfig為開(kāi)發(fā)人員提供了一種純Java方法來(lái)配置與XML配置概念相似的Spring容器。從技術(shù)角度來(lái)講,只使用JavaConfig配置類來(lái)配置容器是可行的,但實(shí)際上很多人認(rèn)為將JavaConfig與XML混合匹配是理想的。類型安全和重構(gòu)友好。JavaConfig提供了一種類型安全的方法來(lái)配置Spring容器。由于Java 5.0對(duì)泛型的支持,現(xiàn)在可以按類型而不是按名稱檢索bean,不需要任何強(qiáng)制轉(zhuǎn)換或基于字符串的查找。

問(wèn)題四

如何重新加載Spring Boot上的更改,而無(wú)需重新啟動(dòng)服務(wù)器?這可以使用DEV工具來(lái)實(shí)現(xiàn)。通過(guò)這種依賴關(guān)系,您可以節(jié)省任何更改,嵌入式tomcat將重新啟動(dòng)。Spring Boot有一個(gè)開(kāi)發(fā)工具(DevTools)模塊,它有助于提高開(kāi)發(fā)人員的生產(chǎn)力。Java開(kāi)發(fā)人員面臨的一個(gè)主要挑戰(zhàn)是將文件更改自動(dòng)部署到服務(wù)器并自動(dòng)重啟服務(wù)器。開(kāi)發(fā)人員可以重新加載Spring Boot上的更改,而無(wú)需重新啟動(dòng)服務(wù)器。這將消除每次手動(dòng)部署更改的需要。Spring Boot在發(fā)布它的第一個(gè)版本時(shí)沒(méi)有這個(gè)功能。這是開(kāi)發(fā)人員最需要的功能。DevTools模塊完全滿足開(kāi)發(fā)人員的需求。該模塊將在生產(chǎn)環(huán)境中被禁用。它還提供H2數(shù)據(jù)庫(kù)控制臺(tái)以更好地測(cè)試應(yīng)用程序。<dependency><groupId>org.springframework.boot</groupId><artifactId>spring-boot-devtools</artifactId><optional>true</optional></dependency>

問(wèn)題五

Spring Boot中的監(jiān)視器是什么?Spring boot actuator是spring啟動(dòng)框架中的重要功能之一。Spring boot監(jiān)視器可幫助您訪問(wèn)生產(chǎn)環(huán)境中正在運(yùn)行的應(yīng)用程序的當(dāng)前狀態(tài)。有幾個(gè)指標(biāo)必須在生產(chǎn)環(huán)境中進(jìn)行檢查和監(jiān)控。即使一些外部應(yīng)用程序可能正在使用這些服務(wù)來(lái)向相關(guān)人員觸發(fā)警報(bào)消息。監(jiān)視器模塊公開(kāi)了一組可直接作為HTTP URL訪問(wèn)的REST端點(diǎn)來(lái)檢查狀態(tài)。

問(wèn)題六

如何在Spring Boot中禁用Actuator端點(diǎn)安全性?默認(rèn)情況下,所有敏感的HTTP端點(diǎn)都是安全的,只有具有ACTUATOR角色的用戶才能訪問(wèn)它們。安全性是使用標(biāo)準(zhǔn)的HttpServletRequest.isUserInRole方法實(shí)施的。 我們可以使用management.security.enabled = false來(lái)禁用安全性。只有在執(zhí)行機(jī)構(gòu)端點(diǎn)在防火墻后訪問(wèn)時(shí),才建議禁用安全性。

問(wèn)題七

如何在自定義端口上運(yùn)行Spring Boot應(yīng)用程序?為了在自定義端口上運(yùn)行Spring Boot應(yīng)用程序,您可以在application.properties中指定端口。server.port = 8090?

問(wèn)題八

什么是YAML?YAML是一種人類可讀的數(shù)據(jù)序列化語(yǔ)言。它通常用于配置文件。與屬性文件相比,如果我們想要在配置文件中添加復(fù)雜的屬性,YAML文件就更加結(jié)構(gòu)化,而且更少混淆。可以看出YAML具有分層配置數(shù)據(jù)。

問(wèn)題九

如何實(shí)現(xiàn)Spring Boot應(yīng)用程序的安全性?為了實(shí)現(xiàn)Spring Boot的安全性,我們使用 spring-boot-starter-security依賴項(xiàng),并且必須添加安全配置。它只需要很少的代碼。配置類將必須擴(kuò)展WebSecurityConfigurerAdapter并覆蓋其方法。

問(wèn)題十

如何集成Spring Boot和ActiveMQ?對(duì)于集成Spring Boot和ActiveMQ,我們使用spring-boot-starter-activemq依賴關(guān)系。 它只需要很少的配置,并且不需要樣板代碼。

問(wèn)題十一

如何使用Spring Boot實(shí)現(xiàn)分頁(yè)和排序?使用Spring Boot實(shí)現(xiàn)分頁(yè)非常簡(jiǎn)單。使用Spring Data-JPA可以實(shí)現(xiàn)將可分頁(yè)的org.springframework.data.domain.Pageable傳遞給存儲(chǔ)庫(kù)方法。

問(wèn)題十二

什么是Swagger?你用Spring Boot實(shí)現(xiàn)了它嗎?Swagger廣泛用于可視化API,使用Swagger UI為前端開(kāi)發(fā)人員提供在線沙箱。Swagger是用于生成RESTful Web服務(wù)的可視化表示的工具,規(guī)范和完整框架實(shí)現(xiàn)。它使文檔能夠以與服務(wù)器相同的速度更新。當(dāng)通過(guò)Swagger正確定義時(shí),消費(fèi)者可以使用最少量的實(shí)現(xiàn)邏輯來(lái)理解遠(yuǎn)程服務(wù)并與其進(jìn)行交互。因此,Swagger消除了調(diào)用服務(wù)時(shí)的猜測(cè)。

問(wèn)題十三

什么是Spring Profiles?Spring Profiles允許用戶根據(jù)配置文件(dev,test,prod等)來(lái)注冊(cè)bean。因此,當(dāng)應(yīng)用程序在開(kāi)發(fā)中運(yùn)行時(shí),只有某些bean可以加載,而在PRODUCTION中,某些其他bean可以加載。假設(shè)我們的要求是Swagger文檔僅適用于QA環(huán)境,并且禁用所有其他文檔。這可以使用配置文件來(lái)完成。Spring Boot使得使用配置文件非常簡(jiǎn)單。

問(wèn)題十四

什么是Spring Batch?Spring Boot Batch提供可重用的函數(shù),這些函數(shù)在處理大量記錄時(shí)非常重要,包括日志/跟蹤,事務(wù)管理,作業(yè)處理統(tǒng)計(jì)信息,作業(yè)重新啟動(dòng),跳過(guò)和資源管理。它還提供了更先進(jìn)的技術(shù)服務(wù)和功能,通過(guò)優(yōu)化和分區(qū)技術(shù),可以實(shí)現(xiàn)極高批量和高性能批處理作業(yè)。簡(jiǎn)單以及復(fù)雜的大批量批處理作業(yè)可以高度可擴(kuò)展的方式利用框架處理重要大量的信息。

問(wèn)題十五

什么是FreeMarker模板?FreeMarker是一個(gè)基于Java的模板引擎,最初專注于使用MVC軟件架構(gòu)進(jìn)行動(dòng)態(tài)網(wǎng)頁(yè)生成。使用Freemarker的主要優(yōu)點(diǎn)是表示層和業(yè)務(wù)層的完全分離。程序員可以處理應(yīng)用程序代碼,而設(shè)計(jì)人員可以處理html頁(yè)面設(shè)計(jì)。最后使用freemarker可以將這些結(jié)合起來(lái),給出最終的輸出頁(yè)面。

問(wèn)題十六

如何使用Spring Boot實(shí)現(xiàn)異常處理?Spring提供了一種使用ControllerAdvice處理異常的非常有用的方法。 我們通過(guò)實(shí)現(xiàn)一個(gè)ControlerAdvice類,來(lái)處理控制器類拋出的所有異常。

問(wèn)題十七

您使用了哪些starter maven依賴項(xiàng)?使用了下面的一些依賴項(xiàng)spring-boot-starter-activemqspring-boot-starter-securityspring-boot-starter-web這有助于增加更少的依賴關(guān)系,并減少版本的沖突。

問(wèn)題十八

什么是CSRF攻擊?CSRF代表跨站請(qǐng)求偽造。這是一種攻擊,迫使最終用戶在當(dāng)前通過(guò)身份驗(yàn)證的Web應(yīng)用程序上執(zhí)行不需要的操作。CSRF攻擊專門針對(duì)狀態(tài)改變請(qǐng)求,而不是數(shù)據(jù)竊取,因?yàn)楣粽邿o(wú)法查看對(duì)偽造請(qǐng)求的響應(yīng)。

問(wèn)題十九

什么是WebSockets?WebSocket是一種計(jì)算機(jī)通信協(xié)議,通過(guò)單個(gè)TCP連接提供全雙工通信信道。

?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請(qǐng)聯(lián)系作者
【社區(qū)內(nèi)容提示】社區(qū)部分內(nèi)容疑似由AI輔助生成,瀏覽時(shí)請(qǐng)結(jié)合常識(shí)與多方信息審慎甄別。
平臺(tái)聲明:文章內(nèi)容(如有圖片或視頻亦包括在內(nèi))由作者上傳并發(fā)布,文章內(nèi)容僅代表作者本人觀點(diǎn),簡(jiǎn)書(shū)系信息發(fā)布平臺(tái),僅提供信息存儲(chǔ)服務(wù)。

相關(guān)閱讀更多精彩內(nèi)容

友情鏈接更多精彩內(nèi)容