Riemann monitors distributed systems.

具体介绍就不多说了,一个分布式的监控系统。可以接收各种event上报,然后通过强大的脚本和插件,展示曲线,柱状,饼图等来对系统进行监控。

一、riemann安装

这里主要说ubuntu的安装:

首先,需要java、ruby环境:
sudo apt-get -y install default-jre ruby-dev build-essential

然后下载riemann的包:

wget https://aphyr.com/riemann/riemann_0.2.8_all.deb
然后直接安装就OK了:
sudo dpkg -i riemann_0.2.8_all.deb 采用命令就可以启动服务了:
 sudo service riemann start
 

二、riemann配置

配置文件在

/etc/riemann/riemann.config

默认配置如下

; -*- mode: clojure; -*-
; vim: filetype=clojure (logging/init {:file "/var/log/riemann/riemann.log"}) ; Listen on the local interface over TCP (), UDP (), and websockets
; ()
(let [host "127.0.0.1"]
(tcp-server {:host host})
(udp-server {:host host})
(ws-server {:host host})) ; Expire old events from the index every seconds.
(periodically-expire ) (let [index (index)]
; Inbound events will be passed to these streams:
(streams
(default :ttl
; Index all events immediately.
index ; Log expired events.
(expired
(fn [event] (info "expired" event))))))

可以使用go的client进行event的发送:

package main

import (
"github.com/bigdatadev/goryman"
//"fmt"
"time"
"math/rand"
) func main(){
c := goryman.NewGorymanClient("localhost:5555")
err := c.Connect()
if err != nil {
panic(err)
} defer c.Close() for {
rd := rand.New(rand.NewSource(time.Now().UnixNano())) err = c.SendEvent(&goryman.Event{
Host : "box1",
Service: "foo",
Metric: rd.Intn(),
Tags: []string{"meter","dev"},
})
if err != nil {
panic(err)
} rd = rand.New(rand.NewSource(time.Now().UnixNano())) err = c.SendEvent(&goryman.Event{
Host : "box2",
Service: "bar",
Metric: rd.Intn(),
Tags: []string{"meter","dev"},
})
if err != nil {
panic(err)
}
}
}

三、把riemann数据使用graphite来进行画图

由于riemann本身提供的数据图形化比较难弄,但是它可以方便的只想graphite进行处理。

所以,我们装一下graphite。

#安装启动graphite
pip install carbonpip install whisperpip install graphite-web
pip install Django
pip install django-tagging

#默认安装路径在 /opt/graphite/目录下 #初始化配置
PYTHONPATH=`pwd`/webapp:`pwd`/whisper python ./webapp/graphite/manage.py syncdbecho DEBUG = True > webapp/graphite/local_settings.py #启动web服务,web访问界面
PYTHONPATH=`pwd`/whisper ./bin/run-graphite-devel-server.py --libs=`pwd`/webapp/ /opt/graphite/ #启动接收数据的后台进程
puchd config cp carbon/conf/carbon.conf.example carbon/conf/carbon.confPYTHONPATH=`pwd`/whisper ./carbon/bin/carbon-cache.py --debug start

在riemann的配置中增加一行:

; -*- mode: clojure; -*-
; vim: filetype=clojure (logging/init {:file "/var/log/riemann/riemann.log"}) ; Listen on the local interface over TCP (), UDP (), and websockets
; ()
(let [host "127.0.0.1"]
(tcp-server {:host host})
(udp-server {:host host})
(ws-server {:host host})) ; Expire old events from the index every seconds.
(periodically-expire ) (let [index (index)]
; Inbound events will be passed to these streams:
(streams
(default :ttl
; Index all events immediately.
index ; Log expired events.
(expired
(fn [event] (info "expired" event)))))) #定义graph绘图的host,这里是部署在一台机器上面的
(def graph (graphite {:host "localhost"})) ;所有的event数据都发给graph进行绘图 (streams graph)

然后启动go的test程序进行发送数据,就能在graphite上面看到数据了:

总结:

riemann非常灵活,但灵活的同时是学习成本的增加。你必须要学会他的配置,而且要熟悉对应的配置语言的语法和函数(当然学会之后,就非常流弊了)。

具体可以参考它官网的howto介绍。 这里就浅尝辄止了,后面项目有需要再好好研究。

参考连接:

http://kartar.net/2014/12/an-introduction-to-riemann/

#如何配置
http://labs.amara.org/2012-07-16-metrics.html#riemann
#streams配置最重要
http://riemann.io/howto.html#running-riemann

