碼猿慢病云管理系統中其實高并發的場景不是很多,沒有必要每個接口都去考慮并發高的場景,比如添加住院患者的這個接口,具體的業務代碼就不貼了,業務偽代碼如下:
圖片
上述代碼有問題嗎?誰能說有問題?一般情況下是沒什么問題,但是在高并發的場景下肯定是存在問題,為什么?
因為有事務的隔離性,step1這個階段對住院號的校驗肯定是存在問題的,在高并發的場景下無法保證這里的校驗一定準確。
其實這個接口的并發并不高,在碼猿慢病云管理系統中一般不會出現這種問題,那么什么時候會出現呢?
醫院中大部分是內網+外網,如果由于網絡的抖動,系統請求響應的時間延遲,這樣會導致醫護操作時會出現重復點擊的情況,比如1秒中之內由于第一次點添加患者這個按鈕沒反應,往往護士都會重復點擊,這種情況下是會出現問題。
這里我們就暫且不談對單個接口的冪等優化了,要想一個方案全局解決這個問題,在碼猿慢病云管理系統中其實只要保證這種并發不高的接口在一定時間段內保證冪等即可,比如5秒之內,這樣在5秒之內護士重復點擊就沒事。
在碼猿慢病云管理系統中新增了一個注解:@RepeatSubmit,代碼如下:
圖片
只需要將該注解標注在新增、修改、刪除接口上就能保證在默認的5秒之內接口冪等。
比如新增住院患者這個接口:
圖片
那么原理是什么?其實很簡單,先來說下原理,再介紹具體的實現:
上述6個步驟中其實只有一點比較難實現的,其他的都是基本操作,就是獲取這個請求參數,下面將詳細介紹一下如何獲取這個請求參數。
對于form-data的入參只需要調用HttpServletRequest的API讀取,但是對于@RequestBody標注的入參是通過IO流讀取數據,且IO流只能被讀取一次,如果在AOP中讀取了,那么在接口層面的入參讀取肯定是有問題,報錯如下:
圖片
解決方案也很簡單,只需要保證IO流能夠多次讀取即可,下面就來介紹一下方案。
這里我們可以利用裝飾者模式對 HttpServletRequest 的功能進行增強,具體做法也很簡單,我們重新定義一個 HttpServletRequest:
圖片
圖片
這段代碼并不難,很好懂。
首先在構造 RepeatedlyRequestWrapper 的時候,就通過 IO 流將數據讀取出來并存入到一個 byte 數組中,然后重寫 getReader 和 getInputStream 方法,在這兩個讀取 IO 流的方法中,都從 byte 數組中返回 IO 流數據出來,這樣就實現了反復讀取了。
接下來我們定義一個過濾器,讓這個裝飾后的 Request 生效:
圖片
判斷一下,如果請求數據類型是 JSON 的話,就把 HttpServletRequest “偷梁換柱”改為 HttpRequestWrapper,然后讓過濾器繼續往下走。
這樣就可以配置后就可以在程序中反復讀取參數了!
解決了參數讀取的問題,下面就可以輕松實現這個防重注解了,首先定義注解com.code.ape.codeape.common.security.annotation.RepeatSubmit:
圖片
接下來直接用AOP實現,com.code.ape.codeape.common.security.component.CodeapeRepeatSubmitAspect代碼如下:
圖片
圖片
邏輯很簡單,上述已經介紹過完整的流程,這里需要注意的是參數的讀取,代碼如下:
圖片
其實就是將request判斷下是否是經過過濾器封裝后的HttpRequestWrapper對象,如果是的話則是@RequestBody入參,直接從IO流中讀取。
本節內容介紹了防重注解@RepeatSubmit的實現原理,后續開發中只需要在非查詢接口中添加這個注解就能保證在一定時間內防止重復提交。
碼猿慢病云管理系統已經在星球中陸續更新,目前更新內容如下:
前言 01 項目架構+業務介紹 02 三方組件介紹 03 服務端項目部署 04 前端項目部署 05 多租戶架構設計 06 醫療系統中的權限如何設計? 07 項目搭建 08 關掉驗證碼登錄 09 開發平臺自動生成業務代碼認證鑒權 01 認證登錄生成token 02 token檢驗、鑒權 03 token有效期設置 04 刷新token 05 檢查token 06 服務中如何獲取當前登錄用戶信息? 07 接口對外暴露 08 接口只允許內部調用怎么處理? 09 如何實現token中繼? 10 當前登錄用戶身份信息如何異步傳遞? 11 科室權限如何定一個注解自動注入? 12 一個注解防止接口重復提交業務 01 科室管理 02 醫院管理 03 角色管理
本文鏈接:http://www.tebozhan.com/showinfo-26-146-0.html一個注解實現接口冪等,這樣才優雅!
聲明:本網頁內容旨在傳播知識,若有侵權等問題請及時與本網聯系,我們將在第一時間刪除處理。郵件:2376512515@qq.com
上一篇: 從零到英雄:高并發與性能優化的神奇之旅