RRDTool 詳解

大綱html

1、MRTG的不足和RRDTool對比前端

2、RRDTool概述node

3、安裝RRDToolmysql

4、RRDTool繪圖步驟linux

5、rrdtool命令詳解sql

6、RRDTool繪圖案例shell

注,實驗環境 CentOS 6.4 x86_64,軟件版本 rrdtool-1.3.8(最新版的是1.4.8)。(說明:本博文的一些圖片和內容自於開源社區與官方網站並非全部內容全是原創)數據庫


1、MRTG的不足和RRDTool對比express

1.MRTG軟件的不足vim

MRTG監測網絡流量很方便,可是若是須要監測其餘的系統性能,好比CPU負載、系統負載、網絡鏈接數等,就不是那麼簡單了。即便實現了這些功能,但管理 起來很是麻煩。好比公司有一兩千個被監測點,分佈在不一樣的機房,爲了管理方便須要將這些服務器和網絡設備分類,這樣的話就須要將這些被監測點放在不一樣的 MRTG配置文件中,運行多個crontab,甚至還要本身寫HTML頁面對其進行管理。


MRTG畢竟是一套很老的軟件,並且存在許多不足的地方,其做者Tobias Oetiker在1999年就已經開始開發另外一套開源軟件RRDTool來代替MRTG。如今RRDTool已經發展得很成熟,在功能MRTG難以與其相提並論。


2.RRDTool與MRTG對比

與MRTG同樣,RRDTool也是由Tobias Oetiker撰寫的開源軟件,但RRDTool並不是MRTG的升級版本,二者有很是大的區別,也能夠說RRDTool是將用來取代MRTG的產品。下面是兩個軟件的一些優缺點的對比。


(1).MRTG

優勢

  • 簡單、易上手,基本安裝完了以後只要修改一下配置文件便可使用。

缺點

  • 使用文本式的數據庫,數據不能重複使用。

  • 只能按日、周、月、年來查看數據。

  • 因爲MRTG原本只是用來監測網絡的流量,因此只能存儲兩個DS(Data Source),即存儲流量的輸入和輸出。

  • 每取一次數據即須要繪圖一次,浪費系統資源。

  • 圖像比較模糊。

  • 無用戶、圖像管理功能。

  • 沒有詳細日誌系統。

  • 沒法詳細瞭解各流量的構成。

  • 只能用於TCP/IP網絡,對於SAN網絡流量無能爲力。

  • 不能在命令行下工做。


(2).RRDTool

優勢:

  • 使用RRD(Round Robin Database)存儲格式,數據等於放在數據庫中,能夠方便地調用。好比,將一個RRD文件中的數據與另外一個RRD文件中的數據相加。

  • 能夠定義任意時間段畫圖,能夠用半年數據畫一張圖,也能夠用半小時內的數據畫一張圖。

  • 能畫任意個DS,多種圖形顯示方式。

  • 數據存儲與繪圖分開,減輕系統負載。

  • 能任意處理RRD文件中的數據,好比,在瀏覽監測中咱們須要將數據由Bytes轉化爲bits,能夠將原始數據乘8。

缺點:

  • RRDTool的做用只是存儲數據和畫圖,它沒有MRTG中集成的數據採集功能。

  • 在命令行下的使用很是複雜,參數極多。

  • 無用戶、圖像管理功能。

RRDTool官方網站:

http://oss.oetiker.ch/rrdtool/


2、RRDTool概述

1.概述

RRDtool 表明 「Round Robin Database tool」 ,做者同時也是 MRTG 軟件的發明人。官方站點位於http://oss.oetiker.ch/rrdtool/所 謂的「Round Robin」 實際上是一種存儲數據的方式,使用固定大小的空間來存儲數據,並有一個指針指向最新的數據的位置。咱們能夠把用於存儲數據的數據庫的空間當作一個圓,上面有 不少刻度。這些刻度所在的位置就表明用於存儲數據的地方。所謂指針,能夠認爲是從圓心指向這些刻度的一條直線。指針會隨着數據的讀寫自動移動。要注意的 是,這個圓沒有起點和終點,因此指針能夠一直移動,而不用擔憂到達終點後就沒法前進的問題。在一段時間後,當全部的空間都存滿了數據,就又從頭開始存放。 這樣整個存儲空間的大小就是一個固定的數值。因此RRDtool 就是使用相似的方式來存放數據的工具, RRDtool 所使用的數據庫文件的後綴名是'.rrd。以下圖,

s13

2.特色

  • 首先 RRDtool 存儲數據,扮演了一個後臺工具的角色。但同時 RRDtool 又容許建立圖表,這使得RRDtool看起來又像是前端工具。其餘的數據庫只能存儲數據,不能建立圖表。

  • RRDtool 的每一個 rrd 文件的大小是固定的,而普通的數據庫文件的大小是隨着時間而增長的。

  • 其餘數據庫只是被動的接受數據, RRDtool 能夠對收到的數據進行計算,例如先後兩個數據的變化程度(rate of change),並存儲該結果。

  • RRDtool 要求定時獲取數據,其餘數據庫則沒有該要求。若是在一個時間間隔內(heartbeat)沒有收到值,則會用 UNKN (unknow)代替,其餘數據庫則不會這樣。


