首页 > 其他分享 >代码坏味道(一)

代码坏味道(一)

时间:2023-05-24 19:22:05浏览次数:39  
标签:请求 味道 代码 API 线程 序列化 优化 CPU

GC 优化

1.防止大对象Buffer到内存中

现象:当大包请求时,YGC 耗时严重

原因:默认情况下 Zuul2 并不会缓存请求体(DirectByteBuffer),也就意味着它会先发送接收到的请求 Headers 到后端服务,之后接收到请求体再继续发送到后端服务,发送请求体的时候,也不是组装为一个完整数据之后才发,而是接收到一部分,就转发一部分。
如果需要缓存请求体:
需要 Override needsBodyBuffered 方法, com.netflix.zuul.netty.filter.BaseZuulFilterRunner#filter
针对大包请求时,网关性能降低,体现在:网关操作会将请求体 Buffer 到用户空间来实现提取请求体做 WAF 拦截

优化

  • 判断大包,大包不缓存(Content-Length)

2.防止多次创建重复对象

现象:YGC 次数多

原因
如何快速获取 Body?Zuul 贴心的为我们提供了如下两种方式,封装在过 Request 中供开发者使用
com.netflix.zuul.message.ZuulMessageImpl#getBodyAsText
com.netflix.zuul.message.ZuulMessageImpl#getBody
但不幸的是,内部每次获取对象繁琐,并且 new String() 创建返回

优化
取一次,缓存在 Context 中,需要时从 Context 获取

3.防止多次创建中间对象

现象:YGC 次数多

原因 :多次创建中间无用对象,例如:ProtobufSerializer#serialize

    @Override
    public byte[] serialize(String topic, Object data) {
        if (data == null) {
            return null;
        }
        return JSON.toJSONString(data).getBytes();
    }

优化:直接序列化成 byte,不需要先创建中间对象 String,再 getBytes()

CPU 优化

1.减少线程个数,降低上下文切换次数

现象:无关线程太多,影响内存(JVM+操作系统)+CPU 争抢

原因:网关内有生产者,消费者,每个消费者都会有消费轨迹的线程池(10),网关有针对不同场景下的消费者,故会创建诸多消息轨迹线程

优化

  • 禁用消息轨迹
  • 调整消费者线程数

2.减少字符串比较次数

现象:每次请求到自定义的 Route Filter,都要通过 Loop 缓存获取到和当前 RequestMethod 一致的 Rest API。通过火焰图可以看出,单位时间内,该部分逻辑 CPU 计算占比高

原因

 Set<String> apis=restApiManager.getApis().stream().filter(a -> method.equalsIgnoreCase(a.getHttpMethod())).collect(Collectors.toSet());

本意是过滤掉和当前 Request Method 不一致的,但是每请求一次,都需要重复计算过滤:O(n)

优化:O(1),改为 HashMap,Key 为 Method,Value 为 Set <String> apis,封装统一方法获取,RestApiManager#getApis(String method)

3.减少正则表达式计算次数

现象:API 路由需要正则匹配,最终确定需要路由的 Service。通过火焰图可以看出,单位时间内,该部分逻辑 CPU 计算占比高

原因:API 路由需要正则匹配,最终确定需要路由的 Service

优化:通过前缀匹配,过滤掉非法的API。比如访问:/v1/accounts/{accountId}/getAllInfo,先过滤掉非 /v1/accounts 开头的 API,因为正则肯定不匹配

4.减少序列化

现象:序列化需要CPU运算,减少不必要的序列化场景可以提高吞吐量

原因:针对相同请求的话,WAF 里需要计算出一个签名,减少攻击验证次数。

因为计算相同内容的 MD5,将对象序列化成 JSON。在高并发下序列化会大量占用 CPU。

signature = buildSignature(objectMapper.writeValueAsString(requestMessage));

优化
使用 ToString 来替换序列化:

signature = buildSignature(requestMessage.toString())

其他优化

  • 不打无用日志,日志需要编码,需要 CPU 消耗

标签:请求,味道,代码,API,线程,序列化,优化,CPU
From: https://www.cnblogs.com/OceanEyes/p/17429291.html

相关文章

  • 源代码工具
    源代码工具一、什么是源代码管理工具?源代码管理工具是一类可以存储代码,可以随时修改已存储的代码,可以实现多个程序员共同开发协作的工具。二、源代码管理工具的优点源代码管理工具允许团队成员看见彼此的代码,这样使项目代码整体具有流畅性。节约时间,节省了将各个功能模块拼......
  • 【无人机三维路径规划】基于遗传算法实现无人机三维路径规划含Matlab代码
    ✅作者简介:热爱科研的Matlab仿真开发者,修心和技术同步精进,matlab项目合作可私信。......
  • AMD Vitis 调试时,BSP代码的某些行没有被执行,代码乱跳等问题。
    问题AMDVitis调试代码时,BSP代码的某些应该被执行的行,没有被执行,调试器显示代码乱跳等。原因为了提高运行速度,BSP编译时,默认使用了优化选项进行编译,导致调试器对应二进制代码、和C代码时出现问题,显示出错误的执行流程。这只是显示问题,实际执行流程是没有问题的。解决办法将......
  • 代码小结构
    20230524一个开放方法,如果可预知的,以后会加方法参数的话,就把所有参数放到一个dto的参数类里面,如果你又不想写太多的setAsetBsetC,那就把所有的set方法放到DtoUtil里面。publicclassDtoUtil{publicstaticDtogetDto(Stringa,Strinbb,Stringc){Dtod=......
  • 源代码管理工具介绍【Gitee】
    本次我选择介绍的源代码管理工具为Gitee,它相对国内用户来说比较好接触一些。Gitee简介Gitee是一家中国的开源代码托管平台,类似于GitHub、GitLab等国际知名的托管平台,提供免费的公共代码仓库和付费的私有代码仓库服务,并支持Git和SVN两种版本控制工具。与其他托管平台不同的是,Gite......
  • 通过Git 从Gitee上下载代码
     打开git.bash,cd到要放置代码包的文件目录运行:gitclonegit@gitee.com:joyiyii/springcloud-config.git  结果:成功clone下来了==================================================================================================================================......
  • python嵌入HTTP代理代码示例
    以下是使用Python嵌入HTTP代理的示例代码:```pythonimporturllib.request#设置代理服务器地址和端口号proxy_handler=urllib.request.ProxyHandler({'http':'http://proxy.example.com:8080'})#创建opener对象opener=urllib.request.build_opener(proxy_handler)#使用opene......
  • 流程表单JavaScript代码
    ----订单流程-----------//表单加载初始化时functionpreinit(){}//表单加载完成,isrun代表流程是否流转中1-是,0-否functionLoaded(isrun){$("#om_order_status").attr("disabled","disabled");......
  • git拉取代码出现“remote: The project you were looking for could not be found.”
    如果输入的远程地址正确,那么极大可能是用户未登录或多个用户登录无法正确获取你想要的用户,如下图所示, 由于之前有同事在我电脑登录git账号,所以在windows凭据中保存了2个git账号,而默认使用的第一个账号的远程库中不存在我想要的目标仓库数据,就出现了“remote:Theprojectyouw......
  • 源代码管理工具
    源代码管理工具是一种软件应用程序,它提供了一个集中位置来存储、管理和版本控制源代码文件和其他软件开发工件。当多个开发人员对同一文件进行更改时,它允许开发人员团队跟踪更改、协作处理功能并解决冲突,从而帮助开发人员团队在代码库上协同工作。源代码管理工具使得一个团队可以......