我花了两天时间没解决的问题,chatgpt用了5秒搞定

前言

一个说难不难,说简单竟看不出来是哪里问题的一个bug。是的 可能自己能力和经验尚浅无法识别,下面你们能否用火眼金睛一眼让bug原形毕露

(这个问题是忽然暴露出来的,无任何征兆,没人改动过,生产上运行了很长时间,故很奇怪,所以这个间谍看来很会隐藏)

隐藏的“间谍”

下面先来看代码(伪代码)

code


/**
 * 两个从数据库查询的耗时任务
 * @param countDownLatch
 * @param all
 */
public static void testCount(CountDownLatch countDownLatch, List<String> all) {
    for (int i = 0; i < 2; i++) {
        int finalI = i;
        ThreadPoolFactory.getGeneral().execute(() -> {
            try {
                List<String> countList = new ArrayList<>();
                //这里之所以用for循环,是因为查询业务需要0和1两个状态去查询
                if (finalI == 0) {
                //这里其实是查询数据库的mapper操作,为了方便演示
                    countList.add("1");
                    countList.add("2");
                    countList.add("3");
                } else {
                //这里其实是查询数据库的mapper操作,为了方便演示
                    countList.add("5");
                    countList.add("6");
                    countList.add("7");
                    countList.add("8");
                }
                if (countList != null) {
                    all.addAll(countList);
                }
            } catch (Exception ex) {
                ex.printStackTrace();
            } finally {
                countDownLatch.countDown();
            }
        });
    }
}



//线程池类
public class ThreadPoolFactory {

    private static final Logger logger = LoggerFactory.getLogger(ThreadPoolFactory.class);

    private static final ThreadFactory GENERAL_THREAD_FACTORY = new ThreadFactoryBuilder().setNameFormat("general-pool-%d").build();

    /**
     * corePoolSize:核心线程池大小
     * maximumPoolSize:最大线程池大小
     * keepAliveTime:线程最大空闲时间
     * unit:时间单位
     * workQueue:线程等待队列  四种队列 1.ArrayBlockingQueue:有界队列,2.SynchronousQueue:同步队列,3.LinkedBlockingQueue:无界队列,4.DelayQueue:延时阻塞队列
     * threadFactory:线程创建工厂
     * handler:拒绝策略 四种策略 1.ThreadPoolExecutor.AbortPolicy():2.ThreadPoolExecutor.CallerRunsPolicy():3.ThreadPoolExecutor.DiscardOldestPolicy():4.ThreadPoolExecutor.DiscardPolicy()
     */
    private static final ExecutorService GENERAL = new ThreadPoolExecutor(5, 10,
            30L, TimeUnit.MILLISECONDS,
            new LinkedBlockingQueue<>(4096), GENERAL_THREAD_FACTORY, new ThreadPoolExecutor.AbortPolicy());

    public static ExecutorService getGeneral() {
        return GENERAL;
    }

}


//main方法测试
public static void main(String[] args) throws Exception {
    List<String> all = new ArrayList<>();
    CountDownLatch countDownLatch = new CountDownLatch(2);
    testCount(countDownLatch,all);
    countDownLatch.await(10, TimeUnit.SECONDS);
    System.out.println(all);
}

复制代码

对于上面CountDownLatch不了解的的可以看下我历史的文章: 干货!CountDownLatch的使用场景

看到这里不知道你们能否看出端倪,先说问题结果吧,最后的这个all集合为空,生产上的接口也是同样的问题,我上面的代码是和生产上的1:1复制的伪代码。

我先说下我的排查思路:

1线程池问题,我认为是线程没有被及时的回收,时间太长,并发数过高,导致线程不够用,第一想到的是便是线程数需要增加

2、数据库数据过多,导致查询比以前慢出一个量级,最后队列阻塞,拖垮线程(这个概率比较低,因为数据库查询很快返回,并没有需要优化的慢sql)

3、怀疑是这个循环造成的,比如某种机制少循环或者不循环,去掉for循环依然没解决问题

验证第一位”间谍“

首先扩大核心线程数和最大线程数,将这俩参数扩大为10和20

private static final ExecutorService GENERAL = new ThreadPoolExecutor(10, 20,
            30L, TimeUnit.MILLISECONDS,
            new LinkedBlockingQueue<>(4096), GENERAL_THREAD_FACTORY, new ThreadPoolExecutor.AbortPolicy());
复制代码

扩大之后,放上去能查出数据了,感觉解决了这个大问题

