Skip to content
体验新版
项目
组织
正在加载...
登录
切换导航
打开侧边栏
张重言
rails
提交
cde7692d
R
rails
项目概览
张重言
/
rails
通知
1
Star
0
Fork
0
代码
文件
提交
分支
Tags
贡献者
分支图
Diff
Issue
0
列表
看板
标记
里程碑
合并请求
0
Wiki
0
Wiki
分析
仓库
DevOps
项目成员
Pages
R
rails
项目概览
项目概览
详情
发布
仓库
仓库
文件
提交
分支
标签
贡献者
分支图
比较
Issue
0
Issue
0
列表
看板
标记
里程碑
合并请求
0
合并请求
0
Pages
分析
分析
仓库分析
DevOps
Wiki
0
Wiki
成员
成员
收起侧边栏
关闭侧边栏
动态
分支图
创建新Issue
提交
Issue看板
体验新版 GitCode,发现更多精彩内容 >>
提交
cde7692d
编写于
12月 30, 2011
作者:
A
Aaron Patterson
浏览文件
操作
浏览文件
下载
电子邮件补丁
差异文件
introduce a timer class for reaping connections
上级
cceabe03
变更
2
隐藏空白更改
内联
并排
Showing
2 changed file
with
65 addition
and
0 deletion
+65
-0
activerecord/lib/active_record/connection_adapters/abstract/connection_pool.rb
...ve_record/connection_adapters/abstract/connection_pool.rb
+19
-0
activerecord/test/cases/reaper_test.rb
activerecord/test/cases/reaper_test.rb
+46
-0
未找到文件。
activerecord/lib/active_record/connection_adapters/abstract/connection_pool.rb
浏览文件 @
cde7692d
...
...
@@ -64,6 +64,25 @@ module ConnectionAdapters
# * +wait_timeout+: number of seconds to block and wait for a connection
# before giving up and raising a timeout error (default 5 seconds).
class
ConnectionPool
class
Reaper
attr_reader
:pool
,
:frequency
def
initialize
(
pool
,
frequency
)
@pool
=
pool
@frequency
=
frequency
end
def
start
return
unless
frequency
Thread
.
new
(
frequency
,
pool
)
{
|
t
,
p
|
while
true
sleep
t
p
.
reap
end
}
end
end
include
MonitorMixin
attr_accessor
:automatic_reconnect
,
:timeout
...
...
activerecord/test/cases/reaper_test.rb
0 → 100644
浏览文件 @
cde7692d
require
"cases/helper"
module
ActiveRecord
module
ConnectionAdapters
class
ReaperTest
<
ActiveRecord
::
TestCase
attr_reader
:pool
def
setup
super
@pool
=
ConnectionPool
.
new
ActiveRecord
::
Base
.
connection_pool
.
spec
end
def
teardown
super
@pool
.
connections
.
each
(
&
:close
)
end
# A reaper with nil time should never reap connections
def
test_nil_time
conn
=
pool
.
checkout
pool
.
timeout
=
0
count
=
pool
.
connections
.
length
conn
.
extend
(
Module
.
new
{
def
active?
;
false
;
end
;
})
reaper
=
ConnectionPool
::
Reaper
.
new
(
pool
,
nil
)
reaper
.
start
sleep
0.0001
assert_equal
count
,
pool
.
connections
.
length
end
def
test_some_time
conn
=
pool
.
checkout
pool
.
timeout
=
0
count
=
pool
.
connections
.
length
conn
.
extend
(
Module
.
new
{
def
active?
;
false
;
end
;
})
reaper
=
ConnectionPool
::
Reaper
.
new
(
pool
,
0.0001
)
reaper
.
start
sleep
0.0002
assert_equal
(
count
-
1
,
pool
.
connections
.
length
)
end
end
end
end
编辑
预览
Markdown
is supported
0%
请重试
或
添加新附件
.
添加附件
取消
You are about to add
0
people
to the discussion. Proceed with caution.
先完成此消息的编辑!
取消
想要评论请
注册
或
登录