最近在进行性能压测, 想验证一下产品的极限性能, 在使用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 数据库连接池大小简单总结的更多相关文章

  1. Springboot数据库连接池报错的解决办法

    Springboot数据库连接池报错的解决办法 这个异常通常在Linux服务器上会发生,原因是Linux系统会主动断开一个长时间没有通信的连接 那么我们的问题就是:数据库连接池长时间处于间歇状态,导致 ...

  2. java数据库连接池技术简单使用

    JDBCDemo.java: package com.itheima.jdbc; import java.sql.Connection; import java.sql.PreparedStateme ...

  3. SpringBoot集成druid数据库连接池的简单使用

    简介 Druid是阿里巴巴旗下Java语言中最好的数据库连接池.Druid能够提供强大的监控和扩展功能. 官网: https://github.com/alibaba/druid/wiki/常见问题 ...

  4. springboot数据库连接池使用策略

    springboot官方文档介绍数据库连接池的使用策略如下: Production database connections can also be auto-configured using a p ...

  5. springBoot数据库连接池常用配置

    在配置文件中添加配置如下(我使用的是多数据源): spring.datasource.primary.url=jdbc\:mysql\://localhost\:3306/test?useUnicod ...

  6. DBCP数据库连接池的简单使用

    0.DBCP简介      DBCP(DataBase connection pool)数据库连接池是 apache 上的一个Java连接池项目.DBCP通过连接池预先同数据库建立一些连接放在内存中( ...

  7. JDBC 数据库连接池的简单实现

    连接池代码: public class MyDataSource2{     private static String url = "jdbc:mysql://localhost:3306 ...

  8. java web学习总结(十六) -------------------数据库连接池

    一.应用程序直接获取数据库连接的缺点 用户每次请求都需要向数据库获得链接,而数据库创建连接通常需要消耗相对较大的资源,创建时间也较长.假设网站一天10万访问量,数据库服务器就需要创建10万次连接,极大 ...

  9. javaweb学习总结(三十九)——数据库连接池

    一.应用程序直接获取数据库连接的缺点 用户每次请求都需要向数据库获得链接,而数据库创建连接通常需要消耗相对较大的资源,创建时间也较长.假设网站一天10万访问量,数据库服务器就需要创建10万次连接,极大 ...

  10. JavaWeb学习(三十)———— 数据库连接池

    一.应用程序直接获取数据库连接的缺点 用户每次请求都需要向数据库获得链接,而数据库创建连接通常需要消耗相对较大的资源,创建时间也较长.假设网站一天10万访问量,数据库服务器就需要创建10万次连接,极大 ...

随机推荐

  1. 基于Fabric的性能测试与调优实践

    摘要:本文聚焦Fabric核心业务,构建一个测试模型,对社区原生的Fabric和华为云区块链(基于Fabric)进行实测,识别社区原生Fabric的性能瓶颈,并尝试通过华为区块链提供的动态伸缩.快速P ...

  2. 带你了解VXLAN网络中报文的转发机制

    摘要:本节以集中式VXLAN网络(手工方式建立VXLAN隧道)为例,分别介绍相同子网内.不同子网间是如何进行通信的.在了解转发机制的前提下,我们先来看下VXLAN网关有哪些种类. VXLAN二层网关与 ...

  3. VS Code摸鱼神器,让你快速开发AI模型

    摘要:ModelArts VS Code插件一键接入云上开发环境介绍及操作指导 对于习惯于使用本地VS Code IDE的开发者,受限于本地资源,采用本地开发加云上调测的远程开发方式不失为一种更好的选 ...

  4. 云小课 | 使用ROMA API,API管理从此不用愁!

    阅识风云是华为云信息大咖,擅长将复杂信息多元化呈现,其出品的一张图(云图说).深入浅出的博文(云小课)或短视频(云视厅)总有一款能让您快速上手华为云.更多精彩内容请单击此处. 摘要:ROMA API致 ...

  5. 再谈BOM和DOM(4):DOM0/DOM2事件处理分析

    JavaScript能够让网站对用户的各种操作及时做出"反馈",响应用户交互行为,而这些就是:DOM,事件以及事件处理 DOM就是操作的元素,这个看<再谈BOM和DOM(1) ...

  6. 一文读懂火山引擎数智平台 VeDI 新品——管理驾驶舱 Plus

    更多技术交流.求职机会,欢迎关注字节跳动数据平台微信公众号,回复[1]进入官方交流群 4 月 18 日,2023 春季火山引擎 FORCE 原动力大会在上海举行,火山引擎发布数智平台(VeDI)新品- ...

  7. 使用 quartz-solon-plugin 开发定时任务(新)

    (一)新建一个 maven 空项目 (二)添加 maven 引用 <dependency> <groupId>org.noear</groupId> <art ...

  8. MongoDB 读写分离——MongoDB 安装

    下载安装包:https://www.mongodb.com/try/download/community 同一台电脑装了两服务,所以下载zip包,单机服务 mis 安装方便些 解压并重命名. 4.2  ...

  9. #1495:非常可乐(BFS+数论)

    题目链接:http://acm.hdu.edu.cn/showproblem.php?pid=1495 BFS解法 题目 给三个数字 s n m s=n+m s在1到100之间 就是个倒水问题可以从第 ...

  10. vue实现文件上传功能

    https://www.jb51.net/article/145500.htm Element中的el-upload使用过程中踩的坑 https://www.jianshu.com/p/c837224 ...