riemann的安装和使用的更多相关文章

  1. docker——容器安装tomcat

    写在前面: 继续docker的学习,学习了docker的基本常用命令之后,我在docker上安装jdk,tomcat两个基本的java web工具,这里对操作流程记录一下. 软件准备: 1.jdk-7 ...

  2. 网络原因导致 npm 软件包 node-sass / gulp-sass 安装失败的处理办法

    如果你正在构建一个基于 gulp 的前端自动化开发环境,那么极有可能会用到 gulp-sass ,由于网络原因你可能会安装失败,因为安装过程中部分细节会到亚马逊云服务器上获取文件.本文主要讨论在不变更 ...

  3. Sublime Text3安装JsHint

    介绍 Sublime Text3使用jshint依赖Nodejs,SublimeLinter和Sublimelinter-jshint. NodeJs的安装省略. 安装SublimeLinter Su ...

  4. Fabio 安装和简单使用

    Fabio(Go 语言):https://github.com/eBay/fabio Fabio 是一个快速.现代.zero-conf 负载均衡 HTTP(S) 路由器,用于部署 Consul 管理的 ...

  5. gentoo 安装

    加载完光驱后 1进行ping命令查看网络是否通畅 2设置硬盘的标识为GPT(主要用于64位且启动模式为UEFI,还有一个是MBR,主要用于32位且启动模式为bois) parted -a optima ...

  6. Linux平台 Oracle 10gR2(10.2.0.5)RAC安装 Part3:db安装和升级

    Linux平台 Oracle 10gR2(10.2.0.5)RAC安装 Part3:db安装和升级 环境:OEL 5.7 + Oracle 10.2.0.5 RAC 5.安装Database软件 5. ...

  7. Linux平台 Oracle 10gR2(10.2.0.5)RAC安装 Part1:准备工作

    Linux平台 Oracle 10gR2(10.2.0.5)RAC安装 Part1:准备工作 环境:OEL 5.7 + Oracle 10.2.0.5 RAC 1.实施前准备工作 1.1 服务器安装操 ...

  8. 【原】nodejs全局安装和本地安装的区别

    来微信支付有2年多了,从2年前的互联网模式转变为O2O模式,主要的场景是跟线下的商户去打交道,不像以往的互联网模式,有产品经理提需求,我们帮忙去解决问题. 转型后是这样的,团队成员更多需要去寻找业务的 ...

  9. tLinux 2.2下安装Mono 4.8

    Tlinux2.2发行版基于CentOS 7.2.1511研发而成,内核版本与Tlinux2.0发行版保持完全一致,更加稳定,并保持对Tlinux2.0的完全兼容.Mono 4版本要求CentOS 7 ...

随机推荐

  1. NFC读卡APP

    # 设计文档 ### 简介----------------------------- 这个APP的功能是使用手机的NFC读卡器功能,做到读取卡片支持M1卡和CPU卡. ### 功能列表-------- ...

  2. 一款基于HTML5 Canvas的画板涂鸦动画

    今天给各网友分享一款基于HTML5 Canvas的画板涂鸦动画.记得之前我们分享过一款HTML5 Canvas画板工具,可以切换不同的笔刷,功能十分强大.本文今天要再来分享一款基于HTML5 Canv ...

  3. PHP——数组中的each(),list()和while循环遍历数组

    .while遍历 在while()语句每次循环中,each()语句将当前数组元素的键,赋给list()函数的第一个参数变量$key.并将当前数组元素中的值,赋给list()函数中的第二个参数变量$va ...

  4. PHP——投票

    要求: 选择第一个页面的复选框值,点击提交则提交数据,点击查看结果在同一页面覆盖显示结果的投票人数,百分比和进度条,点击返回,返回第一页面 数据库为 投票 表格为diaoyanxx 表格内容为: zh ...

  5. 亿级日PV的魅族云同步的核心协议与架构实践(转)

    云同步的业务场景 这是魅族云同步的演进,第一张是M8.M9,然后到后面的是MX系统,M9再往后发展,我们的界面可以看到基本上是没有什么变化的,但本质发生了很大的变化,我们经过了一些协议优化,发展到今天 ...

  6. JavaScript中的闭包详解

    闭包是JavaScript的重要特性,非常强大,可用于执行复杂的计算,可并不容易理解,尤其是对之前从事面向对象编程的人来说,对 JavaScript 认识和编程显得更难.特别是在看一些开源的JavaS ...

  7. Java的多线程 简单入门

    Java的多线程 简单入门 首先能够先搞清楚什么是程序.进程.线程,以及它们之间的关系: 定义: 一 程序仅仅是一组指令的有序集合.它是静态的 二 进程是具有一定独立功能的程序关于某个数据集合上的一次 ...

  8. 在linux 列出 超级用户 普通用户和 系统用户

    #!/bin/bash echo Please select which list you want to print echo "1. admin (enter 1)" echo ...

  9. 关于Unity的组件和作用

    一.Transform组件 整个场景由节点树组成. 节点+Transform组件,每个Transform有自己的孩子Transform,由Transform组成Transform树,而每个Transf ...

  10. 构造方法也可以实现overloading

    构造方法也可以实现overloading.例: public void teach(){}; public void teach(int a){}; public void teach(String ...