码农知识堂 - 1000bd
  •   Python
  •   PHP
  •   JS/TS
  •   JAVA
  •   C/C++
  •   C#
  •   GO
  •   Kotlin
  •   Swift
  • 【含面试题】高并发场景下的接口调用优化


    AI绘画关于SD,MJ,GPT,SDXL百科全书

    面试题分享点我直达

    2023Python面试题

    2023最新面试合集链接

    2023大厂面试题PDF

    面试题PDF版本

    java、python面试题

    项目实战:AI文本 OCR识别最佳实践

    AI Gamma一键生成PPT工具直达链接

    玩转cloud Studio 在线编码神器

    玩转 GPU AI绘画、AI讲话、翻译,GPU点亮AI想象空间

    史上最全文档AI绘画stablediffusion资料分享

    AI绘画 stable diffusion Midjourney 官方GPT文档 AIGC百科全书资料收集

    AIGC资料包

    最近在项目中遇到一个性能瓶颈,就是一个接口需要调用多个下游接口获取数据并合并后返回。由于下游接口数量较多,下载的数据量也不小,导致接口响应时间过长,严重影响了系统的性能。经过分析,这个接口天然适合用并发编程进行优化。今天就来聊聊我是如何用Java中的并发工具类来优化这个接口的。
    首先,这个接口的调用流程其实很简单:

    1. 接收请求
    2. 同时调用5个下游接口,获取返回的数据
    3. 合并下游接口返回的数据
    4. 返回合并后的数据很明显,这里的性能瓶颈在于同时调用下游接口。为了提高并发程度,我们可以使用Java并发包中的ExecutorService来实现线程池,然后提交多个任务到线程池中执行。
      java
      // 创建一个固定大小的线程池
      ExecutorService executor = Executors.newFixedThreadPool(5);

    // 提交任务到线程池执行
    for (int i = 0; i < 5; i++) {
    executor.submit(() -> {
    // 调用下游接口
    });
    }

    // 关闭线程池
    executor.shutdown();
    这样我们就可以最大程度地发挥多线程的优势,5个下游接口调用任务可以同时进行,效率会提高很多。但是,这样还不够。接口的请求量可能变化很大,固定大小的线程池可能会导致资源浪费或者无法处理请求。所以我们可以使用缓存线程池:
    java
    ExecutorService executor = Executors.newCachedThreadPool();
    缓存线程池会根据请求量动态调整线程数,可以提高资源利用率。另外,我们还需要处理线程池中任务的返回结果。可以通过Future来实现:
    java
    List futures = new ArrayList<>();

    for (int i = 0; i < 5; i++) {
    Future future = executor.submit(() -> {
    // 调用下游接口并返回结果
    });

    futures.add(future);
    }

    // 遍历futures获取结果
    for (Future future : futures) {
    Result result = future.get();
    // 处理结果
    }
    这样就可以很方便地获取线程池中任务的返回结果进行后续处理了。最后,我们可能还要合并下游接口返回的数据。可以使用Stream API来实现数据的聚合:
    java
    List results = futures.stream()
    .map(future -> future.get())
    .collect(Collectors.toList());

    Result mergedResult = merge(results);
    Stream可以很好地利用多核 CPU,进一步优化性能。到此,经过并发编程的优化,这个接口的瓶颈就基本上解决了。调用下游接口的时间大大缩短,系统的吞吐量也得到了提升。并发编程是一个非常重要且强大的工具,在 Java 中有很多现成的并发工具类供我们使用,例如线程池、Future等,合理利用可以大大优化我们系统的性能。

  • 相关阅读:
    git概述
    拼多多根据关键词取商品列表 API 返回值说明
    众多互联网公司都在用的Elasticsearch还不会?熬夜整理基于 Elasticsearch 7.x 版本的核心知识学习手册,值得拥有!
    Nginx的root与alias终极用法+区别+案例
    ros指令 rqt_bag <bagname>
    redis之单线程的redis都有哪些阻塞点
    今天博客访问量达到10W了,纪念一下
    基于python的NBA球员数据可视化分析的设计与实现
    Process finished with exit code -1073740791 (0xC0000409)
    7个设计师必备的Figma汉化插件,高效设计超简单!
  • 原文地址:https://blog.csdn.net/weixin_42373241/article/details/133162514
  • 最新文章
  • 攻防演习之三天拿下官网站群
    数据安全治理学习——前期安全规划和安全管理体系建设
    企业安全 | 企业内一次钓鱼演练准备过程
    内网渗透测试 | Kerberos协议及其部分攻击手法
    0day的产生 | 不懂代码的"代码审计"
    安装scrcpy-client模块av模块异常,环境问题解决方案
    leetcode hot100【LeetCode 279. 完全平方数】java实现
    OpenWrt下安装Mosquitto
    AnatoMask论文汇总
    【AI日记】24.11.01 LangChain、openai api和github copilot
  • 热门文章
  • 十款代码表白小特效 一个比一个浪漫 赶紧收藏起来吧!!!
    奉劝各位学弟学妹们,该打造你的技术影响力了!
    五年了,我在 CSDN 的两个一百万。
    Java俄罗斯方块,老程序员花了一个周末,连接中学年代!
    面试官都震惊,你这网络基础可以啊!
    你真的会用百度吗?我不信 — 那些不为人知的搜索引擎语法
    心情不好的时候,用 Python 画棵樱花树送给自己吧
    通宵一晚做出来的一款类似CS的第一人称射击游戏Demo!原来做游戏也不是很难,连憨憨学妹都学会了!
    13 万字 C 语言从入门到精通保姆级教程2021 年版
    10行代码集2000张美女图,Python爬虫120例,再上征途
Copyright © 2022 侵权请联系2656653265@qq.com    京ICP备2022015340号-1
正则表达式工具 cron表达式工具 密码生成工具

京公网安备 11010502049817号