成人免费xxxxx在线视频软件_久久精品久久久_亚洲国产精品久久久_天天色天天色_亚洲人成一区_欧美一级欧美三级在线观看

用 Python 腳本實現對 Linux 服務器的監控

系統 Linux
在實際工作中,Linux 系統管理員可以根據自己使用的服務器的具體情況編寫一下簡單實用的腳本實現對 Linux 服務器的監控。 本文介紹了使用 Python 腳本實現對 Linux 服務器 CPU 內存 網絡的監控腳本的編寫方法。

目前 Linux 下有一些使用 Python 語言編寫的 Linux 系統監控工具 比如 inotify-sync(文件系統安全監控軟件)、glances(資源監控工具)等,在實際工作中,Linux 系統管理員可以根據自己使用的服務器的具體情況編寫一下簡單實用的腳本實現對 Linux 服務器的監控。 本文介紹一下使用 Python 腳本實現對 Linux 服務器 CPU 內存 網絡的監控腳本的編寫。

Python 版本說明

Python 是由 Guido van Rossum 開發的、可免費獲得的、非常高級的解釋型語言。其語法簡單易懂,而其面向對象的語義功能強大(但又靈活)。Python 可以廣泛使用并具有高度的可移植性。本文 Linux 服務器是 Ubuntu 12.10, Python 版本 是 2.7 。如果是 Python 3.0 版本的語法上有一定的出入。另外這里筆者所說的 Python 是 CPython,CPython 是用 C 語言實現的 Python 解釋器,也是官方的并且是最廣泛使用的Python 解釋器。除了 CPython 以外,還有用 Java 實現的 Jython 和用.NET 實現的 IronPython,使 Python方便地和 Java 程序、.NET 程序集成。另外還有一些實驗性的 Python 解釋器比如 PyPy。CPython 是使用字節碼的解釋器,任何程序源代碼在執行之前先要編譯成字節碼。它還有和幾種其它語言(包括 C 語言)交互的外部函數接口。

工作原理:基于/proc 文件系統

Linux 系統為管理員提供了非常好的方法,使其可以在系統運行時更改內核,而不需要重新引導內核系統,這是通過/proc 虛擬文件系統實現的。/proc 文件虛擬系統是一種內核和內核模塊用來向進程(process)發送信息的機制(所以叫做“/proc”),這個偽文件系統允許與內核內部數據結構交互,獲取有關進程的有用信息,在運行中(on the fly)改變設置(通過改變內核參數)。與其他文件系統不同,/proc 存在于內存而不是硬盤中。proc 文件系統提供的信息如下:

  • 進程信息:系統中的任何一個進程,在 proc 的子目錄中都有一個同名的進程 ID,可以找到 cmdline、mem、root、stat、statm,以及 status。某些信息只有超級用戶可見,例如進程根目錄。每一個單獨含有現有進程信息的進程有一些可用的專門鏈接,系統中的任何一個進程都有一個單獨的自鏈接指向進程信息,其用處就是從進程中獲取命令行信息。
  • 系統信息:如果需要了解整個系統信息中也可以從/proc/stat 中獲得,其中包括 CPU 占用情況、磁盤空間、內存對換、中斷等。
  • CPU 信息:利用/proc/CPUinfo 文件可以獲得中央處理器的當前準確信息。
  • 負載信息:/proc/loadavg 文件包含系統負載信息。
  • 系統內存信息:/proc/meminfo 文件包含系統內存的詳細信息,其中顯示物理內存的數量、可用交換空間的數量,以及空閑內存的數量等。

表 1 是 /proc 目錄中的主要文件的說明:

表 1 /proc 目錄中的主要文件的說明

下面本文的幾個例子都是使用 Python 腳本讀取/proc 目錄中的主要文件來實現實現對 Linux 服務器的監控的 。

#p#

使用 Python 腳本實現對 Linux 服務器的監控

  • 對于 CPU(中央處理器)監測

腳本 1 名稱 CPU1.py,作用獲取 CPU 的信息。