3、安裝RRDTool

1.安裝yum源

1
2
[root@node1 ~] # rpm -ivh http://download.fedoraproject.org/pub/epel/6/x86_64/epel-release-6-8.noarch.rpm
[root@node1 ~] # rpm -ivh http://pkgs.repoforge.org/rpmforge-release/rpmforge-release-0.5.3-1.el6.rf.x86_64.rpm

2.同步時間

1
[root@node1 ~] # ntpdate 202.120.2.101

3.下載rrdtool的RPM包

1
[root@node1 ~] # wget ftp://195.220.108.108/linux/centos/6.4/os/x86_64/Packages/rrdtool-1.3.8-6.el6.x86_64.rpm

4.yum安裝rrdtool

1
[root@node1 ~] # yum -y localinstall --nogpgcheck rrdtool-1.3.8-6.el6.x86_64.rpm

5.查看一下安裝文件

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
[root@node1 ~] # rpm -qa | grep rrdtool
rrdtool-1.3.8-6.el6.x86_64
[root@node1 ~] # rpm -ql rrdtool
/usr/bin/rrdcgi
/usr/bin/rrdtool #命令行工具
/usr/bin/rrdupdate
/usr/lib64/librrd .so.4 #下面是庫文件
/usr/lib64/librrd .so.4.0.7
/usr/lib64/librrd_th .so.4
/usr/lib64/librrd_th .so.4.0.7
/usr/share/man/man1/bin_dec_hex .1.gz #下面是幫助文檔
/usr/share/man/man1/cdeftutorial .1.gz
/usr/share/man/man1/rpntutorial .1.gz
/usr/share/man/man1/rrd-beginners .1.gz
/usr/share/man/man1/rrdbuild .1.gz
/usr/share/man/man1/rrdcgi .1.gz
/usr/share/man/man1/rrdcreate .1.gz
/usr/share/man/man1/rrddump .1.gz
/usr/share/man/man1/rrdfetch .1.gz
/usr/share/man/man1/rrdfirst .1.gz
/usr/share/man/man1/rrdgraph .1.gz
/usr/share/man/man1/rrdgraph_data .1.gz
/usr/share/man/man1/rrdgraph_examples .1.gz
/usr/share/man/man1/rrdgraph_graph .1.gz
/usr/share/man/man1/rrdgraph_rpn .1.gz
/usr/share/man/man1/rrdinfo .1.gz
/usr/share/man/man1/rrdlast .1.gz
/usr/share/man/man1/rrdlastupdate .1.gz
/usr/share/man/man1/rrdresize .1.gz
/usr/share/man/man1/rrdrestore .1.gz
/usr/share/man/man1/rrdthreads .1.gz
/usr/share/man/man1/rrdtool .1.gz
/usr/share/man/man1/rrdtune .1.gz
/usr/share/man/man1/rrdtutorial .1.gz
/usr/share/man/man1/rrdupdate .1.gz
/usr/share/man/man1/rrdxport .1.gz
/usr/share/rrdtool

6.查看一下命令行工具

1
2
3
4
5
6
7
8
9
10
[root@node1 ~] # rrdtool -h
RRDtool 1.3.8 Copyright 1997-2009 by Tobias Oetiker <tobi@oetiker.ch>
         Compiled Aug 21 2010 10:57:18
Usage: rrdtool [options] command command_options
Valid commands: create, update, updatev, graph, graphv, dump, restore,
     last, lastupdate, first, info, fetch, tune,
     resize, xport
RRDtool is distributed under the Terms of the GNU General
Public License Version 2. (www.gnu.org /copyleft/gpl .html)
For more information read the RRD manpages

注,使用 man rrdtool 能夠查看詳細的使用方法。好了,到這裏咱們就安裝完成了,下面咱們來講一下RRDTool的繪圖步驟。


4、RRDTool繪圖步驟

s10

步驟一︰創建RRD文件,這個文件說來就是RRDtool的專屬數據庫。RRDtool以自有的格式存放數據。下面會講解!

步 驟二︰抓取數據我的以爲是整個RRDtool最困難的一部分,由於RRDtool的數據是要靠本身在建立RRD數據庫時定義出來,不像MRTG內建抓數據 功能,可是卻由於如此,能夠給RRDtool畫圖的數據彈性也比較大,例如︰snmp查詢結果、系統狀態、網頁中特定數據統計等等。

步驟三︰將抓下來的數據就用rrdtool update的指令進行更新到的RRD數據庫中,讓圖表能畫出最新的流量。

步驟四︰這就是重點啦!經過rrdtool graph的指令來依據RRD數據庫的數據進行繪圖,這也是使用者惟一看的到的東西,若規劃的很差會影響使用者閱讀上的困難!

循環︰因爲要完成動態繪圖的圖表,第二步驟到第四步驟必須不斷的重複執行以維持資料的更新,目前知道要達成循環的方法有兩種︰

  • 在Script中使用循環

  • 使用crontab任務計劃


