为什么慢SQL会把服务器CPU压爆

慢SQL & 连接池

在这里插入图片描述

数据库连接池是池化技术的一种实现,下面模仿一下简单的池化技术。

package com.wuhulala.thread.pool;

import java.util.ArrayList;
import java.util.Arrays;
import java.util.List;

public class ConnectionPool {

    private List<String> pool= new ArrayList<>(Arrays.asList("1", "2", "3", "4", "5", "6", "7", "8", "9", "10"));

    // 如果这个时候把线程给睡眠,估计cpu就不会爆炸,不然会一致重试。链接池的原理????
    public synchronized String getConnection() {
        if (!pool.isEmpty()) {
            String s = pool.get(0);
            pool.remove(0);
            return s;
        }
        return null;
    }

    public synchronized void release(String s) {
        pool.add(s);
    }

    public static void main(String[] args) {
        int n = 200;
        ConnectionPool pool = new ConnectionPool();

        for (int i = 0; i < n; i++) {
            new Thread(new Runnable() {
                @Override
                public void run() {
                    String poolName = null;
                    try {
                        while ((poolName = pool.getConnection()) == null) {
                            System.out.println(Thread.currentThread().getName() + "can not getObtain Pool");
                        }
                        System.out.println(Thread.currentThread().getName() + "obtain Pool [" + poolName + "]");
                        // 模拟慢sql
                        Thread.sleep(200000);
                    } catch (InterruptedException e) {
                        e.printStackTrace();
                    } finally {
                        pool.release(poolName);
                    }
                }
            }).start();
        }
    }
}

这段代码就是200个线程获取十个资源(可以理解为数据库连接),然后10个线程获取后,执行慢SQL,其它线程空转重复轮训可否获取到连接。
以下是cpu表现:
在这里插入图片描述
对比看了下是不是真正的连接池是这样的实现的:

Druid

在这里插入图片描述

HikariPool

在这里插入图片描述

DBCP

在这里插入图片描述

TomcatPool

在这里插入图片描述

总结

可以看出果然如我们所料,超时时间内会无限的重试。

具体的细节没做过的探究

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值