清單 1.獲取 CPU 的信息:

  1. #!/usr/bin/env Python  
  2. from __future__ import print_function  
  3. from collections import OrderedDict  
  4. import pprint  
  5. def CPUinfo():  
  6. ''' Return the information in /proc/CPUinfo  
  7. as a dictionary in the following format:  
  8. CPU_info['proc0']={...}  
  9. CPU_info['proc1']={...}  
  10. '''  
  11. CPUinfo=OrderedDict()  
  12. procinfo=OrderedDict()  
  13. nprocs = 0  
  14. with open('/proc/CPUinfo') as f:  
  15. for line in f:  
  16. if not line.strip():  
  17. # end of one processor  
  18. CPUinfo['proc%s' % nprocs] = procinfo  
  19. nprocsnprocsnprocs=nprocs+1  
  20. # Reset  
  21. procinfo=OrderedDict()  
  22. else:  
  23. if len(line.split(':')) == 2:  
  24. procinfo[line.split(':')[0].strip()] = line.split(':')[1].strip()  
  25. else:  
  26. procinfo[line.split(':')[0].strip()] = ''  
  27. return CPUinfo  
  28. if __name__=='__main__':  
  29. CPUinfoCPUinfoCPUinfo = CPUinfo()  
  30. for processor in CPUinfo.keys():  
  31. print(CPUinfo[processor]['model name'])  

簡單說明一下清單 1,讀取/proc/CPUinfo 中的信息,返回 list,每核心一個 dict。其中 list 是一個使用方括號括起來的有序元素集合。List 可以作為以 0 下標開始的數組。Dict 是 Python 的內置數據類型之一, 它定義了鍵和值之間一對一的關系。OrderedDict 是一個字典子類,可以記住其內容增加的順序。常規 dict 并不跟蹤插入順序,迭代處理時會根據鍵在散列表中存儲的順序來生成值。在 OrderedDict 中則相反,它會記住元素插入的順序,并在創建迭代器時使用這個順序。

可以使用 Python 命令運行腳本 CPU1.py 結果見圖 1:

  1. # Python CPU1.py  
  2. Intel(R) Celeron(R) CPU E3200  @ 2.40GHz  

圖 1.運行清單 1

也可以使用 chmod 命令添加權限收直接運行 CPU1.py:

  1. #chmod +x CPU1.py 
  2. # ./CPU1.py 
  • 對于系統負載監測

腳本 2 名稱 CPU2.py,作用獲取系統的負載信息

清單 2 獲取系統的負載信息:

  1. #!/usr/bin/env Python 
  2. import os 
  3. def load_stat(): 
  4. loadavg = {} 
  5. f = open("/proc/loadavg") 
  6. con = f.read().split() 
  7. f.close() 
  8. loadavg['lavg_1']=con[0] 
  9. loadavg['lavg_5']=con[1] 
  10. loadavg['lavg_15']=con[2] 
  11. loadavg['nr']=con[3] 
  12. loadavg['last_pid']=con[4] 
  13. return loadavg 
  14. print "loadavg",load_stat()['lavg_15'] 

簡單說明一下清單 2:清單 2 讀取/proc/loadavg 中的信息,import os :Python 中 import 用于導入不同的模塊,包括系統提供和自定義的模塊。其基本形式為:import 模塊名 [as 別名],如果只需要導入模塊中的部分或全部內容可以用形式:from 模塊名 import *來導入相應的模塊。OS 模塊 os 模塊提供了一個統一的操作系統接口函數,os 模塊能在不同操作系統平臺如 nt,posix 中的特定函數間自動切換,從而實現跨平臺操作。

可以使用 Python 命令運行腳本 CPU1.py 結果見圖 2:

  1. # Python CPU2.py 

圖 2.運行清單 2

  • 對于內存信息的獲取

腳本 3 名稱 mem.py,作用是獲取內存使用情況信息。

