Skip to content
体验新版
项目
组织
正在加载...
登录
切换导航
打开侧边栏
梦中观雨
cat
提交
7d22b83a
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,发现更多精彩内容 >>
提交
7d22b83a
编写于
6月 14, 2013
作者:
Y
yong.you
浏览文件
操作
浏览文件
下载
电子邮件补丁
差异文件
fix aggregation rule and domain nav problem
上级
47f550b9
变更
11
隐藏空白更改
内联
并排
Showing
11 changed file
with
105 addition
and
39 deletion
+105
-39
cat-consumer/src/main/java/com/dianping/cat/consumer/core/aggregation/AggregationConfigManager.java
...t/consumer/core/aggregation/AggregationConfigManager.java
+4
-0
cat-consumer/src/main/java/com/dianping/cat/consumer/core/aggregation/AggregationHandler.java
...ing/cat/consumer/core/aggregation/AggregationHandler.java
+1
-1
cat-home/src/main/java/com/dianping/cat/build/ComponentsConfigurator.java
...n/java/com/dianping/cat/build/ComponentsConfigurator.java
+1
-1
cat-home/src/main/java/com/dianping/cat/report/page/AbstractReportModel.java
...ava/com/dianping/cat/report/page/AbstractReportModel.java
+17
-8
cat-home/src/main/java/com/dianping/cat/report/page/AbstractReportPayload.java
...a/com/dianping/cat/report/page/AbstractReportPayload.java
+1
-0
cat-home/src/main/java/com/dianping/cat/report/page/dependency/graph/TopologyGraphManager.java
...at/report/page/dependency/graph/TopologyGraphManager.java
+4
-1
cat-home/src/main/java/com/dianping/cat/report/page/jsError/Handler.java
...in/java/com/dianping/cat/report/page/jsError/Handler.java
+7
-6
cat-home/src/main/java/com/dianping/cat/report/view/DomainNavManager.java
...n/java/com/dianping/cat/report/view/DomainNavManager.java
+17
-12
cat-home/src/main/java/com/dianping/cat/system/page/config/Handler.java
...ain/java/com/dianping/cat/system/page/config/Handler.java
+4
-1
cat-home/src/main/resources/META-INF/plexus/components.xml
cat-home/src/main/resources/META-INF/plexus/components.xml
+30
-9
cat-home/src/test/java/com/dianping/cat/report/page/jsError/JsTest.java
...est/java/com/dianping/cat/report/page/jsError/JsTest.java
+19
-0
未找到文件。
cat-consumer/src/main/java/com/dianping/cat/consumer/core/aggregation/AggregationConfigManager.java
浏览文件 @
7d22b83a
...
...
@@ -33,6 +33,7 @@ public class AggregationConfigManager implements Initializable {
public
boolean
deleteAggregationRule
(
String
rule
)
{
m_aggregation
.
removeAggregationRule
(
rule
);
m_handler
.
register
(
queryAggrarationRules
());
return
storeConfig
();
}
...
...
@@ -68,10 +69,13 @@ public class AggregationConfigManager implements Initializable {
if
(
m_aggregation
==
null
)
{
m_aggregation
=
new
Aggregation
();
}
m_handler
.
register
(
queryAggrarationRules
());
}
public
boolean
insertAggregationRule
(
AggregationRule
rule
)
{
m_aggregation
.
addAggregationRule
(
rule
);
m_handler
.
register
(
queryAggrarationRules
());
return
storeConfig
();
}
...
...
cat-consumer/src/main/java/com/dianping/cat/consumer/core/aggregation/AggregationHandler.java
浏览文件 @
7d22b83a
...
...
@@ -13,7 +13,7 @@ public interface AggregationHandler {
* page type and domain to rule List Map
*/
public
void
register
(
List
<
AggregationRule
>
rules
);
/**
* parse input to output use aggregation rule
*
...
...
cat-home/src/main/java/com/dianping/cat/build/ComponentsConfigurator.java
浏览文件 @
7d22b83a
...
...
@@ -77,7 +77,7 @@ public class ComponentsConfigurator extends AbstractResourceConfigurator {
all
.
add
(
C
(
TopologyGraphBuilder
.
class
).
req
(
TopologyGraphItemBuilder
.
class
).
is
(
PER_LOOKUP
));
all
.
add
(
C
(
TopologyGraphManager
.
class
).
req
(
TopologyGraphBuilder
.
class
,
ServerConfigManager
.
class
)
//
.
req
(
ProductLineConfigManager
.
class
,
TopologyGraphDao
.
class
)
//
.
req
(
ProductLineConfigManager
.
class
,
TopologyGraphDao
.
class
,
DomainNavManager
.
class
)
//
.
req
(
ModelService
.
class
,
"dependency"
));
// report serivce
...
...
cat-home/src/main/java/com/dianping/cat/report/page/AbstractReportModel.java
浏览文件 @
7d22b83a
...
...
@@ -6,10 +6,12 @@ import java.util.Collection;
import
java.util.Date
;
import
java.util.Map
;
import
org.unidal.lookup.ContainerLoader
;
import
org.unidal.web.mvc.Action
;
import
org.unidal.web.mvc.ActionContext
;
import
org.unidal.web.mvc.ViewModel
;
import
com.dianping.cat.Cat
;
import
com.dianping.cat.consumer.core.dal.Project
;
import
com.dianping.cat.report.ReportPage
;
import
com.dianping.cat.report.view.DomainNavManager
;
...
...
@@ -37,8 +39,15 @@ public abstract class AbstractReportModel<A extends Action, M extends ActionCont
private
String
m_reportType
;
private
DomainNavManager
m_manager
;
public
AbstractReportModel
(
M
ctx
)
{
super
(
ctx
);
try
{
m_manager
=
ContainerLoader
.
getDefaultContainer
().
lookup
(
DomainNavManager
.
class
);
}
catch
(
Exception
e
)
{
Cat
.
logError
(
e
);
}
}
public
String
getBaseUri
()
{
...
...
@@ -93,9 +102,9 @@ public abstract class AbstractReportModel<A extends Action, M extends ActionCont
public
String
getDepartment
()
{
String
domain
=
getDomain
();
if
(
domain
!=
null
)
{
Project
project
=
DomainNavM
anager
.
getProjectByName
(
domain
);
if
(
domain
!=
null
&&
m_manager
!=
null
)
{
Project
project
=
m_m
anager
.
getProjectByName
(
domain
);
if
(
project
!=
null
)
{
return
project
.
getDepartment
();
}
...
...
@@ -105,18 +114,18 @@ public abstract class AbstractReportModel<A extends Action, M extends ActionCont
public
String
getProjectLine
()
{
String
domain
=
getDomain
();
if
(
domain
!=
null
)
{
Project
project
=
DomainNavM
anager
.
getProjectByName
(
domain
);
if
(
domain
!=
null
&&
m_manager
!=
null
)
{
Project
project
=
m_m
anager
.
getProjectByName
(
domain
);
if
(
project
!=
null
)
{
return
project
.
getProjectLine
();
}
}
return
"Default"
;
}
public
Map
<
String
,
Department
>
getDomainGroups
()
{
return
DomainNavM
anager
.
getDepartment
(
getDomains
());
return
m_m
anager
.
getDepartment
(
getDomains
());
}
public
Throwable
getException
()
{
...
...
cat-home/src/main/java/com/dianping/cat/report/page/AbstractReportPayload.java
浏览文件 @
7d22b83a
...
...
@@ -46,6 +46,7 @@ public abstract class AbstractReportPayload<A extends Action> implements ActionP
private
SimpleDateFormat
m_dayFormat
=
new
SimpleDateFormat
(
"yyyyMMdd"
);
private
ReportPage
m_defaultPage
;
public
AbstractReportPayload
(
ReportPage
defaultPage
)
{
m_defaultPage
=
defaultPage
;
...
...
cat-home/src/main/java/com/dianping/cat/report/page/dependency/graph/TopologyGraphManager.java
浏览文件 @
7d22b83a
...
...
@@ -58,6 +58,9 @@ public class TopologyGraphManager implements Initializable, LogEnabled {
@Inject
private
TopologyGraphDao
m_topologyGraphDao
;
@Inject
private
DomainNavManager
m_domainNavManager
;
private
Map
<
Long
,
TopologyGraph
>
m_topologyGraphs
=
new
ConcurrentHashMap
<
Long
,
TopologyGraph
>(
360
);
...
...
@@ -282,7 +285,7 @@ public class TopologyGraphManager implements Initializable, LogEnabled {
}
private
Collection
<
String
>
queryAllDomains
()
{
return
D
omainNavManager
.
getDomains
();
return
m_d
omainNavManager
.
getDomains
();
}
@Override
...
...
cat-home/src/main/java/com/dianping/cat/report/page/jsError/Handler.java
浏览文件 @
7d22b83a
...
...
@@ -29,6 +29,8 @@ public class Handler implements PageHandler<Context> {
private
String
m_data
;
private
String
m_referer
;
@Override
@PayloadMeta
(
Payload
.
class
)
@InboundActionMeta
(
name
=
"jsError"
)
...
...
@@ -47,9 +49,8 @@ public class Handler implements PageHandler<Context> {
String
host
=
parseHost
();
if
(
file
==
null
||
file
.
length
()
==
0
||
(!
file
.
startsWith
(
"http:"
)))
{
String
url
=
parseValue
(
"Referer"
,
m_data
);
if
(
url
!=
null
)
{
file
=
url
;
if
(
m_referer
!=
null
)
{
file
=
m_referer
;
}
else
{
file
=
"unknown"
;
}
...
...
@@ -86,11 +87,11 @@ public class Handler implements PageHandler<Context> {
String
type
=
temp
.
getType
();
if
(
type
.
equals
(
"URL.Server"
)
||
type
.
equals
(
"ClientInfo"
))
{
m_data
=
temp
.
getData
().
toString
();
String
url
=
parseValue
(
"Referer"
,
m_data
);
m_referer
=
parseValue
(
"Referer"
,
m_data
);
if
(
url
!=
null
)
{
if
(
m_referer
!=
null
)
{
try
{
URL
u
=
new
URL
(
url
);
URL
u
=
new
URL
(
m_referer
);
return
u
.
getHost
().
toLowerCase
();
}
catch
(
MalformedURLException
e
)
{
break
;
...
...
cat-home/src/main/java/com/dianping/cat/report/view/DomainNavManager.java
浏览文件 @
7d22b83a
...
...
@@ -31,15 +31,15 @@ public class DomainNavManager implements Initializable {
private
ServerConfigManager
m_serverConfigManager
;
// key is domain
private
static
Map
<
String
,
Project
>
m_projects
=
new
ConcurrentHashMap
<
String
,
Project
>();
private
Map
<
String
,
Project
>
m_projects
=
new
ConcurrentHashMap
<
String
,
Project
>();
public
static
final
String
DEFAULT
=
"Default"
;
public
static
Collection
<
String
>
getDomains
()
{
public
Collection
<
String
>
getDomains
()
{
return
m_projects
.
keySet
();
}
public
static
Map
<
String
,
Department
>
getDepartment
(
Collection
<
String
>
domains
)
{
public
Map
<
String
,
Department
>
getDepartment
(
Collection
<
String
>
domains
)
{
Map
<
String
,
Department
>
result
=
new
TreeMap
<
String
,
Department
>();
synchronized
(
m_projects
)
{
...
...
@@ -53,6 +53,7 @@ public class DomainNavManager implements Initializable {
projectLine
=
project
.
getProjectLine
();
}
Department
temp
=
result
.
get
(
department
);
if
(
temp
==
null
)
{
temp
=
new
Department
();
result
.
put
(
department
,
temp
);
...
...
@@ -64,12 +65,16 @@ public class DomainNavManager implements Initializable {
return
result
;
}
public
static
Project
getProjectByName
(
String
domain
)
{
return
m_projects
.
get
(
domain
);
public
Project
getProjectByName
(
String
domain
)
{
synchronized
(
m_projects
)
{
return
m_projects
.
get
(
domain
);
}
}
public
static
Map
<
String
,
Project
>
getProjects
()
{
return
m_projects
;
public
Map
<
String
,
Project
>
getProjects
()
{
synchronized
(
m_projects
)
{
return
m_projects
;
}
}
@Override
...
...
@@ -81,18 +86,18 @@ public class DomainNavManager implements Initializable {
}
public
void
reloadDomainInfo
()
{
synchronized
(
m_projects
)
{
try
{
List
<
Project
>
projects
=
m_projectDao
.
findAll
(
ProjectEntity
.
READSET_FULL
);
try
{
List
<
Project
>
projects
=
m_projectDao
.
findAll
(
ProjectEntity
.
READSET_FULL
);
synchronized
(
m_projects
)
{
if
(
projects
.
size
()
>
0
)
{
for
(
Project
project
:
projects
)
{
m_projects
.
put
(
project
.
getDomain
(),
project
);
}
}
}
catch
(
DalException
e
)
{
Cat
.
logError
(
e
);
}
}
catch
(
DalException
e
)
{
Cat
.
logError
(
e
);
}
}
...
...
cat-home/src/main/java/com/dianping/cat/system/page/config/Handler.java
浏览文件 @
7d22b83a
...
...
@@ -47,6 +47,9 @@ public class Handler implements PageHandler<Context> {
@Inject
private
AggregationConfigManager
m_aggreationConfigManager
;
@Inject
private
DomainNavManager
m_manager
;
private
void
deleteAggregationRule
(
Payload
payload
)
{
m_aggreationConfigManager
.
deleteAggregationRule
(
payload
.
getPattern
());
...
...
@@ -250,7 +253,7 @@ public class Handler implements PageHandler<Context> {
try
{
m_projectDao
.
updateByPK
(
project
,
ProjectEntity
.
UPDATESET_FULL
);
DomainNavM
anager
.
getProjects
().
put
(
project
.
getDomain
(),
project
);
m_m
anager
.
getProjects
().
put
(
project
.
getDomain
(),
project
);
}
catch
(
DalException
e
)
{
Cat
.
logError
(
e
);
}
...
...
cat-home/src/main/resources/META-INF/plexus/components.xml
浏览文件 @
7d22b83a
...
...
@@ -142,6 +142,9 @@
<requirement>
<role>
com.dianping.cat.home.dal.report.TopologyGraphDao
</role>
</requirement>
<requirement>
<role>
com.dianping.cat.report.view.DomainNavManager
</role>
</requirement>
<requirement>
<role>
com.dianping.cat.report.page.model.spi.ModelService
</role>
<role-hint>
dependency
</role-hint>
...
...
@@ -2715,6 +2718,9 @@
<requirement>
<role>
com.dianping.cat.home.dal.report.TopologyGraphDao
</role>
</requirement>
<requirement>
<role>
com.dianping.cat.report.view.DomainNavManager
</role>
</requirement>
</requirements>
</component>
<component>
...
...
@@ -2739,6 +2745,27 @@
</requirement>
</requirements>
</component>
<component>
<role>
com.dianping.cat.report.view.DomainNavManager
</role>
<implementation>
com.dianping.cat.report.view.DomainNavManager
</implementation>
<requirements>
<requirement>
<role>
com.dianping.cat.consumer.core.dal.ProjectDao
</role>
</requirement>
<requirement>
<role>
com.dianping.cat.configuration.ServerConfigManager
</role>
</requirement>
</requirements>
</component>
<component>
<role>
com.dianping.cat.consumer.core.dal.ProjectDao
</role>
<implementation>
com.dianping.cat.consumer.core.dal.ProjectDao
</implementation>
<requirements>
<requirement>
<role>
org.unidal.dal.jdbc.QueryEngine
</role>
</requirement>
</requirements>
</component>
<component>
<role>
com.dianping.cat.report.page.dependency.JspViewer
</role>
<implementation>
com.dianping.cat.report.page.dependency.JspViewer
</implementation>
...
...
@@ -3007,6 +3034,9 @@
<requirement>
<role>
com.dianping.cat.consumer.core.aggregation.AggregationConfigManager
</role>
</requirement>
<requirement>
<role>
com.dianping.cat.report.view.DomainNavManager
</role>
</requirement>
</requirements>
</component>
<component>
...
...
@@ -3018,15 +3048,6 @@
</requirement>
</requirements>
</component>
<component>
<role>
com.dianping.cat.consumer.core.dal.ProjectDao
</role>
<implementation>
com.dianping.cat.consumer.core.dal.ProjectDao
</implementation>
<requirements>
<requirement>
<role>
org.unidal.dal.jdbc.QueryEngine
</role>
</requirement>
</requirements>
</component>
<component>
<role>
com.dianping.cat.report.page.dependency.graph.TopologyGraphConfigManager
</role>
<implementation>
com.dianping.cat.report.page.dependency.graph.TopologyGraphConfigManager
</implementation>
...
...
cat-home/src/test/java/com/dianping/cat/report/page/jsError/JsTest.java
浏览文件 @
7d22b83a
...
...
@@ -40,5 +40,24 @@ public class JsTest {
return
sb
.
toString
();
}
@Test
public
void
test2
()
throws
Exception
{
for
(
int
i
=
0
;
i
<
1000
;
i
++)
{
URL
url
=
new
URL
(
"http://localhost:2281/cat/r/jsError?error=Script%20error.&file=&line=0×tamp=1371196520045"
);
URLConnection
URLconnection
=
url
.
openConnection
();
URLconnection
.
setRequestProperty
(
"User-Agent"
,
"Mozilla/4.0 (compatible; MSIE 7.0; Windows NT 5.1; Maxthon;)"
);
URLconnection
.
setRequestProperty
(
"referer"
,
"http://www.dianping.com/shop/1"
);
HttpURLConnection
httpConnection
=
(
HttpURLConnection
)
URLconnection
;
int
responseCode
=
httpConnection
.
getResponseCode
();
if
(
responseCode
==
HttpURLConnection
.
HTTP_OK
)
{
}
else
{
}
Thread
.
sleep
(
100
);
}
}
}
编辑
预览
Markdown
is supported
0%
请重试
或
添加新附件
.
添加附件
取消
You are about to add
0
people
to the discussion. Proceed with caution.
先完成此消息的编辑!
取消
想要评论请
注册
或
登录