ruby-on-rails – Rails 4数据库连接池错误
我有一个使用NGINX和Puma托管的rails应用程序.每10个小时左右,该应用程序将无法使用.每当用户尝试连接时,都会显示以下错误消息:
这将一直持续到应用程序重新启动. 我已经读过这是因为数据库连接池已满,因此必须在rails应用程序中创建线程,这些线程在完成时不会关闭与数据库的连接. 遵循本指南
结束 该站点使用Rails 4.0.0托管.我已经读过这可能实际上是一个Rails 4.0.0问题,并且这在以后的版本中得到修复,但我不确定. >有没有办法监视连接池中活动数据库连接的数量?这将使调试更容易. rails应用程序正在生产环境中运行.如果需要,我可以提供有关我的Puma,NGINX配置的更多信息. 最佳答案
故障安全响应试图分配数据库连接的事实可能是冒烟的枪.它可能有助于您描述故障安全响应中发生的情况.当原始请求触发异常时,可能会触发故障安全响应.在ConnectionManager调用clear_active_connections之后调用调用故障安全响应的rails show_exception例程!对于当前请求(因异常而失败),这意味着在故障安全响应失败后,rails不会自动释放数据库连接.这意味着故障安全响应处理程序负责清理自己的数据库连接.我不确定故障安全响应处理程序是否尝试连接到数据库是好的做法,但如果这是所需的行为,那么您可能必须调用clear_active_connections!显式位于故障安全处理程序的末尾(在ensure块中).
我一直在调查我自己的应用程序中的类似问题,并发现这是一个有用的指南,如何连接工作:https://bibwild.wordpress.com/2014/07/17/activerecord-concurrency-in-rails4-avoid-leaked-connections/.虽然这里引用的代码可能需要一些调整,有一个很好的概述在那里如何去做检测何时创建隐式数据库连接. (编辑:李大同) 【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容! |
- 部署 – Nginx cookbook v 2.0.0:找不到Cookbook http_gz
- Nginx proxy_ssl_certificate未按预期工作
- 如何为使用fastcgi和perlbrew在Nginx上运行的Perl催化剂应用
- Nginx proxy_next_upstream不起作用
- ubuntu – chef-solo错误Errno :: ENOENT:没有这样的文件
- NGINX-正则表达式-在整个位置搜索非字母数字
- 使用opsworks nginx和ELB终止SSL时强制使用HTTPS
- Nginx proxy_pass到密码保护上游
- Nginx在vhost和SSL之间发出问题
- python – 设置Flask uWSGI nginx的最佳实践