淺試仿?mapstruct實現微服務編排框架詳解
微服務編排框架
起始原因 是 我們公司 分布式事務 使用的是 seate 分布式事務框架,現在只在一些小部分使用,因為考慮到seate 對性能 TCP的影響,對事務這塊沒有更多的選擇。我就在想 是不是做一個 微服務 編排框架 來解決這個問題。這里就
開發(fā)背景
- 因為我們是saas 可能A企業(yè)要這個功能,B企業(yè)不要,通過服務編排就可以解決這種情況(還是要受制于業(yè)務的)
- 解決分布式 事務問題,我們涉及到錢的用seate ,其他的用這個框架,能提升性能和TPS
接口的方式
@Component public class AProcessorDemo extends RollbackProcessor { @Override protected void processInternal(ProcessContext context) { System.out.println("a RollBackProcessor " + context.get("id")); } @Override protected void rollback(ProcessContext context) { System.out.println("a rollback RollBackProcessor " + context.get("id")); } }
通過注解的方式
@Component public class AProcessorDemo { @Processor(name="a") protected void processInternal(ProcessContext context) { System.out.println("a RollBackProcessor " + context.get("id")); } @ProcessoRrollback(name="a") protected void rollback(ProcessContext context) { System.out.println("a rollback RollBackProcessor " + context.get("id")); } }
書寫代碼方式的選擇
代碼實現上都可以實現,
選擇接口方式 缺點
- 代碼改動會很大
- node的拆分會根據開發(fā)人員的 水平 得到不同體現
選擇 注解方式
- 代碼可讀性 會降低 因為各種情況都會放在同一個類中
- 和之前代碼的兼容性 比較好,對代碼和抽象的能力 要求降低
我感覺還是先按照 接口方式寫,之前代碼不動,只是新的業(yè)務才這么寫,讓結構清晰,增強抽象的能力。 之后可以用mapStruct 方式優(yōu)化
張小龍說的為客戶/用戶考慮, 到我們這 就是為了開發(fā)人員考慮。這樣能節(jié)省 業(yè)務開發(fā)的改動量
方案選擇
feign
有@FeignClient(name = "provider"),其實不就是 根據注解添加代理么?和我們一樣的功能,是不是可以借鑒下,其實還是反射 拿值 做響應的對應
上生產,通過阿里云監(jiān)控平臺看,8g內存的機器 tps 到200 就會顯示卡在這個BeanUtils 方法上
MapStruct
替換 BeanUtils 復制屬性的新組件,用 生成代理類,set方法賦值 來替換了反射的方式 提升性能,減小內存的使用。這種 也是可以的
方案總結
我們平時學習 學一個技術,其實了解其原理是為了 自己寫組件的時候 ,能用上他們的思路和技術 來達到我們的目的。我個人不是很排斥學習 八股文,可以學到很多的思路 是我們能用上的。但是面試官 別光考八股文
feign 可能是前面第一版會用,等后面的mapStruct demo寫完了 我就升級下版本,讓測試同學幫忙測試下,然后換jar 版本唄
說實話 其實我對這種換jar包的方式 還是比較方案的,之前我都是這么干,但是涉及到改動的地方太多,我現在會從K8s 下手,直接掛 agent,不影響業(yè)務系統
兩個都分析下吧
Feign @FeignClient
主要看 FeignClientsRegistrar registerFeignClients 方法中
BeanDefinition candidateComponent = (BeanDefinition)var21.next(); if (candidateComponent instanceof AnnotatedBeanDefinition) { AnnotatedBeanDefinition beanDefinition = (AnnotatedBeanDefinition)candidateComponent; AnnotationMetadata annotationMetadata = beanDefinition.getMetadata(); Assert.isTrue(annotationMetadata.isInterface(), "@FeignClient can only be specified on an interface"); Map<String, Object> attributes = annotationMetadata.getAnnotationAttributes(FeignClient.class.getCanonicalName()); String name = this.getClientName(attributes); //注冊client 配置到spring 容器 this.registerClientConfiguration(registry, name, attributes.get("configuration")); //注冊動態(tài)代理類到 spring 容器 this.registerFeignClient(registry, annotationMetadata, attributes); }
MapStruct
先實現一個簡易的微服務 編排框架 然后 mapStruct 組件畫圖,然后寫一個demo 升級版本 兼容接口 和 注解 兩種方式
明天去公司 和公司大佬們 聊聊這個組件行不,以上就是淺試仿 mapstruct實現微服務編排框架詳解的詳細內容,更多關于仿 mapstruct微服務編排框架的資料請關注腳本之家其它相關文章!
相關文章
Spring?Boot?配置?Hikari?數據庫連接池的操作代碼
數據庫連接池是一個提高程序與數據庫的連接的優(yōu)化,連接池它主要作用是提高性能、節(jié)省資源、控制連接數、連接管理等操作,這篇文章主要介紹了SpringBoot配置Hikari數據庫連接池,需要的朋友可以參考下2023-09-09阿里資深技術專家:在各階段中3年經驗的java程序員應該具備哪些技術能力
這篇文章主要介紹了阿里資深技術專家:在各階段中3年經驗的java程序員應該具備哪些技術能力,本文給大家列舉了一些內容,大家可以根據自己需要有方法的掌握,感興趣的朋友跟隨小編一起看看吧2020-07-07