服務(wù)器管理監(jiān)控系統(tǒng).doc
《服務(wù)器管理監(jiān)控系統(tǒng).doc》由會(huì)員分享,可在線閱讀,更多相關(guān)《服務(wù)器管理監(jiān)控系統(tǒng).doc(22頁珍藏版)》請(qǐng)?jiān)谘b配圖網(wǎng)上搜索。
. 服務(wù)器管理、監(jiān)控系統(tǒng) 摘要:現(xiàn)今互聯(lián)網(wǎng)行業(yè)發(fā)展迅速,底層支撐互聯(lián)網(wǎng)服務(wù)的服務(wù)器等各種硬件設(shè)備規(guī)模越來龐大。如何管理有效地管理這些設(shè)備、實(shí)時(shí)發(fā)現(xiàn)其潛在的隱患、獲取其運(yùn)行的狀態(tài),而顯得至關(guān)重要。根據(jù)這些信息才能合理地決定設(shè)備上所運(yùn)行系統(tǒng)、應(yīng)用等服務(wù)的關(guān)閉與保留與掛起。本文介紹了利用Zabbix開源監(jiān)控解決方案,以及對(duì)該方案的二次開發(fā)而實(shí)現(xiàn)對(duì)服務(wù)器機(jī)房的專家系統(tǒng)。 關(guān)鍵字:機(jī)房運(yùn)維 服務(wù)器監(jiān)控 Zabbix 目錄 摘要 2 1. 引言 4 2. Zabbix 監(jiān)控原理與應(yīng)用 5 2.1. Zabbix 監(jiān)控原理 5 2.2 Zabbix用戶配置 6 3. 監(jiān)控建立與二次開發(fā) 8 4. 系統(tǒng)展示 10 4.1用戶監(jiān)控對(duì)象添加 10 5.總結(jié) 14 參考文獻(xiàn): 15 精選word范本! . 1. 引言 隨著現(xiàn)今互聯(lián)網(wǎng)行業(yè)的迅速發(fā)展,某些物聯(lián)網(wǎng)服務(wù)的用戶已經(jīng)達(dá)到了億級(jí),如淘寶網(wǎng)注冊(cè)用戶已達(dá)到3.7億,僅在2015年“雙十一”當(dāng)天活躍用戶過億[1]。支撐如此龐大用戶使用的硬件基礎(chǔ)是規(guī)模龐大的服務(wù)器群。如何獲取每一臺(tái)服務(wù)器的運(yùn)行狀態(tài),及時(shí)獲悉潛在隱患,出現(xiàn)問題及時(shí)鎖定排除顯得至關(guān)重要。機(jī)房運(yùn)維人員以及高層決策人員只有在實(shí)時(shí)掌握這些信息后才可有效地對(duì)進(jìn)行決策,如在訪問流量過大或其他惡意攻擊后是及時(shí)關(guān)閉服務(wù)還是啟動(dòng)備用服務(wù),服務(wù)區(qū)癱瘓后是需要工作人員至機(jī)房處理硬件問題還是只需遠(yuǎn)程重啟服務(wù)器等類似或簡(jiǎn)單或復(fù)雜的決策,都需要底層專家系統(tǒng)信息的支持。 現(xiàn)今比較成熟的開源服務(wù)器底層數(shù)據(jù)的采集解決方案主要有Zabbix和Nagios。 Nagios是一個(gè)監(jiān)視系統(tǒng)運(yùn)行狀態(tài)和網(wǎng)絡(luò)信息的監(jiān)視系統(tǒng),能監(jiān)視所指定的本地或遠(yuǎn)程主機(jī)以及服務(wù),同時(shí)提供異常通知功能等[2]。Nagios可運(yùn)行在Linux/Unix平臺(tái)之上,同時(shí)提供一個(gè)可選的基于瀏覽器的Web界面以方便系統(tǒng)管理人員查看網(wǎng)絡(luò)狀態(tài),各種系統(tǒng)問題,以及日志等等。 Nagios 可以監(jiān)控的功能有: 1、監(jiān)控網(wǎng)絡(luò)服務(wù)(SMTP、POP3、HTTP、NNTP、PING等); 2、監(jiān)控主機(jī)資源(處理器負(fù)荷、磁盤利用率等); 3、簡(jiǎn)單地插件設(shè)計(jì)使得用戶可以方便地?cái)U(kuò)展自己服務(wù)的檢測(cè)方法; 4、并行服務(wù)檢查機(jī)制; 5、具備定義網(wǎng)絡(luò)分層結(jié)構(gòu)的能力,用"parent"主機(jī)定義來表達(dá)網(wǎng)絡(luò)主機(jī)間的關(guān)系,這種關(guān)系可被用來發(fā)現(xiàn)和明晰主機(jī)宕機(jī)或不可達(dá)狀態(tài); 6、當(dāng)服務(wù)或主機(jī)問題產(chǎn)生與解決時(shí)將告警發(fā)送給聯(lián)系人(通過EMail、短信、用戶定義方式); 7、可以定義一些處理程序,使之能夠在服務(wù)或者主機(jī)發(fā)生故障時(shí)起到預(yù)防作用; 8、自動(dòng)的日志滾動(dòng)功能; 9、可以支持并實(shí)現(xiàn)對(duì)主機(jī)的冗余監(jiān)控; 10、可選的WEB界面用于查看當(dāng)前的網(wǎng)絡(luò)狀態(tài)、通知和故障歷史、日志文件等[2]; 11、可以通過手機(jī)查看系統(tǒng)監(jiān)控信息; 精選word范本! 12、可指定自定義的事件處理控制器[3]。 其他一些大型企業(yè)也有自己獨(dú)立開發(fā)的服務(wù)器監(jiān)控服務(wù),如小米運(yùn)維部的人性化互聯(lián)網(wǎng)企業(yè)級(jí)監(jiān)控系統(tǒng)Open-Falcon、淘寶運(yùn)維部使用 OpenTSDB等,它們也有各自的優(yōu)點(diǎn)。 本文第一章概述了服務(wù)器機(jī)房的專家,以及可提供這些服務(wù)的一些解決方案等;第二章介紹Zabbix所提供的監(jiān)控原理即使用;第三章介紹Zabbix的實(shí)際監(jiān)控應(yīng)用以及二次開發(fā);第四章進(jìn)行專家的分析;第五章對(duì)服務(wù)器機(jī)房專家系統(tǒng)進(jìn)行總結(jié)。 2. Zabbix 監(jiān)控原理與應(yīng)用 Zabbix是一個(gè)B/S模式的企業(yè)級(jí)的監(jiān)控服務(wù)解決方案,用戶可以此獲取服務(wù)器等硬件、操作系統(tǒng)、中間件等的運(yùn)行狀態(tài),為應(yīng)用層的決策提供決策信息。 2.1Zabbix 監(jiān)控原理 Zabbix由agent和server組成,其中agent負(fù)責(zé)采集服務(wù)器等監(jiān)控對(duì)象的數(shù)據(jù),server負(fù)責(zé)處理這些數(shù)據(jù),判斷異常等,并通過提供apache服務(wù)在web端實(shí)現(xiàn)對(duì)數(shù)據(jù)的可視化展示。 其中agent的類型主要監(jiān)控對(duì)象包括: (1)Zabbix-agent,根據(jù)Zabbix監(jiān)控方式實(shí)現(xiàn)對(duì)操作系統(tǒng)層級(jí)的信息采集,實(shí)現(xiàn)對(duì)系統(tǒng)的監(jiān)控。Zabbix-agent 有sender和get兩部分組成,分別通過命令來采集數(shù)據(jù)[4]。監(jiān)控對(duì)象有CPU運(yùn)行狀態(tài)、磁盤I/O、內(nèi)存使用、進(jìn)程線程數(shù)等;同時(shí)可利用其他應(yīng)用提供的端口實(shí)現(xiàn)對(duì)應(yīng)用服務(wù)的監(jiān)控,如MySQL數(shù)據(jù)庫等。 (2)、IPMI-agent,根據(jù)IPMI(Intelligent Platform Management Interface)接口實(shí)現(xiàn)對(duì)服務(wù)器等硬件設(shè)備的監(jiān)控,監(jiān)控對(duì)象包括CPU運(yùn)行溫度、風(fēng)扇轉(zhuǎn)速、環(huán)境溫度等硬件信息的監(jiān)控; (3)SNMP-agent,根據(jù)SNMP(Simple Network Management Protocol)協(xié)議實(shí)現(xiàn)對(duì)交換機(jī)、路由器等網(wǎng)絡(luò)設(shè)備的監(jiān)控。監(jiān)控對(duì)象包括各端口運(yùn)行狀態(tài)、流入流出流量等。 (4)JMX-agent,根具JMX(Java Management Extensions)提供的接口實(shí)現(xiàn)對(duì)Java類應(yīng)用的監(jiān)控。監(jiān)控對(duì)象包括Java虛擬機(jī)、Tomcat服務(wù),Hadoop、Spark等分布式服務(wù)的監(jiān)控等。 當(dāng)agent得到數(shù)據(jù)并發(fā)送給server后,server端將數(shù)組存放在位于服務(wù)端的數(shù)據(jù)庫,然后前端服務(wù)調(diào)用數(shù)據(jù)庫數(shù)據(jù)并將其可視化顯示。顯示給用戶的只有browser頁面,用戶在前端進(jìn)行服務(wù)器管理并據(jù)此進(jìn)行相應(yīng)決策。圖(1)表示了Zabbix 的監(jiān)控原理。 圖1 Zabbix監(jiān)控原理圖 Zabbix 的agent將數(shù)據(jù)發(fā)送給server并儲(chǔ)存在數(shù)據(jù)庫中,前端頁面調(diào)用數(shù)據(jù)庫中的數(shù)據(jù)與用戶交互。 2.2Zabbix用戶配置 Zabbix server處理數(shù)據(jù)時(shí)為了便于用戶操作按圖(2)的方式處理、集成監(jiān)控?cái)?shù)據(jù)。 圖2數(shù)據(jù)處理、集成圖 其中host為用戶監(jiān)控的主機(jī)、設(shè)備或操作系統(tǒng)等;item為實(shí)際的監(jiān)控個(gè)體,可能是某一個(gè)CPU的使用率,磁盤讀寫速度等,一個(gè)host上可能存在若干item;每一個(gè)item都可設(shè)定對(duì)應(yīng)的trigger,根據(jù)閾值判斷還item的使用情況是否達(dá)到報(bào)警值。Trigger發(fā)現(xiàn)報(bào)警后將會(huì)在主界面顯示,也可都過短信、郵件、微信等向用戶發(fā)送報(bào)警信息,并連接后續(xù)修復(fù)操作。 因此用戶在實(shí)際使用時(shí)主要需配置host,item和trigger,分別如圖(3)、圖(4)、圖(5)所示。 圖3 Host配置圖 用戶配置監(jiān)控方式即監(jiān)控對(duì)象,包括監(jiān)控Host配置圖對(duì)象的名稱、所在群組、監(jiān)控方式、IP地址等。 圖4 item配置圖 用戶根據(jù)不同的監(jiān)控類型配置監(jiān)控的具體個(gè)體,可設(shè)置監(jiān)控元素、監(jiān)控周期、數(shù)據(jù)保存時(shí)限等。 圖5 trigger配置圖 Trigger配置報(bào)警信息,其中Expression為表達(dá)式判斷item的使用情況。如圖所示為空閑內(nèi)存與全部內(nèi)存的比值,但可用內(nèi)存的使用率小于20%時(shí),將產(chǎn)生報(bào)警,警報(bào)級(jí)別為高。 除了上述3種配置外,用戶還可通過配置graph、map、screen等,分別配置數(shù)據(jù)展示圖,host關(guān)系圖、監(jiān)控大屏等。 3. 監(jiān)控建立與二次開發(fā) 本監(jiān)控與專家系統(tǒng)根據(jù)東海分局預(yù)報(bào)中心需要,利用Zabbix監(jiān)控體系并結(jié)合Java web技術(shù)二次開發(fā)建立,為整個(gè)預(yù)報(bào)中心提高機(jī)房管理、監(jiān)控專家服務(wù)。 3.1 搭建環(huán)境 本系統(tǒng)選擇Ubuntu server 作為Zabbix server所在服務(wù)器,上文四種監(jiān)控agent部署與客戶端采集數(shù)據(jù);數(shù)據(jù)庫選擇MySQL server;網(wǎng)頁服務(wù)選擇apache開源服務(wù);同時(shí)利用spring boot 框架進(jìn)行java web開發(fā),整合Zabbix的api,并直接處理Zabbix數(shù)據(jù)庫,在交互更良好的頁面實(shí)現(xiàn)管理與決策。 3.2 Zabbix server建立 根據(jù)Zabbix的監(jiān)控原理,server的搭建主要包括數(shù)據(jù)庫的建立,apache web服務(wù)的建立,Zabbix server的建立等,另外Zabbix server只能搭建在Linux系統(tǒng)中。本系統(tǒng)中Zabbix server的安裝都選擇Ubuntu系統(tǒng)下的編譯安裝,具體建立流程不在贅述,詳情參見Zabbix用戶手冊(cè)[5]。 3.3 二次開發(fā) Zabbix 原始界面為英文界面,中文翻譯的界面十分生硬,不便于中國用戶使用。本系統(tǒng)對(duì)Zabbix進(jìn)行了二次開發(fā),在Zabbix上用封裝了一層用戶管理系統(tǒng)。本系統(tǒng)使用Java web技術(shù),結(jié)合Zabbix api操作Zabbix數(shù)據(jù),同時(shí)根據(jù)用戶需要添加了針對(duì)性的服務(wù)。系統(tǒng)界面如圖6: 圖6平臺(tái)界面 如圖所示,用戶可添加硬件、中間件、操作系統(tǒng)等類型的host。 圖(7)為用戶添加host的界面: 圖7后臺(tái)host添加頁面 用戶可在次添加設(shè)備信息,同時(shí)根據(jù)Zabbix的api可將添加的數(shù)據(jù)發(fā)送值Zabbix server,實(shí)現(xiàn)Zabbix對(duì)該設(shè)備的監(jiān)控。Host添加代碼如下,host的添加選擇了使用Zabbix api實(shí)現(xiàn): /** * Created by light on 2016/2/26. */ public class ZbxHostServiceImpl { public static IHostService hostService = new HostServiceImpl(); static { // 登錄 Login.login(); } // Type: 1 - Zbx_agent; 2 - SNMP; 3 - IPMI 4 - JMX. // Port: 1 - 10050; 2 - 161; 3 - 12345; 4 - 632 public static CreateDuplicate createDuplicate = new CreateDuplicate(); String response; //創(chuàng)建防火墻 public String createHostFw(String hostName,String interfaceIp) { response= createDuplicate.createHostEasy(hostName,interfaceIp,"161","10081",2); return response; } // 創(chuàng)建主機(jī) 收集服務(wù)器性能信息:CPU、Memory等 public String createHostHost(String hostName,String interfaceIp) { response= createDuplicate.createHostEasy(hostName,interfaceIp,"10050","10081",1); return response; } //創(chuàng)建iis 服務(wù) public String createHostIIS(String hostName,String interfaceIp) { response= createDuplicate.createHostEasy(hostName,interfaceIp,"10050","10081",1); return response; } //創(chuàng)建jvm public String createHostJava(String hostName,String interfaceIp) { response= createDuplicate.createHostEasy(hostName,interfaceIp,"12345","10081",4); return response; } //創(chuàng)建 oracle 數(shù)據(jù)庫 public String createHostOracle(String hostName,String interfaceIp) { response= createDuplicate.createHostEasy(hostName,interfaceIp,"161","10081",2); return response; } // 創(chuàng)建 ping 監(jiān)控 changes needed here public String createHostPing(String hostName,String interfaceIp) { response= createDuplicate.createHostEasy(hostName,interfaceIp,"10050","10081",1); return response; } //創(chuàng)建路由 public String createHostRouter(String hostName,String interfaceIp) { response= createDuplicate.createHostEasy(hostName,interfaceIp,"161","10081",2); return response; } // 收集服務(wù)器硬件信息:溫度,轉(zhuǎn)速等 public String createHostServer(String hostName,String interfaceIp,String interfacePort) { response= createDuplicate.createHostEasy(hostName,interfaceIp,interfacePort,"10081",1); return response; } //創(chuàng)建IPMI public String createHostServerIPMI(String hostName,String interfaceIp) { response= createDuplicate.createHostEasy(hostName,interfaceIp,"623","10081",4); return response; } public String createHostSqlserver(String hostName,String interfaceIp) { response= createDuplicate.createHostEasy(hostName,interfaceIp,"10050","10081",1); return response; } //創(chuàng)建存儲(chǔ) public String createHostStore(String hostName,String interfaceIp) { response= createDuplicate.createHostEasy(hostName,interfaceIp,"10050","10081",1); return response; } //創(chuàng)建交換機(jī) With Group public String createHostSwitchboard(String hostName,String interfaceIp) { response= createDuplicate.createHostWithGroup(hostName, interfaceIp, "9","161","10208",2); return response; } //創(chuàng)建tomact服務(wù) public String createHostTomcat(String hostName,String interfaceIp) { response= createDuplicate.createHostEasy(hostName,interfaceIp,"12345","10081",4); return response; } // 創(chuàng)建虛擬機(jī) public String createHostVmware(String hostName,String interfaceIp) { response= createDuplicate.createHostEasy(hostName,interfaceIp,"10050","10081",1); return response; } public String ZbxDeleteServer(String hostId) { // 數(shù)據(jù)準(zhǔn)備 HostDeleteRequest delete = new HostDeleteRequest(); delete.getParams().add(hostId); return hostService.delete(delete); } public JSONObject getHostIdAndName(){ HostGetRequest hostGetRequestContent = new HostGetRequest(); String[] outputs = {"name"}; hostGetRequestContent.getParams().setOutput(outputs); // hostGetRequestContent.getParams(); return hostService.get(hostGetRequestContent); } public JSONObject getHostIdAndName(String hostid){ HostGetRequest hostGetRequestContent = new HostGetRequest(); String[] outputs = {"name"}; String[] hostids = { hostid }; hostGetRequestContent.getParams().setOutput(outputs); hostGetRequestContent.getParams().setHostids(hostids); return hostService.get(hostGetRequestContent); } public static class HostArray{ public static ArrayList- 1.請(qǐng)仔細(xì)閱讀文檔,確保文檔完整性,對(duì)于不預(yù)覽、不比對(duì)內(nèi)容而直接下載帶來的問題本站不予受理。
- 2.下載的文檔,不會(huì)出現(xiàn)我們的網(wǎng)址水印。
- 3、該文檔所得收入(下載+內(nèi)容+預(yù)覽)歸上傳者、原創(chuàng)作者;如果您是本文檔原作者,請(qǐng)點(diǎn)此認(rèn)領(lǐng)!既往收益都?xì)w您。
下載文檔到電腦,查找使用更方便
15 積分
下載 |
- 配套講稿:
如PPT文件的首頁顯示word圖標(biāo),表示該P(yáng)PT已包含配套word講稿。雙擊word圖標(biāo)可打開word文檔。
- 特殊限制:
部分文檔作品中含有的國旗、國徽等圖片,僅作為作品整體效果示例展示,禁止商用。設(shè)計(jì)者僅對(duì)作品中獨(dú)創(chuàng)性部分享有著作權(quán)。
- 關(guān) 鍵 詞:
- 服務(wù)器管理 監(jiān)控 系統(tǒng)
鏈接地址:http://italysoccerbets.com/p-5365959.html