README.md 5.9 KB
Newer Older
1 2 3 4
**CAT**
 [![Build Status](https://travis-ci.org/dianping/cat.png?branch=master)](https://travis-ci.org/dianping/cat)
 [![GitHub stars](https://img.shields.io/github/stars/dianping/cat.svg?style=social&label=Star&)](https://github.com/dianping/cat/stargazers)
 [![GitHub forks](https://img.shields.io/github/forks/dianping/cat.svg?style=social&label=Fork&)](https://github.com/dianping/cat/fork)
L
leon.li 已提交
5 6


W
wangyapu 已提交
7
### CAT 简介 
Y
yong.you 已提交
8

W
wangyapu 已提交
9 10 11
- CAT 是基于 Java 开发的实时应用监控平台,为美团点评提供了全面的实时监控告警服务。
- CAT 作为服务端项目基础组件,提供了Java, C/C++, Node.js, Python, Go等多语言客户端,已经在美团点评的基础架构中间件框架(MVC框架,RPC框架,数据库框架,缓存框架等,消息队列,配置系统等)深度集成,为美团点评各业务线提供系统丰富的性能指标、健康状况、实时告警等。
- CAT 很大的优势是它是一个实时系统,CAT大部分系统是分钟级统计,但是从数据生成到服务端处理结束是秒级别,秒级定义是48分钟40秒,基本上看到48分钟38秒数据,整体报表的统计粒度是分钟级;第二个优势,监控数据是全量统计,客户端预计算;链路数据是采样计算。
L
leon.li 已提交
12

W
wangyapu 已提交
13
### Cat 产品价值
L
leon.li 已提交
14

W
wangyapu 已提交
15 16 17
- 减少故障发现时间
- 降低故障定位成本
- 辅助应用程序优化
L
leon.li 已提交
18

W
wangyapu 已提交
19
### Cat 优势
L
leon.li 已提交
20

W
wangyapu 已提交
21 22 23 24 25 26
- 实时处理:信息的价值会随时间锐减,尤其是事故处理过程中
- 全量数据:全量采集指标数据,便于深度分析故障案例
- 高可用:故障的还原与问题定位,需要高可用监控来支撑
- 故障容忍:故障不影响业务正常运转、对业务透明
- 高吞吐:海量监控数据的收集,需要高吞吐能力做保证
- 可扩展:支持分布式、跨 IDC 部署,横向扩展的监控系统
L
leon.li 已提交
27

W
wangyapu 已提交
28
### CAT 支持的监控消息类型:
L
leon.li 已提交
29

Y
yong.you 已提交
30 31
+  **Transaction**	  适合记录跨越系统边界的程序访问行为,比如远程调用,数据库调用,也适合执行时间较长的业务逻辑监控,Transaction用来记录一段代码的执行时间和次数。
+  **Event**	   用来记录一件事发生的次数,比如记录系统异常,它和transaction相比缺少了时间的统计,开销比transaction要小。
L
Li Donghua 已提交
32
+  **Heartbeat**	表示程序内定期产生的统计信息, 如CPU%, MEM%, 连接池状态, 系统负载等。
Y
yong.you 已提交
33 34
+  **Metric**	  用于记录业务指标、指标可能包含对一个指标记录次数、记录平均值、记录总和,业务指标最低统计粒度为1分钟。

L
leon.li 已提交
35

W
wangyapu 已提交
36
#### 消息树
L
leon.li 已提交
37 38

CAT监控系统将每次URL、Service的请求内部执行情况都封装为一个完整的消息树、消息树可能包括Transaction、Event、Heartbeat、Metric等信息。
Y
yong.you 已提交
39

W
wangyapu 已提交
40
- 完整的消息树
Y
yong.you 已提交
41 42

![Alt text](https://raw.github.com/dianping/cat/master/cat-home/src/main/webapp/images/logviewAll01.png)
W
wangyapu 已提交
43 44

- 可视化消息树
Y
yong.you 已提交
45 46 47

![Alt text](https://raw.github.com/dianping/cat/master/cat-home/src/main/webapp/images/logviewAll02.png)

W
wangyapu 已提交
48
- 分布式消息树【一台机器调用另外一台机器】
Y
yong.you 已提交
49 50 51

![Alt text](https://raw.github.com/dianping/cat/master/cat-home/src/main/webapp/images/logviewAll03.png)

W
wangyapu 已提交
52 53 54 55 56 57 58 59 60 61
### 模块简介

#### 功能模块

- cat-client: 客户端,上报监控数据
    >  根目录下 cat-client 模块以后不再维护,目前仅做服务端的依赖模块。下个大版本更新计划移除。新版Java客户端参考:lib/java    
- cat-consumer: 服务端,收集监控数据进行统计分析,构建丰富的统计报表
- cat-alarm: 实时告警,提供报表指标的监控告警
- cat-hadoop: 数据存储,logview 存储 Hdfs
- cat-home: 管理端,报表展示、配置管理等
A
ainilife 已提交
62

W
wangyapu 已提交
63
`说明:管理端、服务端、告警服务均使用 cat-home 模块部署即可`
L
leon.li 已提交
64

W
wangyapu 已提交
65
#### 其他模块
L
leon.li 已提交
66

W
wangyapu 已提交
67 68 69 70
- cat-doc:服务端报表使用文档
- integration:cat和一些第三方工具集成的内容(此部分一部分是由社区贡献,一部分官方贡献)
- lib:CAT 的客户端,包括Java、C/C++、Python、Node.js、Go
- script:CAT 数据库脚本
L
leon.li 已提交
71

W
wangyapu 已提交
72 73 74
### Quick Start

#### Cat客户端集成
L
leon.li 已提交
75

W
wangyapu 已提交
76 77 78 79 80 81 82 83
Cat目前支持::Java、C、Python、node、Go等语言的接入。详情请参考:[传送门](https://github.com/dianping/cat/tree/master/lib)

* [**Java**](https://github.com/dianping/cat/blob/master/lib/java)
* [**C**](https://github.com/dianping/cat/blob/master/lib/c)
* [**C++**](https://github.com/dianping/cat/blob/master/lib/cpp)
* [**Python**](https://github.com/dianping/cat/blob/master/lib/python)
* [**Go**](https://github.com/dianping/cat/blob/master/lib/go)
* [**Node.js**](https://github.com/dianping/cat/blob/master/lib/node.js)
L
leon.li 已提交
84

W
wangyapu 已提交
85
#### CAT 服务端
L
leon.li 已提交
86

W
wangyapu 已提交
87 88 89 90
- [依赖环境安装](https://github.com/dianping/cat-docs)
- [服务端集群部署](https://github.com/dianping/cat/blob/master/cat-doc/posts/ch4-server/README.md)
- [服务端报表介绍](https://github.com/dianping/cat/blob/master/cat-doc/posts/ch1-report/README.md)
- [服务端配置手册](https://github.com/dianping/cat/blob/master/cat-doc/posts/ch2-config/README.md)
L
leon.li 已提交
91

W
wangyapu 已提交
92
### 更新日志
L
leon.li 已提交
93

W
wangyapu 已提交
94 95
- [**最新版本特性一览**](https://github.com/dianping/cat/blob/master/cat-doc/posts/ch0-release/new.md)
- [**ChangeLog**](https://github.com/dianping/cat/blob/master/cat-doc/posts/ch0-release/changelog.md)
L
leon.li 已提交
96

W
wangyapu 已提交
97
### 项目设计
L
leon.li 已提交
98

W
wangyapu 已提交
99 100 101
- [项目架构](https://github.com/dianping/cat/blob/master/cat-doc/posts/ch5-design/overall.md)
- [客户端设计](https://github.com/dianping/cat/blob/master/cat-doc/posts/ch5-design/client.md)
- [服务端设计](https://github.com/dianping/cat/blob/master/cat-doc/posts/ch5-design/server.md)
L
leon.li 已提交
102

W
wangyapu 已提交
103 104 105
### Copyright and License

[Apache 2.0 License.](/LICENSE)
W
wangyapu 已提交
106 107

### CAT 接入公司
L
leon.li 已提交
108

W
wangyapu 已提交
109
![Alt text](https://raw.github.com/dianping/cat/master/cat-home/src/main/webapp/images/logo/companys.png)
Y
yong.you 已提交
110

L
leon.li 已提交
111

Y
youyong205 已提交
112
更多接入公司,欢迎在<https://github.com/dianping/cat/issues/753>登记
W
wangyapu 已提交
113

W
wangyapu 已提交
114 115
### 联系我们

W
wangyapu 已提交
116 117 118 119
我们需要知道你对Cat的一些看法以及建议:

- Mail: cat@dianping.com,
- [**Github Issues**](https://github.com/dianping/cat/issues)