jjzjj

java - DBCP2 - 何时从池中删除空闲连接

coder 2024-03-10 原文

配置 DBCP2 池时,基于 documentation我注意到 - 有一个名为 timeBetweenEvictionRunsMillis 的配置,描述为:

The number of milliseconds to sleep between runs of the idle object evictor thread. When non-positive, no idle object evictor thread will be run.

它的默认值为-1

这是否意味着逐出线程永远不会在默认配置下运行?那么配置参数 maxIdle 是如何强制执行的 - 如果空闲连接的数量大于 maxIdle,池必须驱逐空闲连接。

让我感到很困惑的是默认配置是空闲连接永远不会被驱逐。

还有另一种配置softMiniEvictableIdleTimeMillis,它似乎在timeBetweenEvictionRunsMillis之上发挥了一些作用。

在这方面的任何澄清都将提供巨大的帮助。

目前,我正在如下配置池 - 因为我的目标是在我的池中没有任何空闲连接太久(这是必需的,因为我们正在使用 AWS RDS,并且似乎有 a weird issue 与我们经常遇到的)

    BasicDataSource dataSource = new BasicDataSource();
    dataSource.setDriverClassName("com.mysql.jdbc.Driver");
    dataSource.setUrl(properties.getProperty("app.mysql.url"));
    dataSource.setUsername(properties.getProperty("app.mysql.username"));
    dataSource.setPassword(properties.getProperty("app.mysql.password"));
    dataSource.setMaxIdle(20);
    dataSource.setMaxWaitMillis(20000); //wait 10 seconds to get new connection
    dataSource.setMaxTotal(200);
    dataSource.setMinIdle(0);
    dataSource.setInitialSize(10);
    dataSource.setTestOnBorrow(true);
    dataSource.setValidationQuery("select 1");
    dataSource.setValidationQueryTimeout(10); //The value is in seconds

    dataSource.setTimeBetweenEvictionRunsMillis(600000); // 10 minutes wait to run evictor process
    dataSource.setSoftMinEvictableIdleTimeMillis(600000); // 10 minutes wait to run evictor process
    dataSource.setMinEvictableIdleTimeMillis(60000); // 60 seconds to wait before idle connection is evicted
    dataSource.setMaxConnLifetimeMillis(600000); // 10 minutes is max life time
    dataSource.setNumTestsPerEvictionRun(10);

最佳答案

是的,驱逐线程默认不会运行。原因是maxIdlemaxTotal的值默认是一样的,也就是说不会有连接立即关闭,也不需要驱逐空闲连接。因此,池只是通过不运行无用的线程来节省一些资源。

但是当你改变 maxIdle 并使其低于 maxTotal 而没有启动 evictor 线程时,这并不意味着你的连接不会被关闭。这意味着它们将在释放后立即关闭,没有延迟,直到它们的计数不下降到 maxIdle

然后 minEvictableIdleTimeMillissoftMinEvictableIdleTimeMillis 开始发挥作用(小心,文档中有错别字,它是 ... MinEvictalbe...,而不是 ...MiniEvictable...)。它们之间的区别在于前者不遵守 minIdle 而后者遵守。这有点棘手,因为 softMinEvictableIdleTimeMillis 仅在 minEvictableIdleTimeMillis 已过时检查。

假设我们有 minEvictableIdleTimeMillis=10000softMinEvictableIdleTimeMillis=-1(默认情况下)。在这种情况下,空闲连接将在池中保留不超过 10 秒。即使连接数没有超过minIdle,也会被关闭。如果它导致连接计数低于 minIdle,将立即创建一个新连接。

现在,假设我们有 minEvictableIdleTimeMillis=10000softMinEvictableIdleTimeMillis=30000。在这种情况下,在检查 minEvictableIdleTimeMillis 和检测到超出之后的空闲连接将另外检查 softMinEvictableIdleTimeMillis。如果空闲时间超过它,连接将被关闭。否则,它将在池中等待下一次针对 minEvictableIdleTimeMillis 的肯定检查。

最终,您将立即关闭 maxTotalmaxIdle 之间的连接,maxIdleminIdle 之间的连接minEvictableIdleTimeMillis 后关闭,minIdle0 之间的连接在 softMinEvictableIdleTimeMillis 后关闭并立即重新打开。给予或接受驱逐检查期。

根据您的配置,当池大于 20 时,您将立即关闭所有连接。这 20 个连接将存在 10 到 20 分钟(即使空闲),因为您有 10 分钟的 EvictableIdleTimeMillis 加上 10 分钟的 TimeBetweenEvictionRunsMillis

我还想提一下 maxIdlemaxTotal 之间存在较大差距的潜在问题。如果您预计 maxIdle 会经常被超出,最好增加它。否则,您将面临持续的连接打开和关闭,这会给您的数据库(因为建立新的数据库连接是相对繁重的操作)和应用程序服务器网络基础设施(因为关闭的连接将挂起在 TIME_WAIT 状态,耗尽您的网络端口)带来额外的压力池)。

关于java - DBCP2 - 何时从池中删除空闲连接,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/38685092/

