**十一、Spring Boot / Spring Cloud**
**104\. 什么是 spring boot?**
在Spring框架這個大家族中,產生了很多衍生框架,比如 Spring、SpringMvc框架等,Spring的核心內容在于控制反轉(IOC)和依賴注入(DI),所謂控制反轉并非是一種技術,而是一種思想,在操作方面是指在spring配置文件中創建,依賴注入即為由spring容器為應用程序的某個對象提供資源,比如 引用對象、常量數據等。
SpringBoot是一個框架,一種全新的編程規范,他的產生簡化了框架的使用,所謂簡化是指簡化了Spring眾多框架中所需的大量且繁瑣的配置文件,所以 SpringBoot是一個服務于框架的框架,服務范圍是簡化配置文件。
**105\. 為什么要用 spring boot?**
* Spring Boot使編碼變簡單
* Spring Boot使配置變簡單
* Spring Boot使部署變簡單
* Spring Boot使監控變簡單
* Spring的不足
**106\. spring boot 核心配置文件是什么?**
Spring Boot提供了兩種常用的配置文件:
* properties文件
* yml文件
**107\. spring boot 配置文件有哪幾種類型?它們有什么區別?**
Spring Boot提供了兩種常用的配置文件,分別是properties文件和yml文件。相對于properties文件而言,yml文件更年輕,也有很多的坑。可謂成也蕭何敗蕭何,yml通過空格來確定層級關系,使配置文件結構跟清晰,但也會因為微不足道的空格而破壞了層級關系。
**108\. spring boot 有哪些方式可以實現熱部署?**
SpringBoot熱部署實現有兩種方式:
**①. 使用spring loaded**
在項目中添加如下代碼:
~~~
<build>
~~~
添加完畢后需要使用mvn指令運行:
首先找到IDEA中的Edit configurations ,然后進行如下操作:(點擊左上角的"+",然后選擇maven將出現右側面板,在紅色劃線部位輸入如圖所示指令,你可以為該指令命名(此處命名為MvnSpringBootRun))

點擊保存將會在IDEA項目運行部位出現,點擊綠色箭頭運行即可