5、rrdtool命令詳解

1.建立RRD數據庫

create 語法

1
2
3
4
5
rrdtool create filename
[--start|-b start time ]
[--step|-s step]
DS:ds-name:DST:dst arguments #最後獲取的數據是PDP,更新數據時要考濾DS順序(*把全部要更新的數據,按照DS定義的順序用冒號格開*)
RRA:CF:cf arguments #最後獲取的數據是CDP,繪圖時使用的是這些數據

參數詳解:

  • DS:DS 用於定義 Data Soure 。也就是用於存放結果的變量名。DS是用來申明數據源的,也能夠理解爲申明數據變量,也就是你要檢測的端口對應的變量名,這個參數在畫圖的時候還要使用的。

  • DST:DST 就是DS的類型。有 COUNTER、GUAGE、DERIVE、ABSOLUTE、COMPUTE 5種。因爲網卡流量屬於計數器型,因此這裏應該爲 COUNTER 。

  • RRA:RRA 用於指定數據如何存放。咱們能夠把一個RRA 當作一個表,各保存不一樣 interval 的統計結果。RRA的做用就是定義更新的數據是如何記錄的。好比咱們每5分鐘產生一條刷新的數據,那麼一個小時就是12條。天天就是288條。這麼龐大的 數據量,必定不可能都存下來。確定有一個合併(consolidate)數據的方式,那麼這個就是RRA的做用了。

  • PDP:Primary Data Point 。正常狀況下每一個 interval RRDtool 都會收到一個值;RRDtool 在收到腳本給來的值後會計算出另一個值(例如平均值),這個 值就是 PDP ;這個值表明的通常是「xxx/秒」的含義。注意,該值不必定等於RRDtool 收到的那個值。除非是GAUGE ,能夠看下面的例子就知道了

  • CF:CF 就是 Consolidation Function 的縮寫。也就是合併(統計)功能。有 AVERAGE、MAX、MIN、LAST 四種分別表示對多個PDP 進行取平均、取最大值、取最小值、取當前值四種類型。具體做用等到 update 操做時再說。

  • CDP:Consolidation Data Point 。RRDtool 使用多個 PDP 合併爲(計算出)一個 CDP。也就是執行上面 的CF 操做後的結果。這個值就是存入 RRA的數據,繪圖時使用的也是這些數據

下面是RRA與PDP、CDP之間的關係圖,

164103483.png

(0).filename

默認是以 .rrd 結尾,但也以隨你設定。


(1).--start|-b start time

設 定RRD數據庫加入的第一個數據值的時間,從1970-01-01 00:00:00 UTC時間以來的時間(秒)。RRDtool不會接受早於或在指定時刻上的任何數值。默認值是now-10s;若是 update 操做中給出的時間在 –-start 以前,則 RRDtool拒絕接受。--satrt 選項也是可選的。 若是你想指定--start 爲1天前,能夠用CODE:--start $(date -d '1 days ago' +%s)。注意,--start 選項的值必是 timestamp 的格式。


(2).--step|-s step

指定數據將要被填入RRD數據庫的基本的時間間隔。默認值是300秒;


(3).DS:ds-name:DST:dst arguments DS(Data Source)

DS:DS 用於定義 Data Soure 。也就是用於存放結果的變量名。 DS是用來申明數據源的,也能夠理解爲申明數據變量,也就是你要檢測的端口對應的變量名,這個參數在畫圖的時候還要使用的。這裏開始定義RRD數據的基本 屬性;單個RRD數據庫能夠接受來自幾個數據源的輸入。在DS選項中要爲每一個須要在RRD中存儲的數據源指定一些基本的屬性;ds-name數據域命 名;DST定義數據源的類型,dst arguments參數依賴於數據源的類型。


案例:DS:mysql:COUNTER:600:0:100000000

DS(Data Source,數據源)表達式總共有六個欄位:

  • DS 表示這個爲DS表達式

  • ds-name 數據域命名

  • DST 定義數據源的類型

  • heartbeat 有效期(heartbeat),案例裏的值爲'600',假設要取12:00的數據,而先後300秒裏的值(11:55-12:05)通過平均或是取最大或最小都算是12:00的有效值;

  • min 容許存放的最小值,此例容許最小爲0。

  • max 容許存放的最大值,最大爲100000000。

注,若是不想設限制能夠再第五個欄位和第六個欄位以 "U:U"表示(U即Unknown)。


