[發明專利]服務調用記錄方法、裝置、計算機設備和存儲介質有效
| 申請號: | 201910578080.1 | 申請日: | 2019-06-28 |
| 公開(公告)號: | CN110290212B | 公開(公告)日: | 2020-06-23 |
| 發明(設計)人: | 季延彬 | 申請(專利權)人: | 浙江大搜車軟件技術有限公司 |
| 主分類號: | H04L29/08 | 分類號: | H04L29/08;H04L29/06 |
| 代理公司: | 杭州華進聯浙知識產權代理有限公司 33250 | 代理人: | 雷志剛 |
| 地址: | 310000 浙江省杭州市余*** | 國省代碼: | 浙江;33 |
| 權利要求書: | 查看更多 | 說明書: | 查看更多 |
| 摘要: | |||
| 搜索關鍵詞: | 服務 調用 記錄 方法 裝置 計算機 設備 存儲 介質 | ||
1.一種服務調用記錄方法,所述方法包括:
獲取檢測到的調用服務的調用類型;
啟用與所述調用類型對應的動態代理,通過所述動態代理攔截所述調用服務的服務調用數據;
從所述服務調用數據中提取出調用方法,判斷所述調用方法是否屬于所述動態代理的目標監控方法;
當判定出所述調用方法屬于所述目標監控方法時,根據所述動態代理中的增強探針從所述服務調用數據中提取目標監控數據,將所述目標監控數據進行記錄。
2.根據權利要求1所述的方法,其特征在于,所述獲取檢測到的調用服務的調用類型之前,還包括:
當檢測到程序啟動時,從所述程序的實例配置文件中解析出注解信息;
獲取所述注解信息所標識的屬性類型,創建與所述屬性類型對應的動態代理;
從所述注解信息中提取增強參數,根據所述增強參數創建增強探針,在所述動態代理中配置所述增強探針。
3.根據權利要求2所述的方法,其特征在于,所述方法還包括:
接收服務監控需求信息;
從所述服務監控需求信息中提取目標服務和監控對象參數;
根據所述監控對象參數生成注解信息,將所述注解信息添加至所述目標服務對應的實例代碼中。
4.根據權利要求3所述的方法,其特征在于,所述根據所述監控對象參數生成注解信息,將所述注解信息添加至所述目標服務對應的實例代碼中,包括:
當所述目標服務為正向調用類型時,從所述監控對象參數中提取出屬性類型,生成與所述屬性類型對應的屬性注解;
從所述監控對象參數中提取出方法參數、增強參數及業務標識字段,根據所述方法參數、所述增強參數和所述業務標識字段生成方法注解;
將所述方法注解添加至所述屬性注解中,并將所述屬性注解添加至所述目標服務對應的實例代碼的屬性字段中。
5.根據權利要求3所述的方法,其特征在于,所述根據所述監控對象參數生成注解信息,將所述注解信息添加至所述目標服務對應的實例代碼中,包括:
當所述目標服務為反向調用類型時,從所述監控對象參數中提取出增強對象、增強參數及業務標識字段;
根據所述增強參數和所述業務標識字段生成類注解或方法注解;
將所述類注解或所述方法注解添加至所述目標服務對應的實例代碼的所述增強對象中。
6.根據權利要求1所述的方法,其特征在于,所述將所述目標監控數據進行記錄,包括:
根據所述動態代理中的業務標識字段從所述服務調用數據中提取業務標識;
將所述業務標識與所述目標監控數據進行關聯生成監控記錄;
查找所述業務標識對應的數據格式,根據所述數據格式對所述監控記錄進行調整,并將調整后的所述監控記錄添加于監控日志中。
7.一種服務調用記錄裝置,其特征在于,所述裝置包括:
類型獲取模塊,用于獲取檢測到的調用服務的調用類型;
代理攔截模塊,用于啟用與所述調用類型對應的動態代理,通過所述動態代理攔截所述調用服務的服務調用數據;
方法判定模塊,用于從所述服務調用數據中提取出調用方法,判斷所述調用方法是否屬于所述動態代理的目標監控方法;
監控記錄模塊,用于當判定出所述調用方法屬于所述目標監控方法時,根據所述動態代理中的增強探針從所述服務調用數據中提取目標監控數據,將所述目標監控數據進行記錄。
8.根據權利要求7所述的裝置,其特征在于,所述裝置還包括:
注解解析模塊,用于當檢測到程序啟動時,從所述程序的實例配置文件中解析出注解信息;
代理創建模塊,用于獲取所述注解信息所標識的屬性類型,創建與所述屬性類型對應的動態代理;
探針配置模塊,用于從所述注解信息中提取增強參數,根據所述增強參數創建增強探針,在所述動態代理中配置所述增強探針。
該專利技術資料僅供研究查看技術是否侵權等信息,商用須獲得專利權人授權。該專利全部權利屬于浙江大搜車軟件技術有限公司,未經浙江大搜車軟件技術有限公司許可,擅自商用是侵權行為。如果您想購買此專利、獲得商業授權和技術合作,請聯系【客服】
本文鏈接:http://www.szxzyx.cn/pat/books/201910578080.1/1.html,轉載請聲明來源鉆瓜專利網。





