游戏电视苹果数码历史美丽
投稿投诉
美丽时装
彩妆资讯
历史明星
乐活安卓
数码常识
驾车健康
苹果问答
网络发型
电视车载
室内电影
游戏科学
音乐整形

微服务分布式架构中,如何高效收集请求响应日志

  本文主要讲述了springcloud微服务使用Feign作为微服务间的通讯框架的情况下,如何配置统一的日志打印,能更直观地在日志中收集有效信息。
  (以下只提供了核心代码截图,详细代码可通过github、gitee仓库查看,文末附代码目录)一、单体服务请求响应日志收集
  1。利用Filter打印请求日志
  2。利用ResponseBodyAdvice打印响应日志
  3。使用postman请求API
  【日志打印效果】(因为log。info是在chain。doFilter之后执行的,所以这里请求日志在后)22:58:23。365〔16582427033635607〕〔httpnio6001exec3〕INFOLogResponseBodyAdvice。beforeBodyWrite〔32〕{code:0,message:成功,data:2022071922:58:23}22:58:23。368〔16582427033635607〕〔httpnio6001exec3〕INFORequestFilter。doFilterInternal〔52〕GET192。168。31。158apitimeheader:{xplatform:app},param:{a:1},body:{b:bb},4ms
  可支持各种请求数据打印(包括请求头、url参数、bodyform参数、bodyraw参数、响应数据)二、微服务请求响应日志收集(基于Feign)
  Feign是一个基于http封装的通讯框架,但因为调用方式的不同,所以在日志的搜集上需要做些额外的操作补充一下日志
  比如当前服务调用user服务的某个Feign接口,user服务集群部署在3台机器上,我想快速知道当前服务调用的下一个节点是那台机器
  1。自定义一个FeignIPClient继承Client。Default,重写execute方法,增加1个日志的打印
  同时我还想知道当前服务调用Feign的请求参数和响应结果
  2。增加1个FeignClient注解的切面,因为Feign的调用就相当于是方法的调用,可以利用AOP的方式来做增强
  同时我还希望Feign调用过程中,可以把当前服务的请求头的内容传递给下一个服务(比如一些公共的请求头,用户ID,链路追踪日志ID等)
  3。利用Feign提供的拦截器RequestInterceptor,在Feign请求发起前往RequestTemplate设置header就OK了
  【当前服务的日志】23:33:50。365〔16582448303481157〕〔hystrixtemplateuser10〕INFOFeignIPClient。execute〔42〕13msGEThttp:192。168。31。158:8002usergetById?id123:33:50。370〔16582448303481157〕〔httpnio6001exec3〕INFOFeignCostTimeAspect。feignCostTime〔30〕requestfeign:UserFeign。getById,mills:19,args:〔1〕,result:{code:0,message:成功,data:{id:1,name:adasd,status:2,statusDesc:冻结}}23:33:50。373〔16582448303481157〕〔httpnio6001exec3〕INFOLogResponseBodyAdvice。beforeBodyWrite〔32〕{code:0,message:成功,data:{id:1,name:adasd,status:2,statusDesc:冻结}}23:33:50。377〔16582448303481157〕〔httpnio6001exec3〕INFORequestFilter。doFilterInternal〔52〕GET192。168。31。158apigetUserByIdheader:{xplatform:app},param:{id:1},body:{},29ms
  【user服务的日志】23:33:50。363〔16582448303481157〕〔httpnio8002exec3〕INFOLogResponseBodyAdvice。beforeBodyWrite〔32〕{code:0,message:成功,data:{id:1,name:adasd,status:2,statusDesc:冻结}}23:33:50。366〔16582448303481157〕〔httpnio8002exec3〕INFORequestFilter。doFilterInternal〔52〕GET192。168。31。158usergetByIdheader:{xplatform:app},param:{id:1},body:{},6ms
  【日志说明】
  FeignIPClient。execute
  》所在的日志行打印的是目标主机的IP端口
  FeignCostTimeAspect。feignCostTime
  》所在的日志行打印的是Feign的请求参数和响应结果
  header:{xplatform:app}
  》就是利用RequestInterceptor传递的请求头
  怎么样?如果你觉得有用的话,还不快快搞起!!!
  附:涉及的代码目录
  github:https:github。com897665787springcloudtemplate
  GitHub897665787springcloudtemplate
  gitee:https:gitee。comjqdispringcloudtemplate
  springcloudtemplate:一个基于springcloudnetflix微服务框架,记录了关于微服务开发的一些最佳应用,欢迎大家学习指导。springcloudtemplatetemplateframeworkadviceLogResponseBodyAdvice响应ahrefhttps:www。bs178。comrizhitargetblankclassinfotextkey日志a统一打印aspectFeignCostTimeAspect记录请求Feign接口耗时,打印在调用方ahrefhttps:www。bs178。comrizhitargetblankclassinfotextkey日志aFeignIPClient打印feign请求目标机器信息autoconfigureLoadBalancerFeignClientAutoConfigurationFeignIPClient的自动配置filterRequestFilter请求参数ahrefhttps:www。bs178。comrizhitargetblankclassinfotextkey日志a打印interceptorFeignHeaderInterceptorFeign调用过程中传递header值