DST 定義數據源的類型。數據源項的後續參數依賴於數據源的類型。對於GAUGE、COUNTER、DERIVE、以及ABSOLUTE,其數據源的格式爲: DS:ds-name:GAUGE | COUNTER | DERIVE | ABSOLUTE:heartbeat:min:max。DST 的選擇是十分重要的,若是選錯了 DST ,即便你的腳本取的數據是對的,放入 RRDtool 後也是錯誤的,更不用提畫出來的圖是否有意義了。

  • GAUGE :GAGUE 和上面三種不一樣,它沒有「平均」的概念,RRDtool 收到值以後字節存入 RRA 中。

  • COUNTER :必須是遞增的,除非是計數器溢出。在這種狀況下,RRDtool 會自動修改收到的值。例如網絡接口流量、收到的packets 數量都屬於這一類型。

  • DERIVE:和 COUNTER 相似。但能夠是遞增,也能夠遞減,或者一會增長一下子減小。

  • ABSOLUTE :ABSOLUTE 比較特殊,它每次都假定前一個interval的值是0,再計算平均值。

  • COMPUTE :COMPUTE 比較特殊,它並不接受輸入,它的定義是一個表達式,可以引用其餘DS並自動計算出某個值。例如 CODE:DS:eth0_bytes:COUNTER:600:0:U DS:eth0_bits:COMPUTE:eth0_bytes,8,* 則 eth0_bytes 每獲得一個值,eth0_bits 會自動計算出它的值:將 eth0_bytes 的值乘以 8 。不過 COMPUTE 型的 DS 有個限制,只能應用它所在的 RRD 的 DS ,不能引用其餘 RRD 的 DS。 COMPUTE 型 DS 是新版本的 RRDtool 纔有的,你也能夠用 CDEF 來實現該功能。如:CDEF:eth0_bits=eth0_bytes,8,*


DST 實例說明,

Values = 300, 600, 900, 1200

#假設 RRDtool 收到4個值,分別是300,600,900,1200。
Step = 300 seconds

#step 爲 300
COUNTER = 1,1,1,1

#(300-0)/300,(600-300)/300,(900-600)/300,(1200-900)/300 ,因此結果爲 1,1,1,1
DERIVE = 1,1,1,1 # 同上
ABSOLUTE = 1,2,3,4

#(300-0)/300,(600-0)/300,(900-0)/300,(1200-0)/300,因此結果爲 1,2,3,4
GAUGE = 300,600,900,1200 # 300 , 600 ,900 ,1200 不作運算,直接存入數據庫。因此第一行的 values 並非 PDP,後面4行纔是PDP。


下面咱們來創建一個RRD庫文件,

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
[root@node1 ~] # rrdtool create eth0.rrd \
> --step 300 \
> DS:eth0_in:COUNTER:600:0:12500000 \
  # 600 是 heartbeat;0 是最小值;12500000 表示最大值;
> DS:eth0_out:COUNER:600:0:12500000 \
# 若是沒有最小值/最大值,能夠用 U 代替,例如 U:U
> RRA:AVERAGE:0.5:1:600 \
# 1 表示對1個 PDP 取平均。實際上就等於 PDP 的值
> RRA:AVERAGE:0.5:4:600 \
# 4 表示每4個 PDP 合成爲一個 CDP,也就是20分鐘。方法是對4個PDP取平均,
> RRA:AVERAGE:0.5:24:600 \ # 同上,但改成24個,也就是24*5=120分鐘=2小時。
> RRA:AVERAGE:0.5:288:730
  # 同上,但改成288個,也就是 288*5=1440分鐘=1天
[root@node1 ~] # ll -h eth0.rrd
-rw-r--r--  1 root   root     41K 10月 11 10:16 eth0.rrd

有的人可能會問,上面有兩個 DS,那 RRA 中究竟存的是那個 DS 的數據呢?實際上,這些 RRA 是共用的,你只需創建一個 RRA,它就能夠用於所有的 DS 。因此在定義 RRA 時不須要指定是給那個 DS 用的。


(4).RRA:CF:cf arguments

RRA的做用就是定義更新的數據是如何記錄的。好比咱們每5分鐘產生一條刷新的數據,那麼一個小時就是12條。天天就是288條。這麼龐大的數據量,必定不可能都存下來。確定有一個合併(consolidate)數據的方式,那麼這個就是RRA的做用了。以下圖,

s11

RRD 的一個目的是在一個環型數據歸檔中存儲數據。一個歸檔有大量的數據值或者每一個已定義的數據源的統計,並且它是在一個RRA行中被定義的。當一個數據進入 RRD數據庫時,首先填入到用 -s 選項所定義的步長的時隙中的數據,就成爲一個pdp值,稱爲首要數據點(Primary Data Point)。該數據也會被用該歸檔的CF歸併函數進行處理。能夠把各個PDPs經過某個聚合函數進行歸併的歸併函數有這樣幾種:AVERAGE、 MIN、MAX、LAST等。這些歸併函數的RRA命令行格式爲:RRA:AVERAGE | MIN | MAX | LAST:xff:steps:rows。


什麼是 CF?

以上面的案例中第2個RRA 和 4,2,1,3 這4個 PDP 爲例

  • AVERAGE :則結果爲 (4+2+1+3)/4=2.5

  • MAX :結果爲4個數中的最大值 4

  • MIN :結果爲4個數中的最小值1

  • LAST :結果爲4個數中的最後一個 3

同理,第三個RRA和第4個RRA則是每24個 PDP、每288個 PDP 合成爲1個 CDP。


