基于jvm-sandbox的imock開發(fā)指南詳解
需求
- 支持java后端服務(wù)方法級別的mock,對沒有測試環(huán)境的第三方服務(wù)進行mock,增加團隊覆蓋率。
- 啟用,返回用戶自定義的mock響應(yīng)結(jié)果
- 停用,返回服務(wù)本身的結(jié)果
通過一系列調(diào)研,最終工具選型了基于 jvm-sandbox的mock服務(wù),是Java方法級別的mock,操作就是監(jiān)聽指定方法,返回指定的mock內(nèi)容。
1、項目介紹
imock 包含mock-module、mock-web ,mock-module就是jvm-sandbox的模塊,需要安裝到目標應(yīng)用服務(wù)器,mock-web 為mock服務(wù)后臺,imock是前后端分離,還有一個前端react 項目 imcok-web
ume_mock_backend :http://git1.local.umetrip.com/guanhongli/ume_mock_backend
ume_mock_frontend :http://git1.local.umetrip.com/guanhongli/ume_mock_frontend
2、imock使用
首先將前后端項目都跑起來,安裝依賴啥的先把環(huán)境調(diào)通。
2.1、啟動imock-web
本地環(huán)境:直接idea啟動即可
容器環(huán)境:java -jar啟動
nohup?java?-jar?/opt/applog/MskyLog/mock/mock-web.jar?>?myout.txt?2>&1?&
2.2、準備mock-module
2.2.0.本地安裝
到項目下的bin目錄執(zhí)行 install-local.sh,通過腳本編譯mock-module,如需修改代碼要重新執(zhí)行此腳本。
2.2.1.修改cfg
#?心跳上報配置??當環(huán)境變量沒有配置的時候使用?該配置 #?mock?服務(wù)的地址和端口 mock.host=http://172.24.146.219:8003 #?標識目標應(yīng)用的名稱 app.name=test-umeapp-checkin #?標識目標應(yīng)用的環(huán)境 app.env=test-umeapp-checkin
2.2.2.拷貝到sandbox-module目錄
將cfg和mock-module拷貝到sandbox/sandbox-module目錄下。
cd?/opt/applog/MskyLog/mock cp?/opt/applog/MskyLog/mock/mock-module.jar??/opt/app/sandbox/sandbox-module cp?-r?/opt/applog/MskyLog/mock/cfg??/opt/app/sandbox/sandbox-module
2.2.3.拷貝到.sandbox-module目錄
cp?/opt/applog/MskyLog/mock/mock-module.jar?/opt/app/.sandbox-module
2.2.4.創(chuàng)建mock日志目錄
mkdir?-p?/home/jboss5/logs/sandbox/mock/
2.3、attch掛載目標應(yīng)用
jps命令查看pid
cd?/opt/app/sandbox/bin/ ./sandbox.sh?-p?22
2.4、查看log
2.4.1、查看sandbox.log
tailf?/opt/applog/MskyLog/sandbox/sandbox.log
2.4.2、查看mock.log
tailf?/home/jboss5/logs/sandbox/mock/mock.log
2.4.3、查看服務(wù)log
結(jié)合log和error日志來看
tailf?/opt/applog/MskyLog/UmeCki/UmeCki_info.log tailf?/opt/applog/MskyLog/UmeCki/UmeCki_trace.log tailf?/opt/applog/MskyLog/UmeCki/UmeCki_err.log
3、遇到的問題
3.1、mock切面問題,增加before返回
看代碼mock邏輯是在afterReturning中實現(xiàn)的,這樣的話是不是原代碼邏輯還是會執(zhí)行,只是修改了返回給調(diào)用方的Object或者Exception。比如我想mock調(diào)用銀行支付邏輯,但是還是會實際支付,所以切面放在before(Advice advice)并且結(jié)合returnImmediately會不會效果更好。
作者的代碼afterReturning方法是通過advice.getReturnObj().getClass()來獲取類,然后把ro.getReturnData()序列化到對象中。
- 如果before方法,則advice.getReturnObj()為空,空指針無法獲取類對象。
- 如果mock方法的值返回為空,則依然無法獲取對象類型。
因此需要換一個方法獲取類對象
使用advice.getTarget()方法來獲取對象類型,使用advice.getBehavior()獲取方法名稱。
Method?method?=?advice.getTarget().getClass().getMethod(advice.getBehavior().getName()); returnType?=?method.getGenericReturnType(); LogUtil.info2("returnType=",?String.valueOf(returnType)); Object?res1?=?JSON.parseObject(ro.getReturnData(),?returnType); LogUtil.info2("res1=",?res1.toString());
但經(jīng)過測試只有springboot可以用,dubbo接口advice.getTarget()為空。
在 Dubbo 中,advice.getTarget()
返回 null
可能是由于 Dubbo 的代理機制導(dǎo)致的。Dubbo 使用代理對象來實現(xiàn)遠程服務(wù)的調(diào)用,代理對象是在運行時動態(tài)生成的,而真正的目標對象是通過 Dubbo 的遠程調(diào)用機制獲取的。因此,在 Dubbo 的 Advice 中,advice.getTarget()
返回的是代理對象,而不是真正的目標對象。由于代理對象并不是目標對象本身,因此可能返回 null
。
在 Spring Boot 中,advice.getTarget()
返回的是目標對象,因為 Spring Boot 使用的代理機制與 Dubbo 不同。Spring Boot 中的 AOP 代理通常是通過 JDK 動態(tài)代理或 CGLIB 生成的,這些代理對象會保留對目標對象的引用,因此在 Advice 中調(diào)用 advice.getTarget()
可以獲取到目標對象的引用,不會返回 null
。
接著找其他的辦法。。。
通過advice.getBehavior().getReturnType()
Method?method?=?advice.getBehavior().getReturnType().getMethod(advice.getBehavior().getName());
完美解決!
//?獲取方法的返回對象類型 Object?res1?=?JSON.parseObject(ro.getReturnData(),?advice.getBehavior().getReturnType()); LogUtil.info2("res1=",?res1.toString());
3.2、報錯time字段不為空
解決辦法:修改數(shù)據(jù)庫讓字段可以為空。
3.3、imock-web
java.lang.TypeNotPresentException: Type org.springframework.boot.maven.RepackageMojo not present
后續(xù)
至此,通過本地調(diào)試,二次開發(fā)imock已經(jīng)能夠符合我們公司的需求,后續(xù)再針對個性化的需求進行開發(fā),更多關(guān)于jvm-sandbox imock開發(fā)的資料請關(guān)注腳本之家其它相關(guān)文章!
相關(guān)文章
springboot整合springsecurity與mybatis-plus的簡單實現(xiàn)
Spring Security基于Spring開發(fā),項目中如果使用Spring作為基礎(chǔ),配合Spring Security做權(quán)限更加方便,而Shiro需要和Spring進行整合開發(fā)。因此作為spring全家桶中的Spring Security在java領(lǐng)域很常用2021-10-10Java發(fā)送http請求的示例(get與post方法請求)
這篇文章主要介紹了Java發(fā)送http請求的示例(get與post方法請求),幫助大家更好的理解和使用Java,感興趣的朋友可以了解下2021-01-01java在linux系統(tǒng)下開機啟動無法使用sudo命令的原因及解決辦法
每次開機自動啟動的java進程,頁面上的關(guān)機按鈕都無法實現(xiàn)關(guān)機功能,但是此時如果以chb賬號通過ssh登錄該服務(wù)器,手動殺掉tomcat進程,然后再重新啟動tomcat,頁面上的關(guān)機按鈕就有效了2013-08-08Mybatis日志配置方式(slf4j、log4j、log4j2)
這篇文章主要介紹了Mybatis日志配置方式(slf4j、log4j、log4j2),具有很好的參考價值,希望對大家有所幫助,如有錯誤或未考慮完全的地方,望不吝賜教2023-09-09idea 訪問html頁面端口號顯示的是63342而不是8080
這篇文章主要介紹了idea 訪問html頁面端口號顯示的是63342而不是8080,文中通過示例代碼介紹的非常詳細,對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧2020-08-08