设为首页 收藏本站
查看: 4731|回复: 1

[经验分享] 小米监控系统open-falcon安装

  [复制链接]
累计签到:1 天
连续签到:1 天
发表于 2016-8-4 09:27:24 | 显示全部楼层 |阅读模式
一、介绍
Open-Falcon 是小米的一款开源的互联网企业级监控系统解决方案。
a.特点
①数据采集免配置:agent自发现、支持Plugin、主动推送模式
②容量水平扩展:生产环境每秒50万次数据收集、告警、存储、绘图,可持续水平扩展。
③告警策略自发现:Web界面、支持策略模板、模板继承和覆盖、多种告警方式、支持回调动作。
④告警设置人性化:支持最大告警次数、告警级别设置、告警恢复通知、告警暂停、不同时段不同阈
值、支持维护周期,支持告警合并。
⑤历史数据高效查询:秒级返回上百个指标一年的历史数据。
⑥Dashboard人性化:多维度的数据展示,用户自定义Dashboard等功能。
⑦架构设计高可用:整个系统无核心单点,易运维,易部署。

b.安装

Open-Falcon,整体可以分为两部分,即绘图组件、告警组件。其中:
①安装绘图组件:负责数据的采集、收集、存储、归档、采样、查询、展示(Dashboard/Screen)等功能,可以单独工作,作为time-series data的一种存储展示方案。
②安装告警组件:负责告警策略配置(portal)、告警判定(judge)、告警处理(alarm/sender)、用户组管理(uic)等,可以单独工作。

注:以下安装操作皆来自于open-falcon book:http://book.open-falcon.org/zh/intro/index.html,可直接前往查看(环境所限并未演示告警部分)。

二、安装(二进制快速安装)
a.环境准备


①安装redis
1
# yum install -y redis




②安装MariaDB
1
# yum install -y mariadb*




③创建并进入工作目录
1
2
# mkdir open-falcon
# cd open-falcon




④初始化MariaDB表结构
1
2
3
4
5
6
7
8
# yum install -y git
# git clone https://github.com/open-falcon/scripts.git
# cd scripts/
# mysql -h localhost -u root --password="" < db_schema/graph-db-schema.sql
# mysql -h localhost -u root --password="" < db_schema/dashboard-db-schema.sql
# mysql -h localhost -u root --password="" < db_schema/portal-db-schema.sql
# mysql -h localhost -u root --password="" < db_schema/links-db-schema.sql
# mysql -h localhost -u root --password="" < db_schema/uic-db-schema.sql




⑤下载并解压编译好的二进制组件(只能跑64位Linux)
1
2
3
4
5
6
7
8
9
10
# DOWNLOAD="https://github.com/open-falcon/of-release/releases/download/v0.1.0/open-falcon-v0.1.0.tar.gz"
# cd open-falcon
# mkdir tmp
# wget $DOWNLOAD -O open-falcon-latest.tar.gz
# tar -zxf open-falcon-latest.tar.gz -C tmp/
# for x in `find ./tmp/ -name "*.tar.gz"`;do \   
      app=`echo $x|cut -d '-' -f2`; \   
      mkdir -p $app; \   
      tar -zxf $x -C $app; \
done




b.安装绘图组件

①安装Transfer
transfer默认监听在:8433端口上,agent会通过jsonrpc的方式来push数据上来。
1
2
3
4
5
6
7
8
9
# cd open-falcon
# cd transfer/
# mv cfg.example.json cfg.json  ##默认下(所有组件都在同一台服务器上),保持cfg.json不变即可
# ./control start                  ##启动transfer
falcon-transfer started..., pid=7447
# curl -s "http://127.0.0.1:7447/health"        ##检验服务
# ./control tail                   ##查看日志
# ./control stop                   ##停止transfer
falcon-transfer stoped...




