部署簡單。Go編譯生成的是一個靜態(tài)可執(zhí)行文件,除了glibc外沒有其他外部依賴。這讓部署變得異常方便:目標機器上只需要一個基礎的系統(tǒng)和必要的管理、監(jiān)控工具,完全不需要操心應用所需的各種包、庫的依賴關系,大大減輕了維護的負擔。這和Python有著巨大的區(qū)別。由于歷史的原因,Python的部署工具生態(tài)相當混亂【比如setuptools,distutils,pip,
專注于為中小企業(yè)提供成都網站制作、做網站服務,電腦端+手機端+微信端的三站合一,更高效的管理,為中小企業(yè)漢陽免費做網站提供優(yōu)質的服務。我們立足成都,凝聚了一批互聯(lián)網行業(yè)人才,有力地推動了上千企業(yè)的穩(wěn)健成長,幫助中小企業(yè)通過網站建設實現規(guī)模擴充和轉變。
buildout的不同適用場合以及兼容性問題】。官方PyPI源又經常出問題,需要搭建私有鏡像,而維護這個鏡像又要花費不少時間和精力。
并發(fā)性好。Goroutine和channel使得編寫高并發(fā)的服務端軟件變得相當容易,很多情況下完全不需要考慮鎖機制以及由此帶來的各種問題。單個Go應用也能有效的利用多個CPU核,并行執(zhí)行的性能好。這和Python也是天壤之比。多線程和多進程的服務端程序編寫起來并不簡單,而且由于全局鎖GIL的原因,多線程的Python程序并不能有效利用多核,只能用多進程的方式部署;如果用標準庫里的multiprocessing包又會對監(jiān)控和管理造成不少的挑戰(zhàn)【我們用的supervisor管理進程,對fork支持不好】。部署Python應用的時候通常是每個CPU核部署一個應用,這會造成不少資源的浪費,比如假設某個Python應用啟動后需要占用100MB內存,而服務器有32個CPU核,那么留一個核給系統(tǒng)、運行31個應用副本就要浪費3GB的內存資源。
良好的語言設計。從學術的角度講Go語言其實非常平庸,不支持許多高級的語言特性;但從工程的角度講,Go的設計是非常優(yōu)秀的:規(guī)范足夠簡單靈活,有其他語言基礎的程序員都能迅速上手。更重要的是Go自帶完善的工具鏈,大大提高了團隊協(xié)作的一致性。比如gofmt自動排版Go代碼,很大程度上杜絕了不同人寫的代碼排版風格不一致的問題。把編輯器配置成在編輯存檔的時候自動運行gofmt,這樣在編寫代碼的時候可以隨意擺放位置,存檔的時候自動變成正確排版的代碼。此外還有gofix,
govet等非常有用的工具。
執(zhí)行性能好。雖然不如C和Java,但通常比原生Python應用還是高一個數量級的,適合編寫一些瓶頸業(yè)務。內存占用也非常省。
Cacti(英文含義為仙人掌〉是一套基于 PHP、MySQL、SNMP和 RRDtool開發(fā)的網絡流量監(jiān)測圖形分析工具。
它通過snmpget來獲取數據,使用RRDTool繪圖,但使用者無須了解RRDTool復雜的參數。它提供了非常強大的數據和用戶管理功能,可以指定每一個用戶能查看樹狀結構、主機設備以及任何一張圖,還可以與LDAP 結合進行用戶認證,同時也能自定義模板,在歷史數據的展示監(jiān)控方面,其功能相當不錯。
Cacti通過添加模板,使不同設備的監(jiān)控添加具有可復用性,并且具備可自定義繪圖的功能,具有強大的運算能力(數據的疊加功能)
1.2Nagios
Nagios是一款開源的免費網絡監(jiān)視工具,能有效監(jiān)控windows、Linux和Unix的主機狀態(tài),交換機、打印機、路由器等網絡設備。在系統(tǒng)或服務狀態(tài)異常時發(fā)出郵件或短信報警第一時間通知網站運維人員,在狀態(tài)恢復后發(fā)出正常的郵件或短信通知。
nagios主要的特征是監(jiān)控告警,最強大的就是告警功能,可支持多種告警方式,但缺點是沒有強大的數據收集機制,并且數據出圖也很簡陋,當監(jiān)控的主機越來越多時,添加主機也非常麻煩,配置文件都是基于文本配置的,不支持web方式管理和配置,這樣很容易出錯,不宜維護。
1.3Zabbix
zabbix是一個基于WEB界面的提供分布式系統(tǒng)監(jiān)視以及網絡監(jiān)視功能的企業(yè)級的開源解決方案。zabbix能監(jiān)視各種網絡參數,保證服務器系統(tǒng)的安全運營;并提供強大的通知機制以讓系統(tǒng)運維人員快速定位/解決存在的各種問題。
zabbix由2部分構成,zabbix server與可選組件zabbix agent。zabbix server可以通過SNMP,zabbix,agent,ping,端口監(jiān)視等方法提供對遠程服務器/網絡狀態(tài)的監(jiān)視,數據收集等功能,它可以運行在Linux,Solaris,HP-UX,AIX,Free BSD,Open BSD,os x等平臺上。
zabbix解決了cacti沒有告警的不足,也解決了nagios不能通過web配置的缺點,同時還支持分布式部署,這使得它迅速流行起來,zabbix也成為目前中小企業(yè)監(jiān)控最流行的運維監(jiān)控平臺。當然,zabbix也有不足之處,它消耗的資源比較多,如果監(jiān)控的主機非常多時(服務器數量超過500臺),可能會出現監(jiān)控超時、告警超時、告警系統(tǒng)單點故障等現象,不過也有很多解決辦法,比如提高硬件性能、改變zabbix監(jiān)控模式等。
① agent代理:專門的代理服務方式進行監(jiān)控,專屬的協(xié)議,裝有zabbix-agent的主機就可以被zabbix-server監(jiān)控,主
動或被動的方式,把數據給到server進行處理。
② ssh/telent:linux主機支持ssh/telent協(xié)議
③ snmp:網絡設備路由器、交換機不能安裝第三方程序(agent),使用簡單網絡協(xié)議。大多數的路由器設備支持SNMP協(xié)議
④ ipmi:通過ipmi接口進行監(jiān)控,我們可以通過標準的ipmi硬件接口,監(jiān)控被監(jiān)控對象的物理特征,比如電壓,溫度,
風扇狀態(tài)電源情況,被廣泛使用服務監(jiān)控中,包括采集cpu溫度,風扇轉速,主板溫度,及遠程開關機等等,而且ipmi獨立于硬件和操作系統(tǒng),無論是cpu,bios還是os出現故障,都不會影響ipmi的工作,因為ipmi的硬件設備BMC(bashboard management controller)是獨立的板卡,獨立供電
⑤ zabbix核心組件介紹
Zabbix Server:
Zabbix軟件實現監(jiān)控的核心程序,主要功能是與Zabbixproxies和Agents進行交互、觸發(fā)器計算、發(fā)送告警通知;并將數據集中保存。與prometheus的類似可以保存收集到的數據,但是prometheus告警需要使用altermanager組件
Database storage:
存儲配置信息以及收集到的數據
web Interface:
Zabbix的GUI接口,通常與server運行在同一臺機器上
Proxy:
可選組件,常用于分布式監(jiān)控環(huán)境中,一個幫助zabbix Server收集數據,分擔zabbix Server的負載的程序
Agent:
部署在被監(jiān)控主機上,負責收集數據發(fā)送給server
1.5Prometheus
borg.kubernetes
borgmon(監(jiān)控系統(tǒng)) 對應克隆的版本:prometheus(go語言)
所以prometheus 特別適合K8S 的架構上
而作為一個數據監(jiān)控解決方案,它由一個大型社區(qū)支持,有來自700多家公司的6300個貢獻者,13500個代碼提交和7200個拉取請求
Prometheus具有以下特性:
① 多維的數據模型(基于時間序列的Key、value鍵值對)
② 靈活的查詢和聚合語言PromQL(難)
③ 提供本地存儲和分布式存儲
④ 通過基于HTTP和HTTPS的Pull模型采集時間序列數據(pull數據的拉取,時間序列:每段
時間點的數據值指標,持續(xù)性的產生。橫軸標識時間,縱軸為數據值,一段時間內數值的動態(tài)變化,所有的點連線形成大盤式的折線圖)
⑤ 可利用Pushgateway (Prometheus的可選中間件)實現Push模式
⑥ 可通過動態(tài)服務發(fā)現或靜態(tài)配置發(fā)現目標機器(通過consul自動發(fā)現和收縮)
⑦ 支持多種圖表和數據大盤
open-Falcaon是小米開源的企業(yè)級監(jiān)控工具,用GO語言開發(fā),包括小米、滴滴、美團等在內的互聯(lián)網公司都在使用它,是一款靈活、可拓展并且高性能的監(jiān)控方案。
服務器工作狀態(tài)可以通過不同方式監(jiān)控。
SNMP和IPMI都是可以的。但是由于很多服務器的數據非常重要,而利用接口的方式監(jiān)控有被黑客攻擊的風險。
現在銀行系統(tǒng)、金融等系統(tǒng)很多采用一種稱之為“神鷹光眼”的方式監(jiān)控服務器狀態(tài)指示燈。用以向監(jiān)控系統(tǒng)實時報告服務器的運行狀態(tài)。由于其采用了最新的光纖技術,與服務器之間物理隔絕。因此系統(tǒng)的安全性得以保障。