1979年,清朝最后一位格格给邓小平写信说请给我工作,后来怎相信不少人对于中国历史上最后一个王朝都是印象深刻的。在这个王朝时期,中国古代历史达到了巅峰,人口也第一次达到了三亿人,国民经济生产总值也是前所未有的发达。康乾盛世也是中国……广东队三消息曝曾繁日已离队,首轮门票售空,朱芳雨可签冯莱曝曾繁日已离队。北京时间2月3日,CBA第二阶段休赛期,广东男篮如期展开集训,根据篮球媒体人昳说体育爆料,广东男篮在休赛期期间,再次做出阵容调整,此前因为腰伤缺席本赛季比……内蒙古包头人怎么样?包头人总体很不错,但是也有一定的不同,尤其几个区的人,都具有不同的特点。一、东河区。大多数东河区的人勤劳善良。但也有一少部分东河区的男人外表光鲜,游手好闲,吃喝玩乐。当地……清明节的故事清明就寓意着天清地明,正是春回大地,万物复苏的最佳时机,作为我国历史悠久的传统节日有着一些有意义的故事。根据史书记载,春秋时期的晋文公还未即位时逃难国外途经荒无人烟的大山……巴勒斯坦到底是不是一个国家?虽然巴勒斯坦已经在1988年宣布建国,并且有一百多个国家和地区承认了巴勒斯坦国,但是从严格意义上来说巴勒斯坦依然只是一个地区名词,而不是一个国家。一个严格意义上的国家,至……持续千年的中世纪罗马一分为二是伏笔,英法百年战争是收官之作很多人都听说过中世纪这个词,可中世纪究竟代表哪个时代,很少有人去了解。其实欧洲的历史,大致上可以划分为3个部分:古典时代、中世纪、近现代。古典时代,指的是古希腊、古罗马时代。具……OPPO很有魄力,5000mAh80W旗舰,12G256G直如果对OPPO这个品牌的产品布局比较了解,你就知道在这个品牌中有主打颜值、轻薄度的K系列千元机,但在今年发布的OPPOK10和OPPOK10Pro身上,我们已经完全看不到曾经主……埃及门将萨拉赫告诉我马内会踢右边,马内对我说会踢左边直播吧2月8日讯埃及在非洲杯决赛点球不敌塞内加尔,门将贾巴尔在开场不久曾扑出了马内主罚的点球,他也谈到了相关细节。在马内失点前,镜头捕捉到萨拉赫与埃及门将贾巴尔有过交流。……克里米亚,本来属于乌克兰的一个地区,为何选择加入俄罗斯?克里米亚半岛位于黑海北岸,拥有数座天然良港,之前隶属于乌克兰。但是,在2014年加入了俄罗斯联邦,成为了俄罗斯的下属行政区域。那么为何本来属于乌克兰的一个地区会选择加入俄罗斯呢……专列南巡途中,毛主席突然问列车员王爱梅小王,你喜欢梅花吗?图王爱梅前言王爱梅曾是毛主席专列的工作人员,在她的印象中,毛主席始终是一个普普通通的慈祥老人。一切都是那么自然,在毛主席身边工作,王爱梅觉得自己是和毛主席平等相处的人。……HeroBrooklyn从平民球队到坐拥豪华三巨头,篮网是怎把时针拨回到201819赛季,球队(篮网)的一切都在向着好的方向发展。肯尼阿特金森不仅证明了他非常适合这支球队,而且远远超过管理层的预期。以德安吉洛拉塞尔、斯潘赛丁威迪和卡利斯……路环闲行记安德鲁咖啡厅的经典三明治早起吃饭,然后继续睡觉,起来喝茶,然后继续睡觉,上周的夜,可能熬得有点儿多。难得复活节四天假,原本是计划再换去金沙住一晚的。但查了携程,发现价格居……
为什么有的女人老了之后更美?除了打扮还有这2点,很多人忽略年长女性很少会再谈起年龄的感,仅仅是作为数字记录,并不足以展现女性的阅历和生活经验。成熟女性的气场,来源于我们对于造型和打扮的提升。能够第一眼就抓住他人眼球,是需要对我们……人间百转千回,自有因果定数这一生,都是上天最好的安排01hr人间百转千回,自有因果定数。在这苍茫的人世间,其实一切皆有定数。所有的努力和奋斗,就像是拨云见日一般,让命运的轨迹慢慢地展现出来。为何我们常说天时地利人和呢……巨金鱼战役围城打援的典范作者:张芃樸1946年12月22日至1947年1月16日,人民解放军晋冀鲁豫野战军在山东省巨野、金乡、鱼台地区发起巨金鱼之战。这是一场经典的围城打援战役,毙伤俘国民党军1……如今如果英国和法国组成英法联军,是否能击败俄罗斯?如果英国、法国单个对阵俄罗斯,可能还有些看头,若组成联军对阵俄罗斯,那绝对是鸡蛋碰石头,英法能输到什么程度,全凭俄罗斯的心情。俄罗斯完全不动用核武器,只是常规力量,就让这两个国……记者拜仁曼联切尔西等队关注穆阿尼,法兰克福希望得到1亿欧直播吧4月13日讯据SPORT1记者ChristopherMichel报道,拜仁在加紧努力引进穆阿尼,曼联、巴黎和切尔西也在关注该球员。ChristopherMichel……事退人员,2024年的养老金将迎来三个变化,待遇会怎么变呢?事退人员,2024年的养老金将迎来三个变化,待遇会怎么变?会变高还是变低呢?各位机关事业单位的退休职工注意,两年之后2024年是个比较特殊的时期,不管你是当年退休、还是在……赵荀一部戏用八个替身,为等他剧组停工半年,却没人说他耍大牌很多人觉得对于演员来说工作似乎是比较的轻松,他们只需要在镜头面前诠释好一个角色就可以了。而且一些偶像剧的演员工作就更加的轻松了,因为这些剧往往难度不大,剧情也相对简单,对演员的……5月所有中国整车厂将停产?不是没有可能近日,上海的疫情进一步发酵,其疫情风控措施对整个汽车产业都产生了非常大的负面影响,蔚来汽车、特斯拉、大众等工厂也都停产了,有不少专业人士在网络上发布对疫情封控下汽车产业走向的看……卡西欧是哪个国家的品牌?卡西欧手表贵吗在国内手表市场中,劳力士、欧米茄、浪琴、天梭、卡西欧应该是最有名的品牌了。即便是对手表一点都不了解的人都听说过这些品牌的大名。其中劳力士、欧米茄、浪琴、天梭都知道是来自瑞士的手……顽固性脚气老不好,这到底是怎么回事?脚气虽然不是什么大病,但却非常的折磨人。如患者胡先生,今年51岁了,他从十几年前就患上脚气病了。那时脚上开始有脚癣,一开始,他就是两只脚的脚指头瘙痒。到后来,开始起小水泡,开始……动态早安最美祝福图片,我祝你周末有个好心情,生活顺心花开香无言,落叶知冬寒,风过起波澜,流水看人间,月缺总会圆,夜深心梦酣,光阴似刀剑,精彩随处见,无忧顺风帆,心宽解愁烦,知己暖心田,逍遥情怡然,知音话语甜,情谊永相伴,早安送问……广西大新县名仕田园里的花好月圆李春英摄广西大新县名仕田园里的花好月圆广西大新县名仕田园里的花好月圆广西大新县名仕田园里的花好月圆广西大新县名仕田园里的花好月圆广西大新县名仕田园……
友情链接:易事利快生活快传网聚热点七猫云快好知快百科中准网快好找文好找中准网快软网