一, 什么是spring boot?
多年來,隨著新功能的增加,spring變得越來越復(fù)雜。只需訪問頁面https://spring.io/projects,我們將看到所有在應(yīng)用程序中使用的不同功能的spring項目。如果必須啟動一個新的spring項目,我們必須添加構(gòu)建路徑或maven依賴項,配置application server,添加spring配置。因此,啟動一個新的spring項目需要大量的工作,因為我們目前必須從頭開始做所有事情。Spring Boot是這個問題的解決方案。Spring boot構(gòu)建在現(xiàn)有Spring框架之上。使用spring boot,我們可以避免以前必須執(zhí)行的所有樣板代碼和配置。因此,Spring boot幫助我們更健壯地使用現(xiàn)有的Spring功能,并且只需最少的工作量。
二,Spring Boot的優(yōu)點是什么?
減少開發(fā)、測試的時間和工作量。
使用JavaConfig有助于避免使用XML。
避免大量maven導(dǎo)入和各種版本沖突。
提供可選的開發(fā)方法。
通過提供默認開發(fā)方式進行快速開發(fā)。
不需要單獨的Web服務(wù)器。這意味著您不再需要啟動Tomcat、Glassfish或其他任何東西。
由于沒有web.xml文件,所以需要更少的配置。只需添加帶@ configuration注釋的類,然后可以添加帶@ bean注釋的方法,Spring將自動加載對象并像往常一樣管理它。您甚至可以將@Autowired添加到bean方法中,使Spring autowire成為bean所需的依賴項。
基于環(huán)境的配置——使用這些屬性,您可以將其傳遞到您正在使用的應(yīng)用程序環(huán)境中:- dspring .profile .active={enviorement}。在加載主應(yīng)用程序?qū)傩晕募螅琒pring將在(application-{environment}.properties)處加載后續(xù)的應(yīng)用程序?qū)傩晕募?/p>
三,您使用過哪些構(gòu)建工具來開發(fā)Spring引導(dǎo)應(yīng)用程序?
Spring Boot應(yīng)用程序可以使用Maven和Gradle開發(fā)。
四,什么是JavaConfig?
Spring JavaConfig是Spring社區(qū)的一個產(chǎn)品,它提供了一種純java方法來配置Spring IoC容器。因此,它有助于避免使用XML配置。使用JavaConfig的優(yōu)點是:
面向?qū)ο蟮呐渲谩R驗榕渲迷贘avaConfig中定義為類,所以用戶可以充分利用Java中的面向?qū)ο筇匦浴R粋€配置類可以子類化另一個配置類,覆蓋它的@Bean方法,等等。
減少或消除XML配置。已經(jīng)證明了基于依賴注入原則的外部化配置的好處。然而,許多開發(fā)人員不愿意在XML和Java之間來回切換。JavaConfig為開發(fā)人員提供了一種純java方法來配置Spring容器,這種方法在概念上類似于XML配置。從技術(shù)上講,僅使用 JavaConfig配置類來配置容器是可行的,但是在實踐中,許多人發(fā)現(xiàn)將JavaConfig與XML混合并匹配是理想的。
類型安全的重構(gòu)能力。JavaConfig提供了一種類型安全的配置Spring容器的方法。由于Java 5.0對泛型的支持,現(xiàn)在可以通過類型而不是名稱檢索bean,不需要進行任何基于類型轉(zhuǎn)換或字符串的查找。
五,如何在不重啟服務(wù)器的情況下在Spring引導(dǎo)時重新加載我的更改?
這可以通過開發(fā)工具來實現(xiàn)。有了這個依賴項,您保存的任何更改都將重新啟動嵌入的tomcat。Spring Boot有一個開發(fā)人員工具(DevTools)模塊,它有助于提高開發(fā)人員的工作效率。Java開發(fā)人員面臨的關(guān)鍵挑戰(zhàn)之一是將文件更改自動部署到服務(wù)器并自動重啟服務(wù)器。開發(fā)人員可以在Spring引導(dǎo)時重新加載更改,而不必重新啟動服務(wù)器。這將消除每次手動部署更改的需要。Spring Boot在發(fā)布第一個版本時沒有這個特性。這是開發(fā)人員最需要的特性。DevTools模塊完全滿足開發(fā)人員的需求。此模塊將在生產(chǎn)環(huán)境中禁用。它還提供了H2-database控制臺,以便更好地測試應(yīng)用程序。使用以下依賴項
<dependency>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-devtools</artifactId>
<optional>true</optional></dependency>
下面的示例演示了自動啟動和H2 DB控制臺的DevTool依賴項用法
六,什么是Spring boot actuator?
Spring boot actuator是Spring boot framework的重要特性之一。Spring boot actuator幫助您訪問生產(chǎn)環(huán)境中正在運行的應(yīng)用程序的當(dāng)前狀態(tài),在生產(chǎn)環(huán)境中必須檢查和監(jiān)視幾個指標(biāo)。甚至一些外部應(yīng)用程序也可能使用這些服務(wù)來觸發(fā)對相關(guān)人員的警報消息。actuator模塊公開一組REST端點,這些端點可以作為HTTP URL直接訪問,以檢查狀態(tài)。
七,如何將Spring Boot應(yīng)用程序作為war包部署?
Spring Boot WAR部署
八,什么是Docker嗎?如何將Spring引導(dǎo)應(yīng)用程序部署到Docker?
Docker是什么
將基于Spring的WAR應(yīng)用程序部署到Docker
將基于Spring的JAR應(yīng)用程序部署到Docker
九,如何禁用執(zhí)行器端點安全在Spring啟動?
默認情況下,所有敏感的HTTP端點都是安全的,只有具有ACTUATOR角色的用戶才能訪問它們。安全性是使用標(biāo)準HttpServletRequest.isUserInRole方法實現(xiàn)的。
我們可以使用-禁用安全性
management.security.enabled = false
建議僅當(dāng)在防火墻后訪問ACTUATOR端點時禁用安全性。
十,如何將Spring引導(dǎo)應(yīng)用程序運行到自定義端口?
要在自定義端口上運行spring引導(dǎo)應(yīng)用程序,可以在application.properties中指定端口。
server.port = 8090
十一,什么是ELK堆棧?如何與Spring Boot一起使用?
ELK堆棧由三個開源產(chǎn)品組成——Elasticsearch、Logstash和Kibana from Elastic。
Elasticsearch是一個基于Lucene搜索引擎的NoSQL數(shù)據(jù)庫。
Logstash是一個日志管道工具,它接受來自不同來源的輸入,執(zhí)行不同的轉(zhuǎn)換,并將數(shù)據(jù)導(dǎo)出到不同的目標(biāo)。它是一個動態(tài)的數(shù)據(jù)收集管道,具有可擴展的插件生態(tài)系統(tǒng)和強大的彈性搜索協(xié)同作用
Kibana是一個可視化UI層,工作在Elasticsearch之上。
這三個項目一起用于各種環(huán)境中的日志分析。因此Logstash收集和解析日志、彈性搜索索引并存儲這些信息,而Kibana提供了一個UI層,提供可操作的可見性。
十二,您有使用Spring Boot編寫測試用例嗎?
SpringBoot為編寫單元測試用例提供了@SpringBootTest
十三,YAML是什么?
YAML是一種人類可讀的數(shù)據(jù)序列化語言。它通常用于配置文件。
與屬性文件相比,YAML文件的結(jié)構(gòu)更加結(jié)構(gòu)化,如果我們希望在配置文件中添加復(fù)雜的屬性,那么它不會造成太大的混亂。可以看到,YAML具有分層的配置數(shù)據(jù)。
十四,如何為Spring引導(dǎo)應(yīng)用程序?qū)崿F(xiàn)安全性?
為了實現(xiàn)Spring Boot的安全性,我們使用Spring - Boot -starter-security依賴項,必須添加安全配置。它只需要很少的代碼。Config類必須擴展WebSecurityConfigurerAdapter并覆蓋它的方法。
十五,您是否集成了Spring Boot和ActiveMQ ?
為了集成Spring Boot和ActiveMQ,我們使用Spring - Boot -starter- ActiveMQ依賴項,它只需要很少的配置,沒有樣板代碼。
十六,您是否集成了Spring Boot和Apache Kafka ?
為了集成Spring Boot和Apache Kafka,我們使用Spring - Kafka依賴項。
十七,如何使用Spring引導(dǎo)實現(xiàn)分頁和排序?
使用Spring Boot實現(xiàn)分頁非常簡單。使用Spring Data-JPA,這是通過傳遞可分頁的org.springframe .data.domain來實現(xiàn)的。可分頁到存儲庫方法。
十八,什么是Swagger?您是否使用Spring Boot實現(xiàn)了它?
Swagger被廣泛用于可視化api,Swagger UI為前端開發(fā)人員提供在線沙箱環(huán)境。在本教程中,我們將使用Swagger 2規(guī)范的Springfox實現(xiàn)。Swagger是一種工具、規(guī)范和完整的框架實現(xiàn),用于生成RESTful Web服務(wù)的可視化表示。它允許文檔以與服務(wù)器相同的速度更新。當(dāng)通過Swagger正確定義時,使用者可以用最少的實現(xiàn)邏輯理解遠程服務(wù)并與之交互。因此Swagger消除了調(diào)用服務(wù)時的猜測。
十九,什么是Spring Profiles?如何使用Spring Boot實現(xiàn)它?
Spring Profiles允許用戶根據(jù)配置文件(dev, test, prod等)注冊bean。因此,當(dāng)應(yīng)用程序在開發(fā)中運行時,只能加載某些bean,當(dāng)應(yīng)用程序在生產(chǎn)中運行時,只能加載某些其他bean。假設(shè)我們的需求是Swagger文檔只對QA環(huán)境啟用,對所有其他環(huán)境禁用。這可以使用配置文件來完成。Spring Boot使得使用配置文件非常容易。
二十,什么是Spring Boot Batch?如何使用Spring Boot實現(xiàn)它?
Spring Boot Batch提供了處理大量記錄所必需的可重用功能,包括日志/跟蹤、事務(wù)管理、作業(yè)處理統(tǒng)計信息、作業(yè)重啟、作業(yè)跳過和資源管理。它還提供了更高級的技術(shù)服務(wù)和特性,通過優(yōu)化和分區(qū)技術(shù),這些特性將支持極高容量和高性能的批處理作業(yè)。無論是簡單的還是復(fù)雜的,大容量批處理作業(yè)都可以以高度可伸縮的方式利用該框架來處理大量信息。
二十一,什么是FreeMarker模板?如何使用Spring Boot實現(xiàn)它?
答:FreeMarker是一個基于java的模板引擎,最初專注于使用MVC軟件架構(gòu)生成動態(tài)web頁面。使用Freemarker的主要優(yōu)勢是完全分離了表示層和業(yè)務(wù)層。程序員可以處理應(yīng)用程序代碼,而設(shè)計人員可以處理html頁面設(shè)計。最后,使用freemarker,這些可以組合在一起,給出最終的輸出頁面。
二十二,如何使用Spring Boot實現(xiàn)異常處理?
Spring提供了一種非常有用的方法,可以使用ControllerAdvice處理異常。我們將實現(xiàn)一個ControlerAdvice類,它將處理控制器類拋出的所有異常。
二十三,什么是緩存?您在Spring引導(dǎo)中使用過緩存框架嗎?
緩存是本地內(nèi)存的一個區(qū)域,它保存了頻繁訪問的數(shù)據(jù)的副本,否則獲取或計算這些數(shù)據(jù)將非常昂貴。使用Hazelcast進行緩存。
二十四您是否使用Spring Boot公開了SOAP web服務(wù)端點?
是的。使用Spring Boot公開了要使用的web服務(wù)。使用契約優(yōu)先的方法從wsdl生成類。
Spring引導(dǎo)+ SOAP Web服務(wù)示例
二十五,您如何使用Spring Boot執(zhí)行數(shù)據(jù)庫操作?
Spring引導(dǎo)教程-Spring Data JPA
二十六,如何使用Spring上傳文件?
二十七,如何用Spring Boot實現(xiàn)攔截器?
使用Spring MVC HandlerInterceptor與Spring引導(dǎo)
二十八,如何在Spring Boot下使用schedulers ?
Spring引導(dǎo)任務(wù)調(diào)度程序示例
二十九,您使用過哪些啟動器maven依賴項?
使用過不同的starter依賴項,如spring-boot-starter-activemq依賴項、spring-boot-starter-security依賴項、spring-boot-starter-web依賴項。
這有助于減少依賴項的數(shù)量,并減少版本組合。
三十,什么是CSRF攻擊?如何啟用CSRF對其進行保護?
CSRF代表跨站請求偽造。它是一種攻擊,迫使最終用戶在其當(dāng)前已經(jīng)過身份驗證的web應(yīng)用程序上執(zhí)行不需要的操作。CSRF攻擊專門針對狀態(tài)更改請求,而不是數(shù)據(jù)竊取,因為攻擊者無法看到對偽造請求的響應(yīng)。
三十一,如何使用Spring引導(dǎo)使用表單登錄身份驗證?
Spring引導(dǎo)表單安全登錄Hello World示例
三十二,什么是OAuth2?如何使用Spring Boot實現(xiàn)它?
三十三,GZIP是什么?如何使用Spring Boot實現(xiàn)它?
gzip是一種文件格式,是一種用于文件壓縮和解壓縮的軟件應(yīng)用程序。
三十四,您在Spring引導(dǎo)中使用過集成框架嗎?
已將Apache Camel與Spring引導(dǎo)集成。使用Apache Camel Spring啟動啟動依賴項。
三十五,什么是Apache Freemarker?什么時候使用它而不是JSP?如何與Spring Boot集成?
JSP是為網(wǎng)頁量身定做的,F(xiàn)reemarker模板是一種更通用的模板語言——它可以用來生成html、純文本、電子郵件等。
三十六,你什么時候使用WebSockets?如何使用Spring Boot實現(xiàn)它?
WebSocket是一種計算機通信協(xié)議,通過單個TCP連接提供全雙工通信通道。
WebSocket是雙向的——使用WebSocket客戶端或服務(wù)器都可以發(fā)起發(fā)送消息。
WebSocket是全雙工的——客戶端和服務(wù)器之間的通信是相互獨立的。
單個TCP連接——初始連接使用HTTP,然后將此連接升級為基于套接字的連接。然后,這個單一連接將用于未來的所有通信
輕- WebSocket消息數(shù)據(jù)交換比http輕得多。
Spring Boot + WebSockets的例子
三十七,什么是AOP?如何與Spring Boot一起使用?
在軟件開發(fā)過程中,跨越應(yīng)用程序多個點的功能稱為橫切關(guān)注點。這些橫切關(guān)注點不同于應(yīng)用程序的主要業(yè)務(wù)邏輯。因此,將這些橫切關(guān)注點從業(yè)務(wù)邏輯中分離出來是面向方面編程(AOP)的切入點。
三十八,什么是Apache Kafka?如何與Spring Boot集成?
apache Kafka是一個分布式發(fā)布-訂閱消息傳遞系統(tǒng)。它是一個可伸縮的、容錯的、發(fā)布-訂閱消息傳遞系統(tǒng),使我們能夠構(gòu)建分布式應(yīng)用程序。這是一個Apache頂級項目。Kafka適用于離線和在線的消息消費。
三十九,我們?nèi)绾伪O(jiān)視所有Spring Boot微服務(wù)?
Spring Boot提供了actuator 端點來監(jiān)控單個微服務(wù)的指標(biāo)。這些端點對于獲取關(guān)于應(yīng)用程序的信息非常有幫助,比如應(yīng)用程序是否啟動,它們的組件(如數(shù)據(jù)庫等)是否正常工作。但是,使用actuator 接口的一個主要缺點或困難是,我們必須逐個命中這些接口,以了解應(yīng)用程序的狀態(tài)或健康狀況。假設(shè)微服務(wù)涉及50個應(yīng)用程序,管理員將不得不命中所有50個應(yīng)用程序的actuator 端點。為了幫助我們處理這種情況,我們將使用位于https://github.com/codecentric/springing-boot-admin的開源項目。
它構(gòu)建在Spring Boot Actuator之上,提供了一個web UI,使我們能夠可視化多個應(yīng)用程序的指標(biāo)。
四十,您在Spring引導(dǎo)中使用過Spring Cloud組件嗎?
使用過Netflix Eureka等Spring Cloud組件進行服務(wù)注冊,Ribbon用于負載平衡。
Spring Boot + Cloud Components
Spring Cloud interview Questions
四十一,如何將Spring Boot應(yīng)用程序部署到Pivotal Cloud Foundry(PCF)?
Deploying Spring Boot Application to PCF
四十二,如何將Spring Boot + MySQL應(yīng)用部署到Pivotal Cloud Foundry(PCF)?
Pivotal Cloud Foundry Tutorial - Deploying Spring Boot + MySQL Application to PCF
四十三,如何將Spring Boot + RabbitMQ應(yīng)用部署到Pivotal Cloud Foundry(PCF)?
Pivotal Cloud Foundry Tutorial - Deploying Spring Boot + RabbitMQ Application to PCF
讀者福利
針對于上面的文章我總結(jié)出了互聯(lián)網(wǎng)公司java程序員面試涉及到的絕大部分面試題及答案做成了文檔和架構(gòu)視頻資料免費分享給大家(包括Dubbo、Redis、Netty、zookeeper、Spring cloud、分布式、高并發(fā)等架構(gòu)技術(shù)資料),希望能幫助到您面試前的復(fù)習(xí)且找到一個好的工作,也節(jié)省大家在網(wǎng)上搜索資料的時間來學(xué)習(xí)。
資料獲取方式:加qun群:956011797點擊立即加入 找管理小姐姐免費獲取!
合理利用自己每一分每一秒的時間來學(xué)習(xí)提升自己,不要再用"沒有時間“來掩飾自己思想上的懶惰!趁年輕,使勁拼,給未來的自己一個交代!