Skip to content
体验新版
项目
组织
正在加载...
登录
切换导航
打开侧边栏
Forever310
druid
提交
ee344154
D
druid
项目概览
Forever310
/
druid
与 Fork 源项目一致
从无法访问的项目Fork
通知
3
Star
0
Fork
0
代码
文件
提交
分支
Tags
贡献者
分支图
Diff
Issue
0
列表
看板
标记
里程碑
合并请求
0
DevOps
流水线
流水线任务
计划
Wiki
0
Wiki
分析
仓库
DevOps
项目成员
Pages
D
druid
项目概览
项目概览
详情
发布
仓库
仓库
文件
提交
分支
标签
贡献者
分支图
比较
Issue
0
Issue
0
列表
看板
标记
里程碑
合并请求
0
合并请求
0
Pages
DevOps
DevOps
流水线
流水线任务
计划
分析
分析
仓库分析
DevOps
Wiki
0
Wiki
成员
成员
收起侧边栏
关闭侧边栏
动态
分支图
创建新Issue
流水线任务
提交
Issue看板
体验新版 GitCode,发现更多精彩内容 >>
提交
ee344154
编写于
4月 01, 2014
作者:
X
Xavier Léauté
浏览文件
操作
浏览文件
下载
电子邮件补丁
差异文件
populate cache without materializing results
上级
89dd0ee2
变更
1
隐藏空白更改
内联
并排
Showing
1 changed file
with
23 addition
and
13 deletion
+23
-13
server/src/main/java/io/druid/client/CachePopulatingQueryRunner.java
...main/java/io/druid/client/CachePopulatingQueryRunner.java
+23
-13
未找到文件。
server/src/main/java/io/druid/client/CachePopulatingQueryRunner.java
浏览文件 @
ee344154
...
...
@@ -20,6 +20,8 @@
package
io.druid.client
;
import
com.fasterxml.jackson.databind.ObjectMapper
;
import
com.google.common.base.Function
;
import
com.google.common.collect.ImmutableList
;
import
com.google.common.collect.Lists
;
import
com.metamx.common.guava.Accumulator
;
import
com.metamx.common.guava.Sequence
;
...
...
@@ -33,6 +35,7 @@ import io.druid.query.QueryRunner;
import
io.druid.query.QueryToolChest
;
import
io.druid.query.SegmentDescriptor
;
import
javax.annotation.Nullable
;
import
java.util.ArrayList
;
public
class
CachePopulatingQueryRunner
<
T
>
implements
QueryRunner
<
T
>
...
...
@@ -72,26 +75,33 @@ public class CachePopulatingQueryRunner<T> implements QueryRunner<T>
final
boolean
populateCache
=
Boolean
.
parseBoolean
(
query
.
getContextValue
(
CacheConfig
.
POPULATE_CACHE
,
"true"
))
&&
strategy
!=
null
&&
cacheConfig
.
isPopulateCache
()
// historical only populates distributed cache since the cache lookups are done at broker.
&&
!(
cache
instanceof
MapCache
);
&&
cacheConfig
.
isPopulateCache
();
final
Sequence
<
T
>
results
=
base
.
run
(
query
);
if
(
populateCache
)
{
Sequence
<
T
>
results
=
base
.
run
(
query
);
Cache
.
NamedKey
key
=
CacheUtil
.
computeSegmentCacheKey
(
final
Cache
.
NamedKey
key
=
CacheUtil
.
computeSegmentCacheKey
(
segmentIdentifier
,
segmentDescriptor
,
strategy
.
computeCacheKey
(
query
)
);
ArrayList
<
T
>
resultAsList
=
Sequences
.
toList
(
results
,
new
ArrayList
<
T
>());
CacheUtil
.
populate
(
cache
,
mapper
,
key
,
Lists
.
transform
(
resultAsList
,
strategy
.
prepareForCache
())
final
Function
cacheFn
=
strategy
.
prepareForCache
();
return
Sequences
.
map
(
results
,
new
Function
<
T
,
T
>()
{
@Nullable
@Override
public
T
apply
(
@Nullable
T
input
)
{
CacheUtil
.
populate
(
cache
,
mapper
,
key
,
ImmutableList
.
of
(
cacheFn
.
apply
(
input
)));
return
input
;
}
}
);
return
Sequences
.
simple
(
resultAsList
);
}
else
{
return
base
.
run
(
query
)
;
return
results
;
}
}
...
...
编辑
预览
Markdown
is supported
0%
请重试
或
添加新附件
.
添加附件
取消
You are about to add
0
people
to the discussion. Proceed with caution.
先完成此消息的编辑!
取消
想要评论请
注册
或
登录