清單 3 獲取內存使用情況:

  1. #!/usr/bin/env Python 
  2. from __future__ import print_function 
  3. from collections import OrderedDict 
  4. def meminfo(): 
  5. ''' Return the information in /proc/meminfo 
  6. as a dictionary ''' 
  7. meminfo=OrderedDict() 
  8. with open('/proc/meminfo') as f: 
  9. for line in f: 
  10. meminfo[line.split(':')[0]] = line.split(':')[1].strip() 
  11. return meminfo 
  12. if __name__=='__main__': 
  13. #print(meminfo()) 
  14. meminfomeminfo = meminfo() 
  15. print('Total memory: {0}'.format(meminfo['MemTotal'])) 
  16. print('Free memory: {0}'.format(meminfo['MemFree'])) 

簡單說明一下清單 3:清單 3 讀取 proc/meminfo 中的信息,Python 字符串的 split 方法是用的頻率還是比較多的。比如我們需要存儲一個很長的數據,并且按照有結構的方法存儲,方便以后取數據進行處理。當然可以用 json 的形式。但是也可以把數據存儲到一個字段里面,然后有某種標示符來分割。 Python 中的 strip 用于去除字符串的首位字符,最后清單 3 打印出內存總數和空閑數。

#p#

可以使用 Python 命令運行腳本 mem.py 結果見圖 3。

  1. # Python mem.py 

圖 3.運行清單 3

  • 對于網絡接口的監測

腳本 4 名稱是 net.py,作用獲取網絡接口的使用情況。

清單 4 net.py 獲取網絡接口的輸入和輸出:

  1. #!/usr/bin/env Python 
  2. import time 
  3. import sys 
  4. if len(sys.argv) > 1: 
  5. INTERFACE = sys.argv[1] 
  6. else: 
  7. INTERFACE = 'eth0' 
  8. STATS = [] 
  9. print 'Interface:',INTERFACE 
  10. def rx(): 
  11. ifstat = open('/proc/net/dev').readlines() 
  12. for interface in  ifstat: 
  13. if INTERFACE in interface: 
  14. stat = float(interface.split()[1]) 
  15. STATS[0:] = [stat] 
  16. def tx(): 
  17. ifstat = open('/proc/net/dev').readlines() 
  18. for interface in  ifstat: 
  19. if INTERFACE in interface: 
  20. stat = float(interface.split()[9]) 
  21. STATS[1:] = [stat] 
  22. print   'In         Out' 
  23. rx() 
  24. tx() 
  25. while   True: 
  26. time.sleep(1) 
  27. rxstat_o = list(STATS) 
  28. rx() 
  29. tx() 
  30. RX = float(STATS[0]) 
  31. RX_O = rxstat_o[0] 
  32. TX = float(STATS[1]) 
  33. TX_O = rxstat_o[1] 
  34. RX_RATE = round((RX - RX_O)/1024/1024,3) 
  35. TX_RATE = round((TX - TX_O)/1024/1024,3) 
  36. print RX_RATE ,'MB      ',TX_RATE ,'MB' 

簡單說明一下清單 4:清單 4 讀取/proc/net/dev 中的信息,Python 中文件操作可以通過 open 函數,這的確很像 C 語言中的 fopen。通過 open 函數獲取一個 file object,然后調用 read(),write()等方法對文件進行讀寫操作。另外 Python 將文本文件的內容讀入可以操作的字符串變量非常容易。文件對象提供了三個“讀”方法: read()、readline() 和 readlines()。每種方法可以接受一個變量以限制每次讀取的數據量,但它們通常不使用變量。 .read() 每次讀取整個文件,它通常用于將文件內容放到一個字符串變量中。然而 .read() 生成文件內容最直接的字符串表示,但對于連續的面向行的處理,它卻是不必要的,并且如果文件大于可用內存,則不可能實現這種處理。.readline() 和 .readlines() 之間的差異是后者一次讀取整個文件,象 .read() 一樣。.readlines() 自動將文件內容分析成一個行的列表,該列表可以由 Python 的 for … in … 結構進行處理。另一方面,.readline() 每次只讀取一行,通常比 .readlines() 慢得多。僅當沒有足夠內存可以一次讀取整個文件時,才應該使用 .readline()。最后清單 4 打印出網絡接口的輸入和輸出情況。

可以使用 Python 命令運行腳本 net.py 結果見圖 4

  1. #Python net.py 

