线程池实现填充短信_填充一个池需要多少个线程?

线程池实现填充短信

在最近几个月中,我们一直看到很小但持续的操作失败,但有一个奇怪的异常– org.springframework.jdbc.CannotGetJdbcConnectionException –“无法获得JDBC连接; 嵌套异常是java.sql.SQLException:客户端尝试检出Connection的尝试已超时。 ”

我们的自然假设是,我们在C3P0连接池中存在某种争用,尝试获取连接的客户端必须等待该争用可用。 我们最好的猜测是正是这种争执导致了超时。

因此,当然,我们要做的第一件事是增加连接池中的最大连接数。 但是,无论我们将限制设置得多么高,它都无济于事。 然后,我们尝试更改连接的超时参数。 那没有产生任何更好的结果。

此时,情报已经确定下来,并且由于猜测似乎没有用,因此我们决定进行测量。 使用连接池上的一个简单包装器,我们看到即使连接池中有空闲连接,我们仍然会得到签出超时。

调查连接池开销

为了研究连接池的开销,我们执行了一个基准测试,该基准测试由6个回合组成,每个回合包括20,000个SQL操作(读/写比为1:10),使用20个线程和20个连接的连接池来执行。 使用具有20个连接的池使用20个线程意味着资源(连接)上没有争用。 因此,任何开销都是由连接池本身引起的。

我们忽略了第一次(预热)运行的结果,而取了随后5次运行的统计数据。 从这些数据中,我们收集连接签出时间,连接释放时间和总池开销。

基准项目代码可以在以下位置找到: https : //github.com/yoavaa/connection-pool-benchmark

我们测试了3个不同的连接池:

  • C3P0 – com.mchange:c3p0:0.9.5-pre3 – C3P0DataSourceBenchmark类
  • Bone CP – com.jolbox:bonecp:0.8.0-rc1 –类BoneDataSourceBenchmark
  • Apache DBCP – commons-dbcp:commons-dbcp:1.4 –类DbcpDataSourceBenchmark

