華為云微服務(wù)引擎| 0停機(jī)遷移Nacos? “它”是這樣做的
遷移云環(huán)境****場景
? 微服務(wù)規(guī)模小,使用微服務(wù)引擎CSE成本太高。
? dubbo/Nacos微服務(wù)架構(gòu)改造dubbo-servicecomb接入CSE需要投入的成本高,且社區(qū)dubbo-servicecomb未投入人力維護(hù),可能遇到很多適配問題。
? 僅想使用CSE的治理能力,配置中心仍然使用Nacos,或者后期微服務(wù)整改后使用CSE,但是目前想使用Nacos過渡情況。
? 傾向使用Nacos作為配置中心使用,其它使用華為云的其它組件,如CCE、中間件等。
? 使用Nacos或者想用Nacos的客戶,項(xiàng)目整改比較緊急,調(diào)整框架遷移CSE時(shí)間不夠。
? 想使用Nacos作為配置中心,但是又不想去動(dòng)原有的代碼邏輯。
概述
結(jié)合市場痛點(diǎn),華為云提供托管版Nacos引擎,能幫助客戶免去運(yùn)維Nacos集群的煩惱,更加聚焦業(yè)務(wù)本身的實(shí)現(xiàn),同時(shí)華為云也提供專業(yè)的Nacos專家支持。本文介紹如何將Spring Cloud應(yīng)用從開源Consul無縫遷移至華為云Nacos。
什么是Sermant Agent
Sermant Agent是一種基于JavaAgent的無代理服務(wù)網(wǎng)格技術(shù)。它利用JavaAgent來檢測主機(jī)應(yīng)用程序,并具有增強(qiáng)的服務(wù)治理功能,以解決海量微服務(wù)架構(gòu)中的服務(wù)治理問題。
Sermant Agent處于快速發(fā)展階段,當(dāng)前已支持多種服務(wù)治理能力,包含流量治理、注冊、優(yōu)雅上下線及動(dòng)態(tài)配置能力。
為什么使用Sermant Agent接入
代碼零侵入,配置很簡單
相較于SDK方式接入,基于Sermant Agent的接入會更加快捷高效,配置簡單,且應(yīng)用無需做任何代碼改造,僅需在服務(wù)啟動(dòng)時(shí)附帶Sermant Agent即可動(dòng)態(tài)接入到CSE的Nacos。
支****持多種治理能力
Sermant Agent默認(rèn)集成流量治理能力,當(dāng)前支持熔斷、限流、隔離倉以及重試治理能力,該能力可基于CSE配置中心進(jìn)行配置與發(fā)布。
支持多種注冊中心
Sermant Agent目前支持業(yè)內(nèi)主流的注冊中心,已經(jīng)支持了ServiceComb ServiceCenter、Naocs,Eureka、Zookeeper等正在開發(fā)中。
支持應(yīng)用不停機(jī)遷移
Sermant Agent支持服務(wù)的雙注冊,可根據(jù)配置中心下發(fā)的服務(wù)訂閱策略,動(dòng)態(tài)修改當(dāng)前服務(wù)的訂閱策略,并基于該能力幫助線上應(yīng)用在業(yè)務(wù)不中斷的前提下完成服務(wù)遷移。
不僅如此,Sermant Agent提供優(yōu)雅上下線能力,在服務(wù)重啟、上下線時(shí)提供保障,在保護(hù)服務(wù)的同時(shí),規(guī)避服務(wù)下線時(shí)可能存在的流量丟失問題。
接入原理
當(dāng)然,在說明原理之前,我們首先需要了解什么是Java Agent。
Java Agent是在JDK1.5之后引入的新特性,它支持JVM將字節(jié)碼文件讀入內(nèi)存之后,JVM使用對應(yīng)的字節(jié)流在Java堆中生成一個(gè)Class對象之前,用戶可以對其字節(jié)碼進(jìn)行修改的能力,JVM使用修改之后的字節(jié)碼進(jìn)行Class對象的創(chuàng)建,從而實(shí)現(xiàn)Java應(yīng)用的非代碼侵入的業(yè)務(wù)邏輯修改和替換。
Sermant Agent正是基于動(dòng)態(tài)修改字節(jié)碼的技術(shù),在服務(wù)啟動(dòng)時(shí),動(dòng)態(tài)增強(qiáng)原服務(wù)的注冊邏輯。那Sermant Agent是如何在不修改代碼的前提下接入Nacos呢?主要流程如下:
包含以下6個(gè)步驟:
- 首先服務(wù)攜帶Sermant Agent啟動(dòng);
- 服務(wù)啟動(dòng)時(shí),針對服務(wù)執(zhí)行字節(jié)碼增強(qiáng)操作(基于Java Agent的字節(jié)碼增強(qiáng)),主要針對注冊與配置兩塊,在步驟3-5體現(xiàn);
- 通過字節(jié)碼增強(qiáng),動(dòng)態(tài)識別原應(yīng)用的注冊中心;
- 注入啟動(dòng)配置,動(dòng)態(tài)關(guān)閉原應(yīng)用的注冊中心自動(dòng)配置邏輯;
- 隨后通過Spring的SpringFactory機(jī)制注入基于Spring Cloud實(shí)現(xiàn)的注冊Nacos的自動(dòng)配置類,由Spring接管;
- 當(dāng)應(yīng)用發(fā)起注冊時(shí),會通過步驟5注入的注冊邏輯向CSE的Nacos發(fā)起注冊,最終完成接入。
簡單零代碼修改,輕松接入CSE的Nacos
接入場景分為虛機(jī)接入和容器接入,大家可以根據(jù)自身需求選擇合適的接入方式。
虛機(jī)場景接入CSE的Nacos
虛機(jī)部署的應(yīng)用可通過Sermant Agent接入到CSE的Nacos。
基于ECS將應(yīng)用接入CSE的Nacos流程
容器場景接入CSE的Nacos
容器部署的應(yīng)用可通過Sermant Injector自動(dòng)掛載Sermant Agent,從而通過Sermant Agent接入到CSE的Nacos。
基于CCE將應(yīng)用接入CSE的Nacos流程
審核編輯 黃昊宇
-
華為云
+關(guān)注
關(guān)注
3文章
2391瀏覽量
17244
發(fā)布評論請先 登錄
相關(guān)推薦
評論