前言
為什么要使用微服務(wù)?
隨著互聯(lián)網(wǎng)的快速發(fā)展,各行各業(yè)都在用互聯(lián)網(wǎng)?;ヂ?lián)網(wǎng)已經(jīng)離不開人們的形形×××。隨著越來越多的用戶,業(yè)務(wù)場(chǎng)景也愈來愈復(fù)雜。
傳統(tǒng)的單體架構(gòu)已經(jīng)很難滿足互聯(lián)網(wǎng)技術(shù)發(fā)展的要求,代碼可維護(hù)性擴(kuò)展性和可讀性降低,維護(hù)成本的提高都是驅(qū)動(dòng)微服務(wù)的發(fā)展趨勢(shì)。
創(chuàng)新互聯(lián)是一家專業(yè)提供拉孜企業(yè)網(wǎng)站建設(shè),專注與網(wǎng)站建設(shè)、成都網(wǎng)站制作、H5開發(fā)、小程序制作等業(yè)務(wù)。10年已為拉孜眾多企業(yè)、政府機(jī)構(gòu)等服務(wù)。創(chuàng)新互聯(lián)專業(yè)網(wǎng)站制作公司優(yōu)惠進(jìn)行中。
Dubbo,是阿里巴巴服務(wù)化治理的核心框架,并被廣泛應(yīng)用于阿里巴巴集團(tuán)的各成員站
點(diǎn)。阿里巴巴近幾年對(duì)開源社區(qū)的貢獻(xiàn)不論在國(guó)內(nèi)還是國(guó)外都是引人注目的,比如:
JStorm 捐贈(zèng)給 Apache 并加入 Apache 基金會(huì)等,為中國(guó)互聯(lián)網(wǎng)人爭(zhēng)足了面子,使得阿
里巴巴在國(guó)人眼里已經(jīng)從電商升級(jí)為一家科技公司了。
Spring Cloud,從命名我們就可以知道,它是 Spring Source 的產(chǎn)物,Spring 社區(qū)的強(qiáng)
大背書可以說是 Java 企業(yè)界最有影響力的組織了,除了 Spring Source 之外,還有
Pivotal 和 Netfix 是其強(qiáng)大的后盾與技術(shù)輸出。其中 Netflix 開源的整套微服務(wù)架構(gòu)套件是
Spring Cloud 的核心。
首先需要有處理網(wǎng)絡(luò)連接通訊的模塊,負(fù)責(zé)連接建立、管理和消息的傳輸。其次需要有編
解碼的模塊,因?yàn)榫W(wǎng)絡(luò)通訊都是傳輸?shù)淖止?jié)碼,需要將我們使用的對(duì)象序列化和反序列
化。剩下的就是客戶端和服務(wù)器端的部分,服務(wù)器端暴露要開放的服務(wù)接口,客戶調(diào)用服
務(wù)接口的一個(gè)代理實(shí)現(xiàn),這個(gè)代理實(shí)現(xiàn)負(fù)責(zé)收集數(shù)據(jù)、編碼并傳輸給服務(wù)器然后等待結(jié)果
返回。
dubbo 作為 rpc 框架,實(shí)現(xiàn)的效果就是調(diào)用遠(yuǎn)程的方法就像在本地調(diào)用一樣。如何做到
呢?就是本地有對(duì)遠(yuǎn)程方法的描述,包括方法名、參數(shù)、返回值,在 dubbo 中是遠(yuǎn)程和本
地使用同樣的接口;然后呢,要有對(duì)網(wǎng)絡(luò)通信的封裝,要對(duì)調(diào)用方來說通信細(xì)節(jié)是完全不
可見的,網(wǎng)絡(luò)通信要做的就是將調(diào)用方法的屬性通過一定的協(xié)議(簡(jiǎn)單來說就是消息格
式)傳遞到服務(wù)端;服務(wù)端按照協(xié)議解析出調(diào)用的信息;執(zhí)行相應(yīng)的方法;在將方法的返
回值通過協(xié)議傳遞給客戶端;客戶端再解析;在調(diào)用方式上又可以分為同步調(diào)用和異步調(diào)
用;簡(jiǎn)單來說基本就這個(gè)過程
Spring Boot 的優(yōu)點(diǎn)有:
減少開發(fā),測(cè)試時(shí)間和努力。
使用 JavaConfig 有助于避免使用 XML。
避免大量的 Maven 導(dǎo)入和各種版本沖突。
提供意見發(fā)展方法。
通過提供默認(rèn)值快速開始開發(fā)。
沒有單獨(dú)的 Web 服務(wù)器需要。這意味著你不再需要啟動(dòng) Tomcat,Glassfish 或其他任何東
西。
需要更少的配置 因?yàn)闆]有 web.xml 文件。只需添加用@ Configuration 注釋的類,然后添加
用@Bean 注釋的方法,Spring 將自動(dòng)加載對(duì)象并像以前一樣對(duì)其進(jìn)行管理。您甚至可以將
@Autowired 添加到 bean 方法中,以使 Spring 自動(dòng)裝入需要的依賴關(guān)系中。
基于環(huán)境的配置 使用這些屬性,您可以將您正在使用的環(huán)境傳遞到應(yīng)用程序:-
Dspring.profiles.active = {enviornment}。在加載主應(yīng)用程序?qū)傩晕募螅琒pring 將在
(application{environment} .properties)中加載后續(xù)的應(yīng)用程序?qū)傩晕募?br/>如何實(shí)現(xiàn) Spring Boot 應(yīng)用程序的安全性?
為了實(shí)現(xiàn) Spring Boot 的安全性,我們使用 spring-boot-starter-security 依賴項(xiàng),并且必須添
加安全配置。它只需要很少的代碼。配置類將必須擴(kuò)展 WebSecurityConfigurerAdapter 并覆
蓋其方法。
如何集成 Spring Boot 和 ActiveMQ?
對(duì)于集成 Spring Boot 和 ActiveMQ,我們使用
spring-boot-starter-activemq
依賴關(guān)系。 它只需要很少的配置,并且不需要樣板代碼。
什么是 Swagger?你用 Spring Boot 實(shí)現(xiàn)了它嗎?
Swagger 廣泛用于可視化 API,使用 Swagger UI 為前端開發(fā)人員提供在線沙箱。Swagger 是
用于生成 RESTful Web 服務(wù)的可視化表示的工具,規(guī)范和完整框架實(shí)現(xiàn)。它使文檔能夠以
與服務(wù)器相同的速度更新。當(dāng)通過 Swagger 正確定義時(shí),消費(fèi)者可以使用最少量的實(shí)現(xiàn)邏
輯來理解遠(yuǎn)程服務(wù)并與其進(jìn)行交互。因此,Swagger 消除了調(diào)用服務(wù)時(shí)的猜測(cè)。
使用 Spring Boot 開發(fā)分布式微服務(wù)時(shí),我們面臨以下問題
與分布式系統(tǒng)相關(guān)的復(fù)雜性-這種開銷包括網(wǎng)絡(luò)問題,延遲開銷,帶寬問題,安全問題。
服務(wù)發(fā)現(xiàn)-服務(wù)發(fā)現(xiàn)工具管理群集中的流程和服務(wù)如何查找和互相交談。它涉及一個(gè)服務(wù)目錄,在該目錄中注冊(cè)服務(wù),然后能夠查找并連接到該目錄中的服務(wù)。
冗余-分布式系統(tǒng)中的冗余問題。
負(fù)載平衡 --負(fù)載平衡改善跨多個(gè)計(jì)算資源的工作負(fù)荷,諸如計(jì)算機(jī),計(jì)算機(jī)集群,網(wǎng)絡(luò)鏈路,中央處理單元,或磁盤驅(qū)動(dòng)器的分布。
性能-問題 由于各種運(yùn)營(yíng)開銷導(dǎo)致的性能問題。
部署復(fù)雜性-Devops 技能的要求。
在計(jì)算中,負(fù)載平衡可以改善跨計(jì)算機(jī),計(jì)算機(jī)集群,網(wǎng)絡(luò)鏈接,中央處理單元或磁盤驅(qū)動(dòng)器等多種計(jì)算
資源的工作負(fù)載分布。負(fù)載平衡旨在優(yōu)化資源使用,最大化吞吐量,最小化響應(yīng)時(shí)間并避免任何單一資源
的過載。使用多個(gè)組件進(jìn)行負(fù)載平衡而不是單個(gè)組件可能會(huì)通過冗余來提高可靠性和可用性。負(fù)載平衡通常涉及專用軟件或硬件,例如多層交換機(jī)或域名系統(tǒng)服務(wù)器進(jìn)程。
什么是 Netflix Feign?它的優(yōu)點(diǎn)是什么?
Feign 是受到 Retrofit,JAXRS-2.0 和 WebSocket 啟發(fā)的 java 客戶端聯(lián)編程序。Feign 的第一個(gè)目標(biāo)
是將約束分母的復(fù)雜性統(tǒng)一到 http apis,而不考慮其穩(wěn)定性。在 employee-consumer 的例子中,我們
使用了 employee-producer 使用 REST 模板公開的 REST 服務(wù)。
但是我們必須編寫大量代碼才能執(zhí)行以下步驟
使用功能區(qū)進(jìn)行負(fù)載平衡。
獲取服務(wù)實(shí)例,然后獲取基本 URL。
利用 REST 模板來使用服務(wù)。 前面的代碼如下
@Controller
public class ConsumerControllerClient {
@Autowired
private LoadBalancerClient loadBalancer;
public void getEmployee() throws RestClientException, IOException {
ServiceInstance serviceInstance=loadBalancer.choose("employee-producer");
System.out.println(serviceInstance.getUri());
String baseUrl=serviceInstance.getUri().toString();
baseUrl=baseUrl+"/employee";
RestTemplate restTemplate = new RestTemplate();
ResponseEntity<String> response=null;
try{
response=restTemplate.exchange(baseUrl,
HttpMethod.GET, getHeaders(),String.class);
}catch (Exception ex)
{
System.out.println(ex);
}
System.out.println(response.getBody());
}
之前的代碼,有像 NullPointer 這樣的例外的機(jī)會(huì),并不是最優(yōu)的。我們將看到如何使用 Netflix Feign使呼叫變得更加輕松和清潔。如果 Netflix Ribbon 依賴關(guān)系也在類路徑中,那么 Feign 默認(rèn)也會(huì)負(fù)責(zé)負(fù)載平衡。
喜歡文章記得點(diǎn)個(gè)贊,感謝支持!
標(biāo)題名稱:10道面試官喜歡問的微服務(wù)面試題SpringCloud+SpringBoot
本文路徑:http://aaarwkj.com/article2/godsic.html
成都網(wǎng)站建設(shè)公司_創(chuàng)新互聯(lián),為您提供網(wǎng)站導(dǎo)航、小程序開發(fā)、App開發(fā)、用戶體驗(yàn)、定制開發(fā)、手機(jī)網(wǎng)站建設(shè)
聲明:本網(wǎng)站發(fā)布的內(nèi)容(圖片、視頻和文字)以用戶投稿、用戶轉(zhuǎn)載內(nèi)容為主,如果涉及侵權(quán)請(qǐng)盡快告知,我們將會(huì)在第一時(shí)間刪除。文章觀點(diǎn)不代表本網(wǎng)站立場(chǎng),如需處理請(qǐng)聯(lián)系客服。電話:028-86922220;郵箱:631063699@qq.com。內(nèi)容未經(jīng)允許不得轉(zhuǎn)載,或轉(zhuǎn)載時(shí)需注明來源: 創(chuàng)新互聯(lián)