(在该项目中,还有一个我自己的实验性异步池的基准测试-https: //github.com/yoavaa/async-connection-pool 。但是,出于本文的目的,我将忽略它)。

为了自己运行基准测试,您应该使用下表设置MySQL

CREATE TABLE item (file_name     varchar(100) NOT NULL,user_guid     varchar(50) NOT NULL,media_type    varchar(16) NOT NULL,date_created  datetime NOT NULL,date_updated  timestamp AUTO_INCREMENT NOT NULL DEFAULT CURRENT_TIMESTAMP,PRIMARY KEY(file_name)
)

然后更新Credentials对象以指向此MySQL安装。

运行基准测试时,结果示例如下:

run, param, total time, errors, under 1000 nSec,1000 nSec - 3200 nSec,3200 nSec - 10 µSec,10 µSec - 32 µSec,32 µSec - 100 µSec,100 µSec - 320 µSec,320 µSec - 1000 µSec,1000 µSec - 3200 µSec,3200 µSec - 10 mSec,10 mSec - 32 mSec,32 mSec - 100 mSec,100 mSec - 320 mSec,320 mSec - 1000 mSec,1000 mSec - 3200 mSec,other
0, acquire,29587,0,0,5,1625,8132,738,660,1332,1787,2062,2048,1430,181,0,0,0
0, execution, , ,0,0,0,0,0,0,0,1848,6566,6456,5078,52,0,0,0
0, release, , ,0,8,6416,9848,3110,68,77,115,124,148,75,11,0,0,0
0, overhead, , ,0,0,49,4573,5459,711,1399,1812,2142,2157,1498,200,0,0,0
1, acquire,27941,0,0,125,8153,499,658,829,1588,2255,2470,2377,1013,33,0,0,0
1, execution, , ,0,0,0,0,0,0,6,1730,6105,6768,5368,23,0,0,0
1, release, , ,0,49,15722,3733,55,42,69,91,123,101,14,1,0,0,0
1, overhead, , ,0,0,2497,5819,869,830,1610,2303,2545,2448,1042,37,0,0,0

此信息已导入Excel文件(也包含在基准项目中)以进行分析。

C3P0

最初在C3P0中,我们在生产环境中看到了原始异常。 让我们看看它如何执行:

阅读图表:

前三个图表(获取,发布,开销)是基于性能的存储桶图表。 Y轴表示在一定时间范围内完成的操作数(在X轴上显示)。 默认的经验法则是,左侧的条形越高,效果越好。 第四图表是瀑布图,其中每个水平线表示一个DB操作。 棕色表示等待获取连接的时间,绿色表示执行数据库操作的时间,蓝色表示将连接返回到连接池的时间。

从图表中可以看出,通常,C3P0在3.2-10微秒内获得连接,并在3.2-10微秒内释放连接。 那绝对是一些令人印象深刻的表现。 但是,C3P0在约3.2-32毫秒处还有另一个峰值,而长尾巴则高达320-1000毫秒。 正是第二个高峰导致了我们的例外。

C3P0怎么了? 是什么原因导致了这种极小但相当大的超长操作百分比,而大多数时候却表现惊人? 纵观4 图可以为我们指出了答案的方向。

第4 图表从左上角到右下角都有一条清晰的对角线,表明总体上,连接获取是按顺序开始的。 但是我们可以识别出一些奇怪的东西–我们可以看到棕色的三角形,表示当多个线程试图获取连接时,第一个线程比后续线程等待更多时间的情况。 这转化为用于获取连接的两个性能“组”。 一些线程极其快速地获得连接,而有些线程则饿死等待连接,而较后的线程的请求则得到了较早的答复。

早期线程比后续线程等待更长的时间的这种行为意味着不公平的同步。 事实上,挖掘到C3P0代码时,我们已经看到了收购的连接的过程中,C3P0使用“ 同步 ”关键字三次。 在Java中,' synceded '关键字创建了不公平的锁,这可能导致线程饥饿。

稍后我们可能会尝试使用公平锁定来修补C3P0。 如果这样做,我们自然会分享我们的发现。

此基准测试的C3P0配置:

  • 最小泳池大小:20
  • 初始池大小:20
  • 游泳池的最大大小:20
  • 采集增量:10
  • 辅助线程数:6

骨CP

我们在Wix上尝试了BoneCP,但结果不一,因此目前尚不确定我们是否喜欢它。 尽管分析并不全面,但我们将BoneCP基准测试的结果包括在这些帖子中。

查看图表,我们可以看到Bone的连接捕获性能非常出色–大多数操作在3.2微秒内完成,比C3P0快得多。 但是,我们还观察到连接释放时间很长,大约1-10毫秒,太高了。 我们还观察到Bone的操作很长,开销高达320毫秒。

从数据来看,在正常和“极端”情况下,BoneCP似乎都比C3P0好。 但是,如图表所示,差异并不大。 查看第4 图表,我们看到与C3P0相比,褐色较少(因为连接获取更好),但出现了蓝线,表明线程等待连接释放的时间。

如上所述,由于我们对使用BoneCP充其量是矛盾的,因此我们没有投入大量资源来分析此连接池的性能问题。

Apache DBCP

Apache DBCP被称为古老的数据源。 让我们看看与其他两个相比的情况如何。

显而易见的是– DBCP性能优于C3P0和Bone。 在所有方面,无论是在连接签出时间,连接释放时间还是瀑布图形式方面,它都优于其他方法。

那么您应该使用什么数据源?

好吧,这是一个不平凡的问题。 显然,就连接池性能而言,我们显然是赢家– DBCP。 似乎C3P0应该很容易修复,我们可以尝试一下。

但是,重要的是要记住,此研究的范围仅限于实际连接获取/释放的性能。 实际的数据源选择是一个更复杂的问题。 例如,该基准测试忽略了一些重要方面,例如池的增长和缩小,网络错误的处理,数据库故障时的故障转移等等。

参考: 填充一个池需要多少个线程? 来自我们的JCG合作伙伴 Yoav Abrahami,来自Wix IO博客。

翻译自: https://www.javacodegeeks.com/2013/06/how-many-threads-does-it-take-to-fill-a-pool.html

线程池实现填充短信

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/348056.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

python线性回归x可以数量不一样吗_R和Python中的线性回归 - 在同一问题上的结果不同...

只是指出这一点: statsmodel s least squares fit does by default not include a constant. If we remove the constant from R适合,我们得到与Python实现非常相似的结果,或者相反,如果我们向 statsmodel -fit添加一个常量&#…

PostgreSQL开放自由

Open Liberty是源自WebSphere Liberty的有趣的新型OSS Java EE应用服务器。 您可以将Open Liberty配置为使用PostgreSQL作为其默认数据源&#xff0c;如下所示&#xff1a; 将<datasource> &#xff0c; <jdbcDriver>和<library>指令添加到server.xml配置中…

实现mysql百度式查询_mysql查询优化建议(百度)

1.对查询进行优化&#xff0c;应尽量避免全表扫描&#xff0c;首先应考虑在 where 及 order by 涉及的列上建立索引。2.应尽量避免在 where 子句中使用!或<>操作符&#xff0c;否则将引擎放弃使用索引而进行全表扫描。3.应尽量避免在 where 子句中对字段进行 null 值判断…

海思芯片怎么使用tde给qt加速_3519移植Qt适配附件

【实例简介】修改Qt5.5.1linuxfb插件代码&#xff0c;适配海思3519平台【实例截图】【核心代码】3519Qt移植.tar├── 3519Qt绉绘│ ├── linuxfb│ │ ├── include│ │ │ ├── acodec.h│ │ │ ├── fisheye_calibrate.h│ │ │ ├─…

jsf标签_多个动态包含一个JSF标签

jsf标签每个JSF开发人员都知道ui&#xff1a;include和ui&#xff1a;param标签。 您可以包括一个facelet&#xff08;XHTML文件&#xff09;并传递一个对象&#xff0c;该对象将在包含的facelet中可用&#xff0c;如下所示&#xff1a; <ui:include src"/sections/co…

用Java比较文件

我正在为PACKT创建一系列有关Java网络编程的视频教程。 有整节关于Java NIO。 一个示例程序是通过原始套接字连接将文件从客户端复制到服务器。 客户端从磁盘读取文件&#xff0c;服务器将到达的字节保存到磁盘。 因为这是一个演示&#xff0c;所以服务器和客户端在同一台计算机…

java哈希_Java如何采用哈希码实现分类(以员工分配为例)

5.总程序&#xff1a;下面代码是我们获取的所有的程序代码&#xff0c;如下&#xff1a;public static void main(String[] args) {Scanner scannew Scanner(System.in);System.out.println("请输入员工姓名&#xff1a;");String namescan.nextLine();System.out.pr…

java反射的原理_java反射机制的实现原理

java反射机制的实现原理反射机制:所谓的反射机制就是java语言在运行时拥有一项自观的能力。通过这种能力可以彻底的了解自身的情况为下一步的动作做准备。下面具体介绍一下java的反射机制。这里你将颠覆原来对java的理解。Java的反射机制的实现要借助于4个类&#xff1a;class&…

java linkedlist 用法_Java LinkedList addLast()用法及代码示例

Java中的java.util.LinkedList.addLast()方法用于在LinkedList的末尾插入特定元素。用法:void addLast(Object element)参数&#xff1a;此函数接受单个参数element &#xff0c;如上面的语法所示。此参数指定的元素将附加在列表的末尾。返回值&#xff1a;此方法不返回任何值。…

spring 长轮询_Spring集成文件轮询和测试

spring 长轮询我最近实施了一个小项目&#xff0c;在该项目中&#xff0c;我们必须轮询文件夹中的新文件&#xff0c;然后在文件内容上触发服务流。 Spring Integration非常适合此要求&#xff0c;因为它带有一个通道适配器 &#xff0c;该适配器可以扫描文件夹中的新文件&…

java扫描指定package注解_java获取包下被指定注解的类

方案一&#xff1a; 采用reflections 框架(此框架依赖com.google.guava)2、项目依赖org.reflectionsreflections0.9.11com.google.guavaguava21.03、实现代码//入参 要扫描的包名Reflections f new Reflections("com.ggband.netty.execute.command");//入参 目标注解…

您将在下一个项目中使用JSF吗?

上周有一篇很棒的stackoverflow博客文章&#xff0c;主题是“ JavaScript框架的残酷生命周期” 。 这篇文章是关于Javascript UI框架&#xff08;angularjs&#xff0c;angular&#xff0c;jquery和react&#xff09;的流行和流行的速度。 这篇文章的关键指标是每月关于框架的问…

java dao层 service层_dao层与service层的区别

service是业务层&#xff0c;dao是数据访问层。这个问题我也曾经考虑过学java的时候&#xff0c;都是在service里直接调用dao&#xff0c;service里面就new一个dao类对象&#xff0c;调用&#xff0c;其他有意义的事没做&#xff0c;也不明白有这个有什么用然后百度了一下我们都…

java heapsort_排序算法笔记:堆排序 HeapSort in java

/*** 堆排序* 简述:* 首先使用建立最大堆的算法建立好最大堆&#xff0c;然后将堆顶元素(最大值)与最后一个值交换&#xff0c;同时使得堆的长度减小1 &#xff0c;调用保持最大堆性质的算法调整&#xff0c;使得堆顶元素成为最大值&#xff0c;此时最后一个元素已被排除在外* …

从Java 10中删除的API

在博客文章“ JDK 10 Release Candidate Phase ”中&#xff0c;我研究了JDK 10可能包含的十二个新功能。 在本文中&#xff0c;我介绍了一些可能会在JDK 10中删除的API&#xff0c;并探讨了一些在JDK 10中建议弃用的API。本文中的信息基于当前版本&#xff08;2018/1 / “ Jav…

使用java自带的日志管理_java日志管理

1.相关概念日志统一框架(日志门面)&#xff1a;apache commons logging、slf4j日志实现框架(实现层)&#xff1a;JDK自带的logging(java.util.logging)、log4j、Java Util Logging、log4j2、logback.(1)JDK自带的logging(java.util.logging)用法&#xff1a;1 importjava.util.…

在会话中使用JWT

在黑客新闻&#xff0c;reddit和博客上&#xff0c;该主题已经讨论了很多次。 共识是–请勿使用JWT&#xff08;用于用户会话&#xff09;。 而且我在很大程度上同意对JWT的典型论点 &#xff0c; 典型的“但我可以使其工作……”的解释以及JWT标准的缺陷的批评 。 。 我不会…

java案例源代码_求java案例源代码 越多越好!

展开全部import java.awt.*;import java.awt.event.*;import java.lang.*;import javax.swing.*;public class Counter extends Frame{//声明三个面板的布局GridLayout gl1,gl2,gl3;Panel p0,p1,p2,p3;JTextField tf1;TextField tf2;Button b0,b1,b2,b3,b4,b5,b6,b7,b8,b9,b10,…

安卓4.4玩java_Android4.4运行过程中闪退java.lang.NoClassDefFoundError

上周五项目测试时发现一个奇怪的Bug&#xff0c;项目中依赖了一个第三方框架&#xff0c;但是在android4.0-4.4.4之间的系统中运行会直接闪退&#xff0c;抛出错误异常为java.lang.NoClassDefFoundError。第一次遇到这样的问题&#xff0c;google了好久找到了以下几个原因&…

java method方法_Java Method.getTypeParameters方法代碼示例

import java.lang.reflect.Method; //導入方法依賴的package包/類private void validateRuleMethod(MethodRuleDefinition, ?> ruleDefinition, Method ruleMethod, RuleSourceValidationProblemCollector problems) {if (Modifier.isPrivate(ruleMethod.getModifiers())) …