解釋度(Resolution)

這 裏要提到一個 Resolution 的概念,在官方文檔中多處提到 resolution 一詞。Resolution 到底是什麼?Resolutino 有什麼用?舉個例子,若是咱們要繪製1小時的數據,也就是60分鐘,那麼咱們能夠從第一個RRA 中取出12個 CDP 來繪圖;也能夠從第2個 RRA中取出3個 CDP 來繪圖。到底 RRDtool 會使用那個呢?讓咱們看一下 RRA 的定義 :RRA:AVERAGE:0.5:4:600 。

Resolution 就等於 4 * step = 4 * 300 = 1200 ,也就是說 ,resolution 是每一個CDP 所表明的時間範圍,或者說 RRA 中每一個 CDP(記錄)之間的時間間隔。因此第一個 RRA 的 resolution 是 1* step=300,第2是 1200,第三個是 24*300=7200,第4個 RRA 是 86400 。

默認狀況下,RRDtool 會自動挑選合適的 resolution 的那個 RRA 的數據來繪圖。咱們大可沒必要關心它。但若是本身想取特定 RRA 的數據,就須要用到它了。關於 Resolution 咱們還會在 fetch 和 graph 中提到它。


xff 字段

細心的朋友可能會發現,在 RRA 的定義中有一個數值,固定是 0.5 ,這個究竟是什麼東東呢?
這個稱爲 xff 字段,是 xfile factor 的縮寫。讓咱們來看它的定義 :

QUOTE:

The xfiles factor defines what part of a consolidation interval may be made up from *UNKNOWN* data while
the consolidated value is still regarded as known. It is given as the ratio of allowed *UNKNOWN* PDPs to
the number of PDPs in the interval. Thus, it ranges from 0 to 1 (exclusive)

這個看起來有點頭暈,咱們舉個簡單的例子 :例如

CODE:RRA:AVERAGE:0.5:24:600

這個 RRA 中,每24個 PDP (共兩小時)就合成爲一個 CDP,若是這 24 個 PDP 中有部分值是 UNKNOWN (緣由能夠不少),例如1個,那麼這個 CDP合成的結果是否就爲 UNKNOWN 呢?


不 是的,這要看 xff 字段而定。Xff 字段實際就是一個比例值。0.5 表示一個 CDP 中的全部 PDP 若是超過一半的值爲 UNKNOWN ,則該 CDP 的值就被標爲UNKNOWN。也就是說,若是24個 PDP中有12個或者超過12個 PDP 的值是 UNKNOWN ,則該 CPD 就沒法合成,或者合成的結果爲 UNKNOWN;若是是11個 PDP 的值爲 UNKNOWN ,則該 CDP 的值等於剩下 13 個 PDP 的平均值。


若是一個 CDP 是有2個 PDP 組成,xff 爲 0.5 ,那麼只要有一個 PDP 爲 UNKNOWN ,則該 PDP 所對應的 CDP 的值就是 UNKNOWN 了。


2.抓取數據

簡單說,就是用shell寫個腳本去不斷的收集數據。對於不懂shell編輯的博友能夠去網上找點資料學習一下,很簡單的。下面是利用snmp來獲取進入網卡的流量。

1
2
[root@node1 ~] # snmpget -v 2c -c public 192.168.18.201 ifInOctets.2
IF-MIB::ifInOctets.2 = Counter32: 57266195

上 面的例子是使用snmpget來抓取192.168.18.201的網卡輸入流量,-v 2c表示snmp版本號,-c public snmp共同體名稱,192.168.18.201是這臺主機的IP地址,ifInOctets.2是指eth0網卡的輸入流 量,ifInOctets.1是指lo0網卡的輸入流量。從上面咱們能夠看出,eth0輸入的流量爲57266195。下面咱們來截取一下輸入流量,

1
2
[root@node1 ~] # snmpget -v 2c -c public 192.168.18.201 ifInOctets.2 | sed -e 's/.*ter32: \(.*\)/\1/'
57463513

咱們獲得的值爲57463513,這就是咱們要的結果。咱們只要用shell腳本寫個循環就能夠收集網卡的輸入流量了,再用rrdtool update命令將收集到的數據更新到RRD數據庫中便可。

固然,您不必定要使用snmpget,也可使用snmpwalk、tcpdump等等抓取數據回來分析,說誇張點,凡有變化的數據均可以通過處理變成咱們要的資料,而後畫成圖表。


3.更新RRD數據庫數據

update 語法

1
2
3
4
rrdtool update filename [--template|-t ds-name[:dsname]...] N|timestamp:value[:value...]
filename RRD數據庫文件名稱
--template|-t ds-name[:ds-name] 要更新RRD數據庫中數據源的名稱,其中-t指定數據源的順序
N|timestamp:value[:value...] 時間:要更新的值

案例:

1
2
[root@node1 ~] #rrdtool update eth0.rrd 1381467942:60723022 或
[root@node1 ~] # rrdtool update eth0.rrd N:60723022

