Skip to content
体验新版
项目
组织
正在加载...
登录
切换导航
打开侧边栏
梦中观雨
cat
提交
2205d288
C
cat
项目概览
梦中观雨
/
cat
与 Fork 源项目一致
从无法访问的项目Fork
通知
1
Star
0
Fork
0
代码
文件
提交
分支
Tags
贡献者
分支图
Diff
Issue
0
列表
看板
标记
里程碑
合并请求
0
Wiki
0
Wiki
分析
仓库
DevOps
项目成员
Pages
C
cat
项目概览
项目概览
详情
发布
仓库
仓库
文件
提交
分支
标签
贡献者
分支图
比较
Issue
0
Issue
0
列表
看板
标记
里程碑
合并请求
0
合并请求
0
Pages
分析
分析
仓库分析
DevOps
Wiki
0
Wiki
成员
成员
收起侧边栏
关闭侧边栏
动态
分支图
创建新Issue
提交
Issue看板
体验新版 GitCode,发现更多精彩内容 >>
提交
2205d288
编写于
4月 07, 2013
作者:
Y
yong.you
浏览文件
操作
浏览文件
下载
电子邮件补丁
差异文件
metric report add conversion rate graph
上级
614b2436
变更
5
隐藏空白更改
内联
并排
Showing
5 changed file
with
58 addition
and
6 deletion
+58
-6
cat-home/src/main/java/com/dianping/cat/report/page/metric/Handler.java
...ain/java/com/dianping/cat/report/page/metric/Handler.java
+2
-0
cat-home/src/main/java/com/dianping/cat/report/page/metric/MetricDisplay.java
...va/com/dianping/cat/report/page/metric/MetricDisplay.java
+41
-2
cat-home/src/main/webapp/jsp/report/metric.jsp
cat-home/src/main/webapp/jsp/report/metric.jsp
+12
-0
cat-home/src/test/java/com/dianping/cat/demo/TestBusinessMessage.java
.../test/java/com/dianping/cat/demo/TestBusinessMessage.java
+2
-3
pom.xml
pom.xml
+1
-1
未找到文件。
cat-home/src/main/java/com/dianping/cat/report/page/metric/Handler.java
浏览文件 @
2205d288
...
...
@@ -67,6 +67,8 @@ public class Handler implements PageHandler<Context> {
display
.
visitMetricReport
(
report
);
display
.
buildConvertRate
(
"/index"
,
"/detail"
);
display
.
buildConvertRate
(
"/detail"
,
"/order/submitOrder"
);
model
.
setDisplay
(
display
);
model
.
setReport
(
report
);
}
...
...
cat-home/src/main/java/com/dianping/cat/report/page/metric/MetricDisplay.java
浏览文件 @
2205d288
...
...
@@ -19,12 +19,16 @@ public class MetricDisplay extends BaseVisitor {
private
Map
<
String
,
GraphItem
>
m_metrics
=
new
LinkedHashMap
<
String
,
GraphItem
>();
private
Map
<
String
,
GraphItem
>
m_conversionRates
=
new
LinkedHashMap
<
String
,
GraphItem
>();
private
String
m_key
;
private
Date
m_start
;
private
MetricConfig
m_config
;
private
static
final
String
COUNT
=
":count"
;
public
MetricDisplay
(
MetricConfig
metricConfig
,
Date
start
)
{
m_config
=
metricConfig
;
m_start
=
start
;
...
...
@@ -35,7 +39,7 @@ public class MetricDisplay extends BaseVisitor {
m_metrics
.
put
(
title
,
new
GraphItem
(
m_start
,
title
,
flag
.
getKey
()));
}
if
(
flag
.
isShowCount
())
{
String
title
=
flag
.
getKey
()
+
":count"
;
String
title
=
flag
.
getKey
()
+
COUNT
;
m_metrics
.
put
(
title
,
new
GraphItem
(
m_start
,
title
,
flag
.
getKey
()));
}
if
(
flag
.
isShowAvg
())
{
...
...
@@ -45,6 +49,33 @@ public class MetricDisplay extends BaseVisitor {
}
}
public
MetricDisplay
buildConvertRate
(
String
key1
,
String
key2
)
{
GraphItem
item1
=
m_metrics
.
get
(
key1
+
COUNT
);
GraphItem
item2
=
m_metrics
.
get
(
key2
+
COUNT
);
if
(
item1
!=
null
&&
item2
!=
null
)
{
String
key
=
key1
+
":"
+
key2
;
GraphItem
item
=
new
GraphItem
(
m_start
,
key1
+
" to "
+
key2
+
" Conversion Rate"
,
key
);
double
[]
value1
=
item1
.
getValues
();
double
[]
value2
=
item2
.
getValues
();
int
size
=
item
.
getSize
();
double
[]
value
=
new
double
[
size
];
for
(
int
i
=
0
;
i
<
size
;
i
++)
{
if
(
value1
[
i
]
>
0
)
{
value
[
i
]
=
value2
[
i
]
/
value1
[
i
];
}
}
item
.
setValues
(
value
);
m_conversionRates
.
put
(
key
,
item
);
}
return
this
;
}
public
List
<
GraphItem
>
getConversionRates
()
{
return
new
ArrayList
<
GraphItem
>(
m_conversionRates
.
values
());
}
public
List
<
GraphItem
>
getGroups
()
{
return
new
ArrayList
<
GraphItem
>(
m_metrics
.
values
());
}
...
...
@@ -154,7 +185,15 @@ public class MetricDisplay extends BaseVisitor {
public
String
getKey
()
{
return
key
;
}
public
double
[]
getValues
()
{
return
values
;
}
public
void
setValues
(
double
[]
values
)
{
this
.
values
=
values
;
}
}
}
cat-home/src/main/webapp/jsp/report/metric.jsp
浏览文件 @
2205d288
...
...
@@ -34,7 +34,14 @@
graph
(
document
.
getElementById
(
'
${item.title}
'
),
data
);
</c:forEach>
<c:forEach
var=
"item"
items=
"
${
model
.
display
.
conversionRates
}
"
varStatus=
"status"
>
var
data
=
$
{
item
.
jsonString
};
graph
(
document
.
getElementById
(
'
${item.title}
'
),
data
);
</c:forEach>
});
</script>
<div
class=
"report"
>
<table
class=
"header"
>
...
...
@@ -65,6 +72,11 @@
<c:forEach
var=
"item"
items=
"
${
model
.
display
.
groups
}
"
varStatus=
"status"
>
<div
style=
"float:left;"
id=
"${item.title}"
class=
"graph"
></div>
</c:forEach>
<h3
class=
'text-center'
>
页面实时转化率
</h3>
<c:forEach
var=
"item"
items=
"
${
model
.
display
.
conversionRates
}
"
varStatus=
"status"
>
<div
style=
"float:left;"
id=
"${item.title}"
class=
"graph"
></div>
</c:forEach>
</div>
</div></div>
<table
class=
"footer"
>
...
...
cat-home/src/test/java/com/dianping/cat/demo/TestBusinessMessage.java
浏览文件 @
2205d288
...
...
@@ -14,16 +14,15 @@ public class TestBusinessMessage {
for
(
int
i
=
0
;
i
<
1000
;
i
++)
{
Transaction
t
=
Cat
.
newTransaction
(
"URL"
,
"/index"
);
Cat
.
logMetric
(
"order"
,
"quantity"
,
i
);
t
.
complete
();
}
for
(
int
i
=
0
;
i
<
10
00
;
i
++)
{
for
(
int
i
=
0
;
i
<
9
00
;
i
++)
{
Transaction
t
=
Cat
.
newTransaction
(
"URL"
,
"/detail"
);
Cat
.
logMetric
(
"payment.pending"
,
"amount"
,
i
);
t
.
complete
();
}
for
(
int
i
=
0
;
i
<
10
00
;
i
++)
{
for
(
int
i
=
0
;
i
<
5
00
;
i
++)
{
Transaction
t
=
Cat
.
newTransaction
(
"URL"
,
"/order/submitOrder"
);
Cat
.
logMetric
(
"payment.success"
,
"amount"
,
i
);
...
...
pom.xml
浏览文件 @
2205d288
...
...
@@ -212,7 +212,7 @@ org.eclipse.jdt.core.compiler.compliance=1.6
<distributionManagement>
<repository>
<id>
dianping.repo
</id>
<url>
http://192.168.8.45:8080/artifactory/dianping
-release
s
</url>
<url>
http://192.168.8.45:8080/artifactory/dianping
.repo.snapshot
s
</url>
</repository>
</distributionManagement>
<properties>
...
...
编辑
预览
Markdown
is supported
0%
请重试
或
添加新附件
.
添加附件
取消
You are about to add
0
people
to the discussion. Proceed with caution.
先完成此消息的编辑!
取消
想要评论请
注册
或
登录