我花了两天时间没解决的问题,chatgpt用了5秒搞定

那句话怎么说来着,真相往往不是那么的容易发现,最先抓到的都是小鱼小虾,果不其然,运行了一周左右,同样的问题又出现了,感觉这就是一水缸,你把水缸变大,终有蓄满的一天。我们都知道,线程池可不是越大越好。

我花了两天时间没解决的问题,chatgpt用了5秒搞定

那么真相究竟是什呢,看到这里的小伙伴如果你已经有了答案,可以先去评论区评论,不要看下面的答案。

借助GPT“侦探柯南”

chatgpt这里我就不多说了,这个东西如果现在还不了解的,那我就。。。就只能求求你赶紧去了解下吧

我花了两天时间没解决的问题,chatgpt用了5秒搞定

我把生产上的代码完整的贴上去,他是这样回答的

我花了两天时间没解决的问题,chatgpt用了5秒搞定

不得不说,一语中的,仅5秒就把我们所能想到和不能想到的都回答出来了

  • 很显然,第二点,第三点我们基本上验证通过了
  • 那就是第一点了,其实我们早就应该想到这一点的,多线程环境下,线程安全问题是首位的!!!

找出”真凶”

使用synchronized关键字解决线程安全

我花了两天时间没解决的问题,chatgpt用了5秒搞定

使用synchronized关键字来同步访问all列表,即在多个线程访问all列表时,使用同一个锁来保证线程安全,避免出现数据不一致的问题。这样就解决了多个线程可能会同时访问并修改数据,导致数据丢失或损坏的问题。

聪明的你有没有找出“真凶”呢???

还记得我们加大线程数来解决问题吗,我又问了一个问题

我花了两天时间没解决的问题,chatgpt用了5秒搞定

扩大线程池的参数可能会提高程序的并发处理能力,但并不能从根本上解决问题。如果是由于数据同步问题导致的线程池查不到数据,那么扩大线程池只是把问题暂时推迟了而已。此外,扩大线程池的核心线程池数量也会占用更多的系统资源

AI已来,未来已来

再啰嗦一句,AI的强大这里就不再强调了 ,接下来我会持续利用GPT输出很多干货和其他AI生态的东西,都收在下方的AI专栏里,一起学习,一起成长,欢迎关注下方的AI专栏,点赞,谢谢各位看官

用一句话作为结尾吧: 将来淘汰你的不是AI,而是不会用AI的人

作者:1点东西
链接:https://juejin.cn/post/7219978250847928357
来源:稀土掘金
著作权归作者所有。商业转载请联系作者获得授权,非商业转载请注明出处。

本文内容由互联网用户自发贡献,该文观点仅代表作者本人。商机网仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌抄袭侵权/违法违规的内容, 请发送邮件至 tenspace2022@163.com 举报,一经查实,本站将立刻删除。 本文链接:https://www.315965.com/n/55326.html 聚才发 母婴好物

(0)
上一篇 2023年12月18日 上午1:20
下一篇 2023年12月18日 上午1:32