其中,1381467942是當前的時間戳,能夠用date +%s命令得到,或者直接用N代替。60723022是當前要更新的流量數據,能夠用shell腳本得到。下面咱們來查看一下,更新的數據。

1
[root@node1 ~] # rrdtool fetch eth0.rrd AVERAGE


4.繪製圖表

使用RRDtool 咱們最關心什麼?固然是把數據畫出來了。雖然前面談了不少,但這些都是基礎來的。掌握好了,可讓你在繪圖時更加駕輕就熟。

graph 語法

1
2
3
4
5
6
7
8
9
10
rrdtool graph filename [option ...]
[data definition ...]
[data calculation ...]
[variable definition ...]
[graph element ...]
[print element ...]
其中的 data definiton、variable definition 、data calculation、分別是下面的格式,
DEF:<vname>=<rrdfile>:<ds-name>:<CF>[:step=<step>][:start=< time >][:end=< time >][:reduce=<CF>]
VDEF:vname=RPN expression
CDEF:vname=RPN expression

其中 filename 就是你想要生成的圖片文件的名稱,默認是 png 。你能夠經過選項修改圖片的類型,能夠有 PNG、SVG、EPS、PDF四種。

(1).DEF 是 Definition (定義)的意思。定義什麼呢?你要繪圖,總要有數據源吧?DEF 就是告訴 RRDtool 從那個 RRD 中取出指定。

爲何還有一個 CF 字段?由於 RRA 有多種CF 類型,有些 RRA 可能用來保存平均值、有些 RRA 可能用於統計最大值、最小值等等。因此你必須同時指定使用什麼 CF 類型的 RRA的數據。

至於 :start 和 :end 、:reduce 則用得比較少,最經常使用的就是 :step 了,它可讓你控制 RRDtool 從那個 RRA 中取數據。


(2).VDEF 是 Variable Definition (變量定義)的意思。定義什麼呢?記得 MRTG 在圖表的下面有一個稱之爲 Legend 的部分嗎?那裏顯示了1個或者2個 DS (MRTG 沒有 DS 一說,這裏是借用 RRDtool 的)的 「最大值」、「平均值」、「當前值」。


RRDtool 中用 VDEF 來定義。這個變量專門存放某個 DS 某種類型的值,例如 eth0_in 的最大值、eht0_out 的當前值等。當你須要象MRTG 同樣輸出數字報表(Legend) 時,就能夠在 GPRINT 子句(sub clause)中調用它。一樣它也須要用一個變量來存放數值。要注意的是,舊版 的 RRDtool 中是用另一種格式來達到相同的目的。新版的 RRDtool 則推薦使用VDEF語句。但在使用過程當中,卻發現 VDEF 的使用反而形成了困擾。 例如你有5個 DS 要畫,每一個 DS 你都想輸出最大值、最小值、平均值 、當前值。 若是使用 VDEF ,則須要 4 * 5 = 20 個 VDEF 語句,這會形成極大的困擾。具體例子能夠看第十一節「數字報表」部分。


(3).CDEF 是 Calculation Define 的意思。使用過MRTG 的都會體會到一點,MRTG 的計算能力實在太差了。例如你有兩個 Target ,一個是 eth0_in , 一個是 eth0_out,若是要把它們相加起來,再除以8,得出 bytes 爲單位的值,如何計算呢?或者說你只想看 eth0_in 中超過 10Mb/s 的那部分, 其他的不關心,又如何實現呢?由於 MRTG 不能對它從 log 取出來的數據進行修改,只能原本來本的表現,因此很難知足咱們的要求。而使用 CDEF , 這一切均可以很容易的實現。CDEF 支持不少數學運算,甚至還支持簡單的邏輯運算 if-then-else ,能夠解決前面提到的第2個問題:如何只繪製你所關 心的數據。不過這一切都須要熟悉 RPN 的語法.因此咱們放到下一節介紹,這一節就介紹把 RRDtool 中的數據以圖表的方式顯示出來。


(4).其它選項分類

本部分咱們按照官方文檔的方式,把選項分紅幾大類,分爲 :

  • Time range : 用於控制圖表的X軸顯示的起始/結束時間,也包括從RRA中提取指定時間的數據。

  • Labels :用於控制 X/Y 軸的說明文字。

  • Size :用於控制圖片的大小。

  • Limits :用於控制 Y 軸的上下限。

  • Grid :用於控制 X/Y 軸的刻度如何顯示。

  • Miscellaneous :其餘選項。例如顯示中文、水印效果等等。

  • Report :數字報表

注,須要說明的是,本博文中並非列出了全部選項的用法,只是列出較爲經常使用的選項,若是想查看全部選項的的用法,能夠到官方站點下載文檔。其實大部分選項咱們均可以使用默認值不須要修改的。下面是經常使用選項,