圖 4.運行清單 4

監控 Apache 服務器進程的 Python 腳本

Apache 服務器進程可能會因為系統各種原因而出現異常退出,導致 Web 服務暫停。所以筆者寫一個 Python 腳本文件:

清單 5 crtrl.py 監控 Apache 服務器進程的 Python 腳本:

  1. #!/usr/bin/env Python 
  2. import os, sys, time 
  3. while True: 
  4. time.sleep(4) 
  5. try: 
  6. ret = os.popen('ps -C apache -o pid,cmd').readlines() 
  7. if len(ret) < 2: 
  8. print "apache 進程異常退出, 4 秒后重新啟動" 
  9. time.sleep(3) 
  10. os.system("service apache2 restart") 
  11. except: 
  12. print "Error", sys.exc_info()[1] 

設置文件權限為執行屬性(使用命令 chmod +x crtrl.py),然后加入到/etc/rc.local 即可,一旦 Apache 服務器進程異常退出,該腳本自動檢查并且重啟。 簡單說明一下清單 5 這個腳本不是基于/proc 偽文件系統的,是基于 Python 自己提供的一些模塊來實現的 。這里使用的是 Python 的內嵌 time 模板,time 模塊提供各種操作時間的函數。

總結

在實際工作中,Linux 系統管理員可以根據自己使用的服務器的具體情況編寫一下簡單實用的腳本實現對 Linux 服務器的監控。本文介紹一下使用 Python 腳本實現對 Linux 服務器 CPU 、系統負載、內存和 網絡使用情況的監控腳本的編寫方法。

責任編輯:黃丹 來源: jobbole.com
相關推薦

2010-12-17 09:22:01

Linux服務器性能監控Munin

2011-03-25 15:01:25

Cacti監控Windows

2011-03-31 12:48:04

cactiLinuxWindows

2009-04-28 19:38:02

LinuxSrvRepor遠程監控

2011-04-02 11:12:48

cacti監控windows

2011-03-25 15:24:40

Nagios監控

2009-12-09 10:01:41

ibmdwShell刀片服務器

2011-03-22 09:07:13

Nagios監控Linux

2020-06-07 11:54:34

Linux服務器命令

2019-06-13 17:15:30

監控Linux服務器

2018-12-11 10:39:14

Python服務器微信

2010-02-03 10:24:48

監控寶監控Linux

2012-05-07 10:08:25

Linux

2019-02-11 10:05:10

監控Linux命令

2011-01-21 14:52:37

Sendmail

2011-04-06 15:05:56

nagios監控Linux

2017-02-05 16:48:38

LinuxGanglia

2011-08-22 12:25:08

nagios

2009-06-08 10:30:00

ASP腳本服務器

2011-04-06 14:24:28

nagios監控Linux
點贊
收藏

51CTO技術棧公眾號

主站蜘蛛池模板: 97免费在线视频 | 久久久久久久久99精品 | 福利视频网址 | 99久久婷婷国产综合精品电影 | 日本精a在线观看 | 福利影院在线看 | 日韩不卡一区二区 | 伊人一区| 欧美精品在线播放 | 亚洲免费网 | 九九久久久 | 日韩在线免费看 | 欧美一级在线免费观看 | 久久久做 | 亚洲欧美在线一区 | 午夜影院在线观看 | 欧美日韩一二三区 | 国产精品免费播放 | 国产精品日本一区二区不卡视频 | 给我免费的视频在线观看 | 成人免费大片黄在线播放 | 日韩欧美在| 日韩第一夜 | 成人福利在线 | 99re视频在线免费观看 | 国产精品一区久久久 | 成人网在线观看 | 99热在线免费 | 99视频免费在线 | 一区二区三区在线免费 | 在线国产一区 | 亚洲一区播放 | 三级黄色片在线观看 | 中文字幕在线视频一区二区三区 | 欧美一级艳情片免费观看 | 成人自拍视频网站 | 婷婷福利视频导航 | 日日操夜夜操视频 | 久久久久国产精品一区 | 91视频大全| 国产精品视频 |