相关推荐

  • 不只是启动声音,微软还悄悄降低了 Win11 OOBE 动画的质量

    虽然微软会公布 Windows 系统更新的大部分改进和变化,但有时也会有一些变化不会公布。而在极少数情况下,有些变化实际上会降低一些东西的质量。 去年 7 月,网友发现微软悄悄地降低了 Windows 11 22H2 的启动声音的质量。启动声音是指当用户打开电脑时,会听到的一段音乐。网友发现启动声音的比特率(即音频数据的密度)从原来的 1411 kbps 降…

    2023年12月24日
    139
  • 电子书阅读器app排行榜前十名,网易云阅读上榜,七猫免费小说排名第二(附2024最新排名前十名单)

    哪个看小说的app好用而且免费 1、笔趣阁:拥有众多的小说资源,无论是玄幻修真、官斗军事、历史穿越还是都市言情,都能找到自己想要的小说资源,还有各大小说榜单,辩棚顷来帮你推荐书籍,让你不会闹书荒。 2、小说大全:一款广受好评的小说阅读软件。不仅能在站内搜索还能直接搜索全网资源,每天都有小说上线,及时更新最新的章节,贴心的夜间模式和自动翻页功能,以及懒人听书,…

    2024年2月2日
    240
  • 2023 年的无人机:下一步是什么?源代码

    无人机,也称为无人驾驶飞机系统 (UAS) 或遥控飞行机器人,已经从娱乐新奇物发展为商业必需品。 凭借从交付到监控的各种能力,以及前所未有的效率水平,商用无人机的发展势在必行。 与此同时,商用和休闲无人机的安全可靠运行(或缺乏安全可靠运行)也是一个值得关注的问题。 这些是您可以期待在 2020 年看到的一些无人机趋势。 无人机和毒品制药业准备利用无人机送货服…

    2024年1月16日
    137
  • 国产笔记本电脑十大品牌排行榜(附2024最新排名前十名单)

    笔记本电脑排行榜2024前十名 1、华为MateBook 14s (2021):最佳整体 以重量为单位,华为MateBook 14s是您现在可以买到的最好的笔记本电脑。性能、设计和经济性的完美结合意味着它很容易推荐,尤其是网络摄像头回到屏幕上方而不是隐藏在键盘中。 2、Apple MacBook Air (M1):最佳MacBook Apple MacBoo…

    2024年2月1日
    548
  • 初创公司NUVIEW 提出光达技术卫星星座,绘制全球地表3D 地图

      当前卫星图像提供的地球2D 照片已不够看,美国初创公司NUVIEW 本月提出以光学雷达(LiDAR)技术建造新卫星星座的计画,试图描绘出更立体、更完整的地球3D 表面。 不少人造卫星正从空中使用高解析度相机拍摄地球表面,除了追踪人类活动范围,也有助于气象学观测、天气预报、物理环境(水文、植被等)变迁分析等,不过当前卫星提供的都是2D 照片。 一…

    2023年12月24日
    130
  • 数据泄露响应:恢复的 5 个基本步骤源代码

    根据 Cybersecurity Ventures 的数据,到 2025 年,全球网络犯罪的成本预计将增长到惊人的每年 10.5 万亿美元。 这一统计数据既引人入胜又令人恐惧,因为它揭示了黑客的聪明才智以及他们勒索网络世界的能力。 在整个 COVID-19 大流行期间,越来越多的企业采用远程工作和使用云通信(例如云联络中心)来提供客户支持。 这为数据盗窃创造…

    2024年1月15日
    131
  • 全新 MINI COOPER EV 电动车官图发布,明年国内上市

    全新 MINI COOPER EV 纯电动车官图已正式发布,据此前消息,新车预计将于 2024 年上市,也将进入国内销售,并有望进行本地化生产。 全新 MINI COOPER EV 保留了经典的 MINI 元素,但在设计上有了一些创新,比如采用了三角形的尾灯,以及精致的轮毂。官图展示的车型为全新 MINI COOPER SE 版本,新车继续采用双门车身加掀背…

    2023年12月17日
    175
  • 2023年Q1全球智能手机份额报告!三星险胜苹果重返第一宝座

    近日,统计机构Canalys发布了2023年第一季度全球智能手📱机销售情况报告。根据报告显示,相比起去年,2023年Q1智能手📱机销量同比下跌了12%,这已经是连续五个季度出现下跌的情况。同时,三星也反超了苹果重返至第一的宝座。不过Canalys是以“艰难重返”来形容,整个市场的销量表现还是不太乐观。 具体数据上,三星以22%的市场份额,险胜第二位21%份额…

    2023年12月19日
    147
  • 怎么查看自己电脑的IP地址(附2024年排行榜前十名单)

    怎么查找电脑的ip地址 查询本机电脑ip地址的方法: 方法一:网络和共享中心查询 1、在电脑桌面右绝睁下角找到网络图标,鼠标右键开打“网络和共享中心”界面;如图 2、然后在“网络和共享中心”界面上,点击我们正在连接的网络;如图 3、在弹出的WLAN界面上,选择“详细信息”;如图 4、最后在弹出的界面上, ipv4后面的ip就是我们电脑的ip地址;如图 方法二…

    2024年2月5日
    125
  • 视频播放器哪个软件最好用 推荐几款不流氓的播放器(附2024年排行榜前十名单)

    推荐几款不流氓的视频播放器,无边框看视频不要太香 上了一天班回来你住的地方,你累得像条狗,现在让你休息的话,你肯定睡不着,如果可以看一部电影来缓解一下疲惫的心情还是很不错的。现在视频播放器软件特别多,现在就来推荐几款比较好用的,不流氓的视频播放器。 1,MPC-BE 现在的播放多如牛毛,一键安装强制关联文件格式,开机强制启动,弹窗广告等。MPC-BE作为一个…

    2024年2月4日
    264