Springboot 数据库连接池大小简单总结
最近在进行性能压测, 想验证一下产品的极限性能, 在使用openpower 2路22核(SMT4)176线程 512G内存的服务器上面进行性能压测
压测进行到1000并发或者是2000并发时性能有一定的衰减, 有开发确认, 数据库事务仅是比较短促的OLTP的保存操作, 耗时都比较短 ,
所以在这种情况下, 将数据库连接池的 大小 从2000逐步递减到 350 左右, 性能压测有了一定提高. 并发相应时间从7s 变成了3s 左右, 并且性能比较稳定了.
初步怀疑问题原因在于 较高连接数时 操作系统进行 线程调度时的损耗会比较大,如果设置超多的连接池数据, 并且要求数据库服务器也提高max-connections 数目, 会导致
应用后端的 jvm 内的 connection pool 出现大量的 线程切换, 影响性能, 在数据库端, 如果数据库保持较多的关于客户端的db connection 连接, 也需要进行数据库服务器层面的线程切换.
并且前端时间出现过 jvm 的crash 现象, 怀疑也是在Openpower上面的 openjdk的 jvm 到达 三四千线程之后 容易出现稳定性问题,
在这里一直有一个不太明白的事项:
springboot 里面有两个连接池 一个是为前端http服务的 tomcat http连接池, 这个连接池数量一样可能会要求比较高一些.
虽然数据库事务比较短促, 但是可能需要客户端与应用服务器保持长连接, 应用服务器也需要较长时间的分析客户请求, 访问数据库, 处理数据库返回数据, 打包传递给客户端等步骤, 这些步骤可能需要较长的时间来进行处理.
有时为了安全客户端和应用服务器端还会保持一个keepalive 的通信机制, 定期校验更换token 以保证安全.
刚才看了下 我这边 登录服务器 就产生了 7个tcp连接

可以明显看到 是一个chrome 的进程在处理相关业务

然后在服务器端可以看到有多个连接

然后一段时间不报错就会立马降为 1个 连接 时间大约为1 min
所以怀疑用户并发时可能会占用较多的http连接池.
看到这么一个数据
148 11840 okhttp3.internal.connection.RealConnection
怀疑跟这个数据有点靠近