**②. 使用spring-boot-devtools**
在項目的pom文件中添加依賴:
~~~
?<!--熱部署jar-->
~~~
然后:使用 shift+ctrl+alt+"/" (IDEA中的快捷鍵) 選擇"Registry" 然后勾選?compiler.automake.allow.when.app.running
**109\. jpa 和 hibernate 有什么區別?**
* JPA Java Persistence API,是Java EE 5的標準ORM接口,也是ejb3規范的一部分。
* Hibernate,當今很流行的ORM框架,是JPA的一個實現,但是其功能是JPA的超集。
* JPA和Hibernate之間的關系,可以簡單的理解為JPA是標準接口,Hibernate是實現。那么Hibernate是如何實現與JPA的這種關系的呢。Hibernate主要是通過三個組件來實現的,及hibernate-annotation、hibernate-entitymanager和hibernate-core。
* hibernate-annotation是Hibernate支持annotation方式配置的基礎,它包括了標準的JPA annotation以及Hibernate自身特殊功能的annotation。
* hibernate-core是Hibernate的核心實現,提供了Hibernate所有的核心功能。
* hibernate-entitymanager實現了標準的JPA,可以把它看成hibernate-core和JPA之間的適配器,它并不直接提供ORM的功能,而是對hibernate-core進行封裝,使得Hibernate符合JPA的規范。
**110\. 什么是 spring cloud?**
從字面理解,Spring Cloud 就是致力于分布式系統、云服務的框架。
Spring Cloud 是整個 Spring 家族中新的成員,是最近云服務火爆的必然產物。
Spring Cloud 為開發人員提供了快速構建分布式系統中一些常見模式的工具,例如:
* 配置管理
* 服務注冊與發現
* 斷路器
* 智能路由
* 服務間調用
* 負載均衡
* 微代理
* 控制總線
* 一次性令牌
* 全局鎖
* 領導選舉
* 分布式會話
* 集群狀態
* 分布式消息
* ……
使用 Spring Cloud 開發人員可以開箱即用的實現這些模式的服務和應用程序。這些服務可以任何環境下運行,包括分布式環境,也包括開發人員自己的筆記本電腦以及各種托管平臺。
**111\. spring cloud 斷路器的作用是什么?**
在Spring Cloud中使用了Hystrix?來實現斷路器的功能,斷路器可以防止一個應用程序多次試圖執行一個操作,即很可能失敗,允許它繼續而不等待故障恢復或者浪費 CPU 周期,而它確定該故障是持久的。斷路器模式也使應用程序能夠檢測故障是否已經解決,如果問題似乎已經得到糾正,應用程序可以嘗試調用操作。
斷路器增加了穩定性和靈活性,以一個系統,提供穩定性,而系統從故障中恢復,并盡量減少此故障的對性能的影響。它可以幫助快速地拒絕對一個操作,即很可能失敗,而不是等待操作超時(或者不返回)的請求,以保持系統的響應時間。如果斷路器提高每次改變狀態的時間的事件,該信息可以被用來監測由斷路器保護系統的部件的健康狀況,或以提醒管理員當斷路器跳閘,以在打開狀態。
**112\. spring cloud 的核心組件有哪些?**
**①. 服務發現——Netflix Eureka**
一個RESTful服務,用來定位運行在AWS地區(Region)中的中間層服務。由兩個組件組成:Eureka服務器和Eureka客戶端。Eureka服務器用作服務注冊服務器。Eureka客戶端是一個java客戶端,用來簡化與服務器的交互、作為輪詢負載均衡器,并提供服務的故障切換支持。Netflix在其生產環境中使用的是另外的客戶端,它提供基于流量、資源利用率以及出錯狀態的加權負載均衡。
**②. 客服端負載均衡——Netflix Ribbon**
Ribbon,主要提供客戶側的軟件負載均衡算法。Ribbon客戶端組件提供一系列完善的配置選項,比如連接超時、重試、重試算法等。Ribbon內置可插拔、可定制的負載均衡組件。
**③. 斷路器——Netflix Hystrix**
斷路器可以防止一個應用程序多次試圖執行一個操作,即很可能失敗,允許它繼續而不等待故障恢復或者浪費 CPU 周期,而它確定該故障是持久的。斷路器模式也使應用程序能夠檢測故障是否已經解決。如果問題似乎已經得到糾正,應用程序可以嘗試調用操作。
**④. 服務網關——Netflix Zuul**
類似nginx,反向代理的功能,不過netflix自己增加了一些配合其他組件的特性。
**⑤. 分布式配置——Spring Cloud Config**
這個還是靜態的,得配合Spring Cloud Bus實現動態的配置更新。
- 空白目錄
- Java 最常見的 208 道面試題:第一模塊答案
- Java 最常見的 208 道面試題:第二模塊答案
- Java 最常見的 208 道面試題:第三模塊答案
- Java 最常見的 208 道面試題:第四模塊和第五模塊答案
- Java 最常見的 208 道面試題:第六模塊答案
- Java 最常見的 208 道面試題:第七模塊答案
- Java 最常見的 208 道面試題:第八模塊答案
- Java 最常見的 208 道面試題:第九模塊和第十模塊答案
- Java 最常見的 208 道面試題:第十一模塊答案
- Java 最常見的 208 道面試題:第十二模塊答案
- Java 最常見的 208 道面試題:第十三模塊答案
- Java 最常見的 208 道面試題:第十四模塊答案
- Java 最常見的 208 道面試題:第十五模塊答案
- Java 最常見的 208 道面試題:第十六模塊答案
- ava 最常見的 208 道面試題:第十七模塊答案
- Java 最常見的 208 道面試題:第十八模塊答案
- Java 最常見的 208 道面試題:第十九模塊答案
- 關于暑假自學內容