②安装Agent
每台机器上,都需要部署agent,agent会自动采集预先定义的各种采集项,每隔60秒,push到transfer。
1
2
3
4
5
6
7
8
9
10
11
12
# cd open-falcon/agent/
# mv cfg.example.json cfg.json
# cat cfg.json | sed -n 17,22p
    "transfer": {
        "enabled": true,         ##true,表示开启向transfer发送数据的功能,默认开启
        "addrs": [                 ##改地址为transfer组件的监听地址, 为列表形式
            "127.0.0.1:8433",
            "127.0.0.1:8433"
        ],         ### 默认情况下(所有组件都在同一台服务器上),保持cfg.json不变即可
# ./control start             ##启动agent
falcon-agent started..., pid=9067
# ./control tail               ##查看日志




③安装Graph
graph组件是存储绘图数据、历史数据的组件。transfer会把接收到的数据,转发给graph。
1
2
3
4
5
6
# cd open-falcon/graph/
# mv cfg.example.json cfg.json  ##默认情况下(所有组件都在同一台服务器上),保持配置不变即可
# ./control start                ##启动graph
start ok, pid=9089
# ./control tail                ##查看日志
# curl -s "http://127.0.0.1:9089/health"      ##检验服务





④安装Query
query组件,绘图数据的查询接口,query组件收到用户的查询请求后,会从后端的多个graph,查询相应的数据,聚合后,再返回给用户。
1
2
3
4
5
# cd open-falcon/query/
# mv cfg.example.json cfg.json  ##默认情况下(所有组件都在同一台服务器上),保持配置不变即可
# ./control start                 ##启动query
start ok, pid=9146
# ./control tail                 ##查看日志






⑤安装Dashboard
dashboard是面向用户的查询界面,在这里,用户可以看到push到graph中的所有数据,并查看其趋势图。
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
# yum install -y python-virtualenv mariadb-devel gcc
# cd open-falcon/dashboard/
# virtualenv ./env
New python executable in ./env/bin/python
Installing Setuptools..............................................................................................................................................................................................................................done.
Installing Pip.....................................................................................................................................................................................................................................................................................................................................done.
# ./env/bin/pip install -r pip_requirements.txt
# cat rrd/config.py            ##默认情况下(所有组件都在同一台服务器上),保持默认配置即可
#-*-coding:utf8-*-
import os
#-- dashboard db config --               ### dashboard的数据库配置
DASHBOARD_DB_HOST = "127.0.0.1"
DASHBOARD_DB_PORT = 3306
DASHBOARD_DB_USER = "root"
DASHBOARD_DB_PASSWD = ""
DASHBOARD_DB_NAME = "dashboard"
#-- graph db config --                  ### graph的数据库配置
GRAPH_DB_HOST = "127.0.0.1"
GRAPH_DB_PORT = 3306
GRAPH_DB_USER = "root"
GRAPH_DB_PASSWD = ""
GRAPH_DB_NAME = "graph"
#-- app config --                    ## dashboard的配置
DEBUG = True
SECRET_KEY = "secret-key"
SESSION_COOKIE_NAME = "open-falcon"
PERMANENT_SESSION_LIFETIME = 3600 * 24 * 30
SITE_COOKIE = "open-falcon-ck"
#-- query config --                   ### query服务的地址
QUERY_ADDR = "http://127.0.0.1:9966"
BASE_DIR = "/home/work/open-falcon/dashboard/"
LOG_PATH = os.path.join(BASE_DIR,"log/")
try:
    from rrd.local_config import *
except:
    pass
# ./control start            ##启动dashboard
falcon-dashboard started..., pid=11835
# ./control tail             ##查看日志
# ./control stop             ##停止dashboard




这时候就可以通过http://localhost:8081访问dashboard主页了;
在dashboard首页的endpoint字段中,搜索机器名并点击“刷新counter列表”就可以看到数据了。
wKiom1eQc6nx1fGaAADYDB9JF6U803.jpg



运维网声明 1、欢迎大家加入本站运维交流群:群②:261659950 群⑤:202807635 群⑦870801961 群⑧679858003
2、本站所有主题由该帖子作者发表,该帖子作者与运维网享有帖子相关版权
3、所有作品的著作权均归原作者享有,请您和我们一样尊重他人的著作权等合法权益。如果您对作品感到满意,请购买正版
4、禁止制作、复制、发布和传播具有反动、淫秽、色情、暴力、凶杀等内容的信息,一经发现立即删除。若您因此触犯法律,一切后果自负,我们对此不承担任何责任
5、所有资源均系网友上传或者通过网络收集,我们仅提供一个展示、介绍、观摩学习的平台,我们不对其内容的准确性、可靠性、正当性、安全性、合法性等负责,亦不承担任何法律责任
6、所有作品仅供您个人学习、研究或欣赏,不得用于商业或者其他用途,否则,一切后果均由您自己承担,我们对此不承担任何法律责任
7、如涉及侵犯版权等问题,请您及时通知我们,我们将立即采取措施予以解决
8、联系人Email:admin@iyunv.com 网址:www.yunweiku.com

所有资源均系网友上传或者通过网络收集,我们仅提供一个展示、介绍、观摩学习的平台,我们不对其承担任何法律责任,如涉及侵犯版权等问题,请您及时通知我们,我们将立即处理,联系人Email:kefu@iyunv.com,QQ:1061981298 本贴地址:https://www.yunweiku.com/thread-252556-1-1.html 上篇帖子: Open-falcon部署文档(绘图及报警) 下篇帖子: open-falcon "Dashboard" 报SSL错 监控系统
您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

扫码加入运维网微信交流群X

扫码加入运维网微信交流群

扫描二维码加入运维网微信交流群,最新一手资源尽在官方微信交流群!快快加入我们吧...

扫描微信二维码查看详情

客服E-mail:kefu@iyunv.com 客服QQ:1061981298


QQ群⑦:运维网交流群⑦ QQ群⑧:运维网交流群⑧ k8s群:运维网kubernetes交流群


提醒:禁止发布任何违反国家法律、法规的言论与图片等内容;本站内容均来自个人观点与网络等信息,非本站认同之观点.


本站大部分资源是网友从网上搜集分享而来,其版权均归原作者及其网站所有,我们尊重他人的合法权益,如有内容侵犯您的合法权益,请及时与我们联系进行核实删除!



合作伙伴: 青云cloud

快速回复 返回顶部 返回列表