感觉 http 连接池 比较轻量 也不会占用太多的资源
但是数据库连接池比较 狠一些 数据库需要做相关的 保持状态以及事务处理 所以不能太多
但是发现数据库连接池的大小可能大于实际的物理连接
[root@CentOS8 ~]# echo "当前数据库连接池大小为:" $(jmap -histo `jps |grep caf |awk '{print $1}'` |grep PoolEntry$ |awk '{print $2}')
当前数据库连接池大小为: 89
[root@CentOS8 ~]# lsof -i:5236 |grep 29490 |wc -l
23
这一块理解的不太清楚
只是怀疑这个http 的连接数是 okhttp的 后面再给tomcat 进行处理.
但是tomcat的连接数多少可能需要通过http-nio 才分析.
比较忙 改天再整理
Springboot 数据库连接池大小简单总结的更多相关文章
- Springboot数据库连接池报错的解决办法
Springboot数据库连接池报错的解决办法 这个异常通常在Linux服务器上会发生,原因是Linux系统会主动断开一个长时间没有通信的连接 那么我们的问题就是:数据库连接池长时间处于间歇状态,导致 ...
- java数据库连接池技术简单使用
JDBCDemo.java: package com.itheima.jdbc; import java.sql.Connection; import java.sql.PreparedStateme ...
- SpringBoot集成druid数据库连接池的简单使用
简介 Druid是阿里巴巴旗下Java语言中最好的数据库连接池.Druid能够提供强大的监控和扩展功能. 官网: https://github.com/alibaba/druid/wiki/常见问题 ...
- springboot数据库连接池使用策略
springboot官方文档介绍数据库连接池的使用策略如下: Production database connections can also be auto-configured using a p ...
- springBoot数据库连接池常用配置
在配置文件中添加配置如下(我使用的是多数据源): spring.datasource.primary.url=jdbc\:mysql\://localhost\:3306/test?useUnicod ...
- DBCP数据库连接池的简单使用
0.DBCP简介 DBCP(DataBase connection pool)数据库连接池是 apache 上的一个Java连接池项目.DBCP通过连接池预先同数据库建立一些连接放在内存中( ...
- JDBC 数据库连接池的简单实现
连接池代码: public class MyDataSource2{ private static String url = "jdbc:mysql://localhost:3306 ...
- java web学习总结(十六) -------------------数据库连接池
一.应用程序直接获取数据库连接的缺点 用户每次请求都需要向数据库获得链接,而数据库创建连接通常需要消耗相对较大的资源,创建时间也较长.假设网站一天10万访问量,数据库服务器就需要创建10万次连接,极大 ...
- javaweb学习总结(三十九)——数据库连接池
一.应用程序直接获取数据库连接的缺点 用户每次请求都需要向数据库获得链接,而数据库创建连接通常需要消耗相对较大的资源,创建时间也较长.假设网站一天10万访问量,数据库服务器就需要创建10万次连接,极大 ...
- JavaWeb学习(三十)———— 数据库连接池
一.应用程序直接获取数据库连接的缺点 用户每次请求都需要向数据库获得链接,而数据库创建连接通常需要消耗相对较大的资源,创建时间也较长.假设网站一天10万访问量,数据库服务器就需要创建10万次连接,极大 ...
随机推荐
- 协同编辑:Google Wave架构分析
Google Wave的设计初衷是让人们互相发送信息,一起编辑文档,但用户对此感到困惑,很快就以失败告终.Google Wave持续了大约一年时间,于2010年8月被关闭. Wave"领先于 ...
- 火山引擎DataTester:如何使用A/B测试优化全域营销效果
当前,营销技术步入了全渠道.全周期的全域时代,随着广泛的数据积累,数据科学技术在营销领域发挥着越来越重要的作用,从消费者人群洞察到智能化信息广告投放,营销的提效让企业得以在转化的每个环节提升影响力 ...
- Asp.net MVC 跨域设置
.Net Core 跨域 <system.webServer> <httpProtocol> <customHeaders> <add name=" ...
- yaml/json/ini 配置读取
ConfigParser 安装 ConfigParser 是解析配置文件的第三方库,须要安装 pip install ConfigParser pip install ConfigParser Con ...
- 4个工具,让 ChatGPT 如虎添翼!
LightGBM中文文档 机器学习统计学,476页 机器学习圣经PRML中文版 经典著作<机器学习:概率视角 让 ChatGPT 如虎添翼! ChatGPT 很好用,其核心是prompt的运用, ...
- Nginx--引用多配置文件
在nginx.conf的http模块,include 指定某个目录下的*.conf user nginx; worker_processes auto; error_log /var/log/ngin ...
- 从阿里云全球实时传输网络GRTN出发,浅谈QOE优化实践
直播已深入每家每户,以淘宝的直播为例,在粉丝与主播的连麦互动中如何实现无感合屏或切屏?阿里云GRTN核心网技术负责人肖凯,在LVS2022上海站为我们分享了GRTN核心网的运作机制.运用方面以及QOE ...
- 图扑 Web SCADA 智慧钢厂能源监控 HMI
前言 钢铁行业作为我国的支柱产业,也是我国能源消耗的重点行业之一,随着国家节能减排政策的推进,有效实施能源管控是企业提高能源绩效.降低能源成本和提高核心竞争力的重要途径. 通过对钢铁企业能耗现状和能源 ...
- Go语言安装(Windows10)
一. 官网下载 https://golang.google.cn/dl/ 二. 软件包安装 选择对应的路径进行安装 三. 环境变量设置 1.path 检查系统环境变量Path内已经添加Go的安 ...
- spring启动流程 (4) FactoryBean详解
FactoryBean接口 实现类对象将被用作创建Bean实例的工厂,即调用getObject()方法返回的对象才是真正要使用的Bean实例,而不是直接将FactoryBean对象作为暴露的Bean实 ...