有关java - DBCP2 - 何时从池中删除空闲连接的更多相关文章

  1. ruby-on-rails - 如何从 format.xml 中删除 <hash></hash> - 2

    我有一个对象has_many应呈现为xml的子对象。这不是问题。我的问题是我创建了一个Hash包含此数据,就像解析器需要它一样。但是rails自动将整个文件包含在.........我需要摆脱type="array"和我该如何处理?我没有在文档中找到任何内容。 最佳答案 我遇到了同样的问题;这是我的XML:我在用这个:entries.to_xml将散列数据转换为XML,但这会将条目的数据包装到中所以我修改了:entries.to_xml(root:"Contacts")但这仍然将转换后的XML包装在“联系人”中,将我的XML代码修改为

  2. ruby - 我可以使用 Ruby 从 CSV 中删除列吗? - 2

    查看Ruby的CSV库的文档,我非常确定这是可能且简单的。我只需要使用Ruby删除CSV文件的前三列,但我没有成功运行它。 最佳答案 csv_table=CSV.read(file_path_in,:headers=>true)csv_table.delete("header_name")csv_table.to_csv#=>ThenewCSVinstringformat检查CSV::Table文档:http://ruby-doc.org/stdlib-1.9.2/libdoc/csv/rdoc/CSV/Table.html

  3. ruby - 我可以使用 aws-sdk-ruby 在 AWS S3 上使用事务性文件删除/上传吗? - 2

    我发现ActiveRecord::Base.transaction在复杂方法中非常有效。我想知道是否可以在如下事务中从AWSS3上传/删除文件:S3Object.transactiondo#writeintofiles#raiseanexceptionend引发异常后,每个操作都应在S3上回滚。S3Object这可能吗?? 最佳答案 虽然S3API具有批量删除功能,但它不支持事务,因为每个删除操作都可以独立于其他操作成功/失败。该API不提供任何批量上传功能(通过PUT或POST),因此每个上传操作都是通过一个独立的API调用完成的

  4. java - 等价于 Java 中的 Ruby Hash - 2

    我真的很习惯使用Ruby编写以下代码:my_hash={}my_hash['test']=1Java中对应的数据结构是什么? 最佳答案 HashMapmap=newHashMap();map.put("test",1);我假设? 关于java-等价于Java中的RubyHash,我们在StackOverflow上找到一个类似的问题: https://stackoverflow.com/questions/22737685/

  5. java - 从 JRuby 调用 Java 类的问题 - 2

    我正在尝试使用boilerpipe来自JRuby。我看过guide从JRuby调用Java,并成功地将它与另一个Java包一起使用,但无法弄清楚为什么同样的东西不能用于boilerpipe。我正在尝试基本上从JRuby中执行与此Java等效的操作:URLurl=newURL("http://www.example.com/some-location/index.html");Stringtext=ArticleExtractor.INSTANCE.getText(url);在JRuby中试过这个:require'java'url=java.net.URL.new("http://www

  6. ruby - 如何安全地删除文件? - 2

    在Ruby中是否有Gem或安全删除文件的方法?我想避免系统上可能不存在的外部程序。“安全删除”指的是覆盖文件内容。 最佳答案 如果您使用的是*nix,一个很好的方法是使用exec/open3/open4调用shred:`shred-fxuz#{filename}`http://www.gnu.org/s/coreutils/manual/html_node/shred-invocation.html检查这个类似的帖子:Writingafileshredderinpythonorruby?

  7. java - 我的模型类或其他类中应该有逻辑吗 - 2

    我只想对我一直在思考的这个问题有其他意见,例如我有classuser_controller和classuserclassUserattr_accessor:name,:usernameendclassUserController//dosomethingaboutanythingaboutusersend问题是我的User类中是否应该有逻辑user=User.newuser.do_something(user1)oritshouldbeuser_controller=UserController.newuser_controller.do_something(user1,user2)我

  8. java - 什么相当于 ruby​​ 的 rack 或 python 的 Java wsgi? - 2

    什么是ruby​​的rack或python的Java的wsgi?还有一个路由库。 最佳答案 来自Python标准PEP333:Bycontrast,althoughJavahasjustasmanywebapplicationframeworksavailable,Java's"servlet"APImakesitpossibleforapplicationswrittenwithanyJavawebapplicationframeworktoruninanywebserverthatsupportstheservletAPI.ht

  9. ruby-on-rails - 标准化文件名的字符串,删除重音和特殊字符 - 2

    我正在尝试找到一种方法来规范化字符串以将其作为文件名传递。到目前为止我有这个:my_string.mb_chars.normalize(:kd).gsub(/[^\x00-\x7F]/n,'').downcase.gsub(/[^a-z]/,'_')但第一个问题:-字符。我猜这个方法还有更多问题。我不控制名称,名称字符串可以有重音符、空格和特殊字符。我想删除所有这些,用相应的字母('é'=>'e')替换重音符号,并将其余的替换为'_'字符。名字是这样的:“Prélèvements-常规”“健康证”...我希望它们像一个没有空格/特殊字符的文件名:“prelevements_routin

  10. Observability:从零开始创建 Java 微服务并监控它 (二) - 2

    这篇文章是继上一篇文章“Observability:从零开始创建Java微服务并监控它(一)”的续篇。在上一篇文章中,我们讲述了如何创建一个Javaweb应用,并使用Filebeat来收集应用所生成的日志。在今天的文章中,我来详述如何收集应用的指标,使用APM来监控应用并监督web服务的在线情况。源码可以在地址 https://github.com/liu-xiao-guo/java_observability 进行下载。摄入指标指标被视为可以随时更改的时间点值。当前请求的数量可以改变任何毫秒。你可能有1000个请求的峰值,然后一切都回到一个请求。这也意味着这些指标可能不准确,你还想提取最小/

随机推荐