1
rrdtool graph filename [option ...] [data definition ...] [data calculation ...] [variable definition ...] [graph element ...] [print element ...]
  • filename 要繪製的圖片名稱

  • Time range時間範圍

  • [-s|--start time] 啓始時間[-e|--end time]結束時間 [-S|--step seconds]步長

  • Labels

  • [-t|--title string]圖片的標題 [-v|--vertical-label string] Y軸說明

  • Size

  • [-w|--width pixels] 顯示區的寬度[-h|--height pixels]顯示區的高度 [-j|--only-graph]

  • Limits

  • [-u|--upper-limit value] Y軸正值高度[-l|--lower-limit value]Y軸負值高度 [-r|--rigid]

  • Data and variables

  • DEF:vname=rrdfile:ds-name:CF[:step=step][:start=time][:end=time]

  • CDEF:vname=RPN expression

  • VDEF:vname=RPN expression

好了,到這裏咱們RRDTool命令工具的基本使用,就講解到這裏了更多詳細的內容請參考官方網站。好了,下面咱們來演示一個完整的案例。


6、RRDTool繪圖案例

案例:利用RRDTool來繪製mysql服務器查詢次數的曲線圖。

1.安裝mysql服務器

1
[root@node1 ~] # yum install -y mysql-server

2.啓動並測試

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
41
42
43
44
[root@node1 ~] # chkconfig mysqld on
[root@node1 ~] # service mysqld start
初始化 MySQL 數據庫: Installing MySQL system tables...
OK
Filling help tables...
OK
To start mysqld at boot time you have to copy
support-files /mysql .server to the right place for your system
PLEASE REMEMBER TO SET A PASSWORD FOR THE MySQL root USER !
To do so, start the server, then issue the following commands:
/usr/bin/mysqladmin -u root password 'new-password'
/usr/bin/mysqladmin -u root -h node1. test .com password 'new-password'
Alternatively you can run:
/usr/bin/mysql_secure_installation
which will also give you the option of removing the test
databases and anonymous user created by default. This is
strongly recommended for production servers.
See the manual for more instructions.
You can start the MySQL daemon with:
cd /usr ; /usr/bin/mysqld_safe &
You can test the MySQL daemon with mysql- test -run.pl
cd /usr/mysql-test ; perl mysql- test -run.pl
Please report any problems with the /usr/bin/mysqlbug script!
                               [肯定]
正在啓動 mysqld:                     [肯定]
[root@node1 ~] # mysql
Welcome to the MySQL monitor. Commands end with ; or \g.
Your MySQL connection id is 2
Server version: 5.1.69 Source distribution
Copyright (c) 2000, 2013, Oracle and /or its affiliates. All rights reserved.
Oracle is a registered trademark of Oracle Corporation and /or its
affiliates. Other names may be trademarks of their respective
owners.
Type 'help;' or '\h' for help. Type '\c' to clear the current input statement.
mysql> show databases;
+--------------------+
| Database      |
+--------------------+
| information_schema |
| mysql       |
| test        |
+--------------------+
3 rows in set (0.00 sec)
mysql>

3.建立RRD數據庫文件

1
2
3
4
5
6
7
8
[root@node1 ~] # rrdtool create mysql.rrd --step 3 DS:mysqlselect:COUNTER:5:0:U RRA:AVERAGE:0.5:1:28800 RRA:AVERAGE:0.5:10:2880 RRA:MAX:0.5:10:2880 RRA:LAST:0.5:10:2880
[root@node1 ~] # ll -h
總用量 620K
-rw-------. 1 root root 970 8月 17 18:50 anaconda-ks.cfg
-rw-r--r--. 1 root root 16K 8月 17 18:50 install .log
-rw-r--r--. 1 root root 4.1K 8月 17 18:48 install .log.syslog
-rw-r--r-- 1 root root 294K 10月 11 15:57 mysql.rrd
-rw-r--r-- 1 root root 294K 10月 10 21:53 rrdtool-1.3.8-6.el6.x86_64.rpm

4.抓取數據

1
2
[root@node1 ~] # mysql --batch -e "show global status like 'com_select'" | awk '/Com_select/{print $2}'
5

5.更新RRD數據庫

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
[root@node1 ~] # vim getselect.sh
#!/bin/bash
#
while true ; do
     SELECT=`mysql --batch -e "show global status like 'com_select'" | awk '/Com_select/{print $2}' `
     rrdtool update mysql.rrd N:$SELECT
     sleep 3
done
[root@node1 ~] # bash -n getselect.sh
[root@node1 ~] # bash -x getselect.sh
+ true
++ mysql --batch -e 'show global status like ' \ '' com_select '\'' '
++ awk '/Com_select/{print $2}'
+ SELECT=10
+ rrdtool update mysql.rrd N:10
+ sleep 3
+ true
++ awk '/Com_select/{print $2}'
++ mysql --batch -e 'show global status like ' \ '' com_select '\'' '
+ SELECT=11
+ rrdtool update mysql.rrd N:11
+ sleep 3
+ true
++ mysql --batch -e 'show global status like ' \ '' com_select '\'' '
++ awk '/Com_select/{print $2}'
+ SELECT=12
+ rrdtool update mysql.rrd N:12

注,讓這個腳本一直執行着。

6.建立一個測試數據庫

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
[root@node1 ~] # mysql
Welcome to the MySQL monitor. Commands end with ; or \g.
Your MySQL connection id is 55
Server version: 5.1.69 Source distribution
Copyright (c) 2000, 2013, Oracle and /or its affiliates. All rights reserved.
Oracle is a registered trademark of Oracle Corporation and /or its
affiliates. Other names may be trademarks of their respective
owners.
Type 'help;' or '\h' for help. Type '\c' to clear the current input statement.
mysql> create database testdb;
Query OK, 1 row affected (0.01 sec)
mysql> use testdb;
Database changed
mysql> create table tb1 ( id int UNSIGNED NOT NULL AUTO_INCREMENT PRIMARY KEY, name char(50) NOT NULL);
Query OK, 0 rows affected (0.02 sec)
mysql> show tables;
+------------------+
| Tables_in_testdb |
+------------------+
| tb1       |
+------------------+
1 row in set (0.00 sec)
mysql>

7.建立一個腳本不斷的插入數據並查詢

1
2
3
4
5
6
7
8
9
10
[root@node1 ~] # vim insert.sh
#!/bin/bash
#
for I in {1..200000}; do
     mysql -e "INSERT INTO testdb.tb1(name) VALUES ('stu$I')"
     mysql -e "SELECT * FROM testdb.tb1" &> /dev/null
done
~
[root@node1 ~] # bash -n insert.sh
[root@node1 ~] # bash -x insert.sh

8.查看一下RRD數據庫更新的數據

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
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
[root@node1 ~] # rrdtool fetch -r 3 mysql.rrd AVERAGE
1381478757: -nan
1381478760: -nan
1381478763: -nan
1381478766: -nan
1381478769: -nan
1381478772: -nan
1381478775: 2.7153386392e-01
1381478778: 3.2831536999e-01
1381478781: 3.2891623754e-01
1381478784: 3.2705226490e-01
1381478787: 3.2799497906e-01
1381478790: 3.2750147283e-01
1381478793: 3.2962107218e-01
1381478796: 3.3022497969e-01
1381478799: 3.3027211905e-01
1381478802: 3.3020369194e-01
1381478805: 3.2946024073e-01
1381478808: 3.2988230260e-01
1381478811: 3.2969005472e-01
1381478814: 3.2974230463e-01
1381478817: 3.3001057711e-01
1381478820: 3.3019278582e-01
1381478823: 3.3083777490e-01
1381478826: 3.3015850009e-01
1381478829: 3.2968813815e-01
1381478832: 3.3021007195e-01
1381478835: 3.2890877932e-01
1381478838: 3.2919982365e-01
1381478841: 3.2820752812e-01
1381478844: 3.2498916047e-01
1381478847: 3.2435105446e-01
1381478850: 3.2631508451e-01
1381478853: 3.2927988387e-01
1381478856: 3.3061808059e-01
1381478859: 3.3065099981e-01
1381478862: 3.3079060547e-01
1381478865: 3.2993297013e-01
1381478868: 3.2998088978e-01
1381478871: 3.3045720109e-01
1381478874: 3.3052361682e-01
1381478877: 3.3021445518e-01
1381478880: 3.3033678729e-01
1381478883: 3.3017146110e-01
1381478886: 3.2932443118e-01
1381478889: 3.2872916025e-01
1381478892: 3.2942230122e-01
1381478895: 3.3004157568e-01
1381478898: 3.3035752652e-01
1381478901: 3.3026495130e-01
1381478904: 4.2927608935e-01
1381478907: 5.6199888336e-01
1381478910: 3.2960053815e-01
1381478913: 3.3019513627e-01
1381478916: 3.3008973582e-01
1381478919: 3.3023471404e-01
1381478922: 3.3044897038e-01
1381478925: 3.3025127245e-01
1381478928: 3.2999671137e-01
1381478931: 3.2995130475e-01
1381478934: 3.3001845566e-01
1381478937: 3.3004261932e-01
1381478940: 3.2985954162e-01
1381478943: 3.2962262303e-01
1381478946: 3.3033462847e-01
1381478949: 3.3000997317e-01
1381478952: 3.3023836505e-01
1381478955: 3.2987551061e-01
1381478958: 3.3038940726e-01
1381478961: 3.3047901095e-01
1381478964: 3.2999606597e-01
1381478967: 3.3021352982e-01
1381478970: 3.2998445954e-01
1381478973: 3.3029458891e-01
1381478976: 3.3009257605e-01
1381478979: 3.3008453893e-01
1381478982: 3.2998650516e-01
1381478985: 3.3014434356e-01
1381478988: 3.2950044395e-01

注,你們能夠看到如今已經有不少的數據了,下面咱們來簡單的製做一查詢曲線圖。

9.製做查詢曲線圖

1
2
[root@node1 ~] # rrdtool graph mysql.png -s 1381478754 -t "mysql select" -v "selects/3" DEF:select3=mysql.rrd:mysqlselect:AVERAGE:step=3 LINE1:select3#FF0000:"select"
497x174

10.取出mysql.png圖片並查看

r11

mysql

相關文章
相關標籤/搜索