Skip to content
体验新版
项目
组织
正在加载...
登录
切换导航
打开侧边栏
apache
SkyWalking
提交
022bf381
S
SkyWalking
项目概览
apache
/
SkyWalking
上一次同步 1 年多
通知
302
Star
21345
Fork
6091
代码
文件
提交
分支
Tags
贡献者
分支图
Diff
Issue
0
列表
看板
标记
里程碑
合并请求
0
Wiki
0
Wiki
分析
仓库
DevOps
项目成员
Pages
S
SkyWalking
项目概览
项目概览
详情
发布
仓库
仓库
文件
提交
分支
标签
贡献者
分支图
比较
Issue
0
Issue
0
列表
看板
标记
里程碑
合并请求
0
合并请求
0
Pages
分析
分析
仓库分析
DevOps
Wiki
0
Wiki
成员
成员
收起侧边栏
关闭侧边栏
动态
分支图
创建新Issue
提交
Issue看板
前往新版Gitcode,体验更适合开发者的 AI 搜索 >>
未验证
提交
022bf381
编写于
7月 03, 2021
作者:
D
Daming
提交者:
GitHub
7月 03, 2021
浏览文件
操作
浏览文件
下载
电子邮件补丁
差异文件
Fix InfluxDB storage-plugin Metrics#multiGet issue (#7238)
上级
0f62d928
变更
2
隐藏空白更改
内联
并排
Showing
2 changed file
with
28 addition
and
18 deletion
+28
-18
CHANGES.md
CHANGES.md
+1
-0
oap-server/server-storage-plugin/storage-influxdb-plugin/src/main/java/org/apache/skywalking/oap/server/storage/plugin/influxdb/base/MetricsDAO.java
...g/oap/server/storage/plugin/influxdb/base/MetricsDAO.java
+27
-18
未找到文件。
CHANGES.md
浏览文件 @
022bf381
...
...
@@ -69,6 +69,7 @@ Release Notes.
*
Re-implement storage session mechanism, cached metrics are removed only according to their last access timestamp,
rather than first time. This makes sure hot data never gets removed unexpectedly.
*
Support session expired threshold configurable.
*
Fix InfluxDB storage-plugin Metrics#multiGet issue.
#### UI
...
...
oap-server/server-storage-plugin/storage-influxdb-plugin/src/main/java/org/apache/skywalking/oap/server/storage/plugin/influxdb/base/MetricsDAO.java
浏览文件 @
022bf381
...
...
@@ -21,9 +21,11 @@ package org.apache.skywalking.oap.server.storage.plugin.influxdb.base;
import
com.google.common.collect.Lists
;
import
com.google.common.collect.Maps
;
import
java.io.IOException
;
import
java.util.Collection
;
import
java.util.Collections
;
import
java.util.List
;
import
java.util.Map
;
import
java.util.Objects
;
import
java.util.concurrent.TimeUnit
;
import
java.util.function.Function
;
import
java.util.stream.Collectors
;
...
...
@@ -39,6 +41,7 @@ import org.apache.skywalking.oap.server.core.storage.model.Model;
import
org.apache.skywalking.oap.server.core.storage.type.StorageDataComplexObject
;
import
org.apache.skywalking.oap.server.library.client.request.InsertRequest
;
import
org.apache.skywalking.oap.server.library.client.request.UpdateRequest
;
import
org.apache.skywalking.oap.server.library.util.CollectionUtils
;
import
org.apache.skywalking.oap.server.storage.plugin.influxdb.InfluxClient
;
import
org.apache.skywalking.oap.server.storage.plugin.influxdb.InfluxConstants.TagName
;
import
org.apache.skywalking.oap.server.storage.plugin.influxdb.TableMetaInfo
;
...
...
@@ -103,32 +106,38 @@ public class MetricsDAO implements IMetricsDAO {
}
final
Query
query
=
new
Query
(
queryStr
);
QueryResult
.
Series
series
=
client
.
queryForSingleSeries
(
query
);
final
List
<
QueryResult
.
Result
>
results
=
client
.
query
(
query
);
if
(
log
.
isDebugEnabled
())
{
log
.
debug
(
"SQL: {} result: {}"
,
query
.
getCommand
(),
serie
s
);
log
.
debug
(
"SQL: {} result: {}"
,
query
.
getCommand
(),
result
s
);
}
if
(
series
==
null
)
{
if
(
CollectionUtils
.
isEmpty
(
results
)
)
{
return
Collections
.
emptyList
();
}
final
List
<
Metrics
>
newMetrics
=
Lists
.
newArrayList
();
final
List
<
String
>
columns
=
series
.
getColumns
();
final
Map
<
String
,
String
>
storageAndColumnMap
=
metaInfo
.
getStorageAndColumnMap
();
series
.
getValues
().
forEach
(
values
->
{
Map
<
String
,
Object
>
data
=
Maps
.
newHashMap
();
for
(
int
i
=
1
;
i
<
columns
.
size
();
i
++)
{
Object
value
=
values
.
get
(
i
);
if
(
value
instanceof
StorageDataComplexObject
)
{
value
=
((
StorageDataComplexObject
)
value
).
toStorageData
();
}
data
.
put
(
storageAndColumnMap
.
get
(
columns
.
get
(
i
)),
value
);
}
newMetrics
.
add
(
storageBuilder
.
storage2Entity
(
data
));
});
results
.
stream
()
.
map
(
QueryResult
.
Result
::
getSeries
)
.
filter
(
Objects:
:
nonNull
)
.
flatMap
(
Collection:
:
stream
)
.
filter
(
Objects:
:
nonNull
)
.
forEach
(
series
->
{
final
List
<
String
>
columns
=
series
.
getColumns
();
series
.
getValues
().
forEach
(
values
->
{
Map
<
String
,
Object
>
data
=
Maps
.
newHashMap
();
for
(
int
i
=
1
;
i
<
columns
.
size
();
i
++)
{
Object
value
=
values
.
get
(
i
);
if
(
value
instanceof
StorageDataComplexObject
)
{
value
=
((
StorageDataComplexObject
)
value
).
toStorageData
();
}
data
.
put
(
storageAndColumnMap
.
get
(
columns
.
get
(
i
)),
value
);
}
newMetrics
.
add
(
storageBuilder
.
storage2Entity
(
data
));
});
});
return
newMetrics
;
}
...
...
编辑
预览
Markdown
is supported
0%
请重试
或
添加新附件
.
添加附件
取消
You are about to add
0
people
to the discussion. Proceed with caution.
先完成此消息的编辑!
取消
想要评论请
注册
或
登录