Prometheus(三):Prometheus監控交換機(snmp)

来源:https://www.cnblogs.com/guoxiangyue/archive/2019/11/04/11778217.html
-Advertisement-
Play Games

預設已安裝Prometheus服務,服務地址:192.168.56.200 一、獲取交換機snmp信息 snmp服務IP(交換機IP):172.20.2.83 snmp community:dfetest 二、部署 snmp_exporter 2.1 下載snmp_exporter 下載snmp_e ...


預設已安裝Prometheus服務,服務地址:192.168.56.200

一、獲取交換機snmp信息

snmp服務IP(交換機IP):172.20.2.83

snmp community:dfetest

二、部署 snmp_exporter

2.1 下載snmp_exporter

下載snmp_exporter安裝包,下載地址:https://github.com/prometheus/snmp_exporter/releases 

下載完成後,上傳至機器的  /usr/local 目錄下

 解壓安裝包

#   tar -zvxf snmp_exporter-0.15.0.linux-arm64.tar.gz 
#   mv snmp_exporter-0.15.0.linux-arm64/ snmp_exporter

2.2 配置snmp_exporter

snmp_exporter的配置文件需要自己通過SNMP Exporter Config Generator 項目編譯生成,

參考方法: https://github.com/prometheus/snmp_exporter/tree/master/generator#file-format  

由於Prometheus使用go語言開發的,所以自己編譯生成snmp_exporter的配置文件需要go環境,Linux中安裝go環境可參考:https://www.cnblogs.com/guoxiangyue/p/11772717.html  中安裝go環境章節

go環境安裝以後,構建snmp exporter  config Generator,執行以下操作:

#  yum -y install git
#  yum -y install gcc gcc-g++ make net-snmp net-snmp-utils net-snmp-libs net-snmp-devel
#  go get github.com/prometheus/snmp_exporter/generator
#  cd ${GOPATH-$HOME/go}/src/github.com/prometheus/snmp_exporter/generator
#  go build
#  make mibs

 編譯完成後,修改當前目錄下的generator.yml 文件,generator.yml文件的配置可以參考 https://github.com/prometheus/snmp_exporter/tree/master/generator#file-format ,generator.yml文件中只需要註入snmp的community即可,下麵僅修改了modules.if_mib.auth欄位,其餘與 File Format 中一致。

#  vim generator.yml

generator.yml 中module.if_mib.auth欄位:

modules:
  # Default IF-MIB interfaces table with ifIndex.
  if_mib:
    walk: [sysUpTime, interfaces, ifXTable]
    version: 1
    auth:
      community: dfetest
    lookups:
      - source_indexes: [ifIndex]
        lookup: ifAlias
      - source_indexes: [ifIndex]
        lookup: ifDescr
      - source_indexes: [ifIndex]
        # Use OID to avoid conflict with Netscaler NS-ROOT-MIB.
        lookup: 1.3.6.1.2.1.31.1.1.1.1 # ifName
    overrides:
      ifAlias:
        ignore: true # Lookup metric
      ifDescr:
        ignore: true # Lookup metric
      ifName:
        ignore: true # Lookup metric
      ifType:
        type: EnumAsInfo

修改完成後,保存退出,執行以下操作,生成新的 snmp.yml 文件

#   export MIBDIRS=mibs
#   ./generator generate

將新生成的snmp.yml 替換掉原snmp_exporter中的snmp.yml

#   cp snmp.yml /usr/local/snmp_exporter

 2.3 驗證並設置snmp_exporter 服務開機啟動

#   cd /usr/local/snmp_exporter
#   ./snmp_exporter

開啟服務埠在9116上,瀏覽器訪問 http://192.168.56.200:9116 , 在 Target 輸入框中填入交換機IP地址,點擊 submit 按鈕,出現數據,在snmp_exporter 配置成功。

 

 2.4 設置snmp_exporter 以服務方式,開機啟動

Ctrl+C 結束掉 snmp_exporter 進程,創建 snmp_exporter 服務,讓 snmp_exporter 以服務的方式,開機自啟。

添加系統服務

#   vim /etc/systemd/system/snmp_exporter.service

將以下內容寫入文件中

[Unit]
Description=node_exporter
After=network.target 

[Service]
ExecStart=/usr/local/snmp_exporter/snmp_exporter
Restart=on-failure

[Install]
WantedBy=multi-user.target

啟動服務,設置開機自啟

#  systemctl daemon-reload
#  systemctl enable snmp_exporter 
#  systemctl start snmp_exporter

三、修改Prometheus 配置

進入Prometheus的安裝文件夾,打開Prometheus配置文件

#  cd /usr/local/prometheus
#  vim prometheus.yml

在scrape_configs標簽下,添加以下內容,配置監控。params.module中可以配置需要抓取的模塊,不配置表示全部抓取。

- job_name: 'snmp'
    scrape_interval: 10s
    static_configs:
     - targets:
       - 172.20.2.83  # 交換機IP地址
    metrics_path: /snmp
    # params:
     # module: [if_mib]
    relabel_configs:
      - source_labels: [__address__]
        target_label: __param_target
      - source_labels: [__param_target]
        target_label: instance
      - target_label: __address__
        replacement: 192.168.56.200:9116 # snmp_exporter 服務IP地址

以下是Prometheus.yml 文件全部內容

# my global config
global:
  scrape_interval:     15s # Set the scrape interval to every 15 seconds. Default is every 1 minute.
  evaluation_interval: 15s # Evaluate rules every 15 seconds. The default is every 1 minute.
  # scrape_timeout is set to the global default (10s).

# Alertmanager configuration
alerting:
  alertmanagers:
  - static_configs:
    - targets:
      # - alertmanager:9093

# Load rules once and periodically evaluate them according to the global 'evaluation_interval'.
rule_files:
  # - "first_rules.yml"
  # - "second_rules.yml"

# A scrape configuration containing exactly one endpoint to scrape:
# Here it's Prometheus itself.
scrape_configs:
  # The job name is added as a label `job=<job_name>` to any timeseries scraped from this config.
  - job_name: 'prometheus'

    # metrics_path defaults to '/metrics'
    # scheme defaults to 'http'.

    static_configs:
    - targets: ['localhost:9090']

  - job_name: 'Linux'
    static_configs:
    - targets: ['192.168.56.201:9100']
      labels:
        instance: Linux

  - job_name: 'Windows'
    static_configs:
    - targets: ['192.168.56.1:9182']
      labels:
        instance: Windows

  - job_name: 'snmp'
    scrape_interval: 10s
    static_configs:
     - targets:
       - 172.20.2.83  # 交換機IP地址
    metrics_path: /snmp
    # params:
     # module: [if_mib]
    relabel_configs:
      - source_labels: [__address__]
        target_label: __param_target
      - source_labels: [__param_target]
        target_label: instance
      - target_label: __address__
        replacement: 192.168.56.200:9116 # snmp_exporter 服務IP地址

保存退出,重啟Prometheus服務

#  systemctl restart prometheus

瀏覽器訪問 http://192.168.56.200:9090/targets  查看監控信息

可以看到,snmp已經加入進來。

 四、配置Grafana

添加dashboard

Grafana官方為我們提供了很多dashboard頁面,可直接下載使用。瀏覽器訪問 https://grafana.com/grafana/dashboards 下載所需要的dashboard頁面

此處我們使用  snmp 的監控dashboard,dashboard Id為:10523

然後打開我們的Grafana監控頁面,打開dashboard的管理頁面

 點擊【import】按鈕

然後將我們剛纔的dashboard Id (10523) 複製進去

Grafana會自動識別dashboard Id 。

然後點擊【change】按鈕,生成一個隨機的UID,然後點擊下方輸入框,選擇我們之前創建的數據源Prometheus,最後點擊【Import】按鈕,即可完成導入。

 導入成功後,會自動打開該Dashboard,即可看到我們剛纔設置好的snmp監控

至此Prometheus監控交換機,配置完成。


您的分享是我們最大的動力!

-Advertisement-
Play Games
更多相關文章
  • 分區的方式: 1)mbr分區: 1.最多支持四個分區 2.系統只能安裝在主分區 3.擴展分區要占一個主分區 4.mbr最大隻支持2TB,但擁有最好的相容性 2) gpt分區: 1.支持無限多個主分區(但操作系統可能限制,比如windows下最多128個分區) 2.最大支持18EB的大容量(1EB=1 ...
  • 管理用戶 刪除用戶 若使用 userdel myuser 命令刪除該用戶時,並不能刪除該用戶的所有信息,只是刪除了/etc/passwd、/etc/shadow、/etc/group/、/etc/gshadow四個文件里的該賬戶和組的信息。預設情況下創建一個用戶賬號,會創建一個家目錄和一個用戶郵箱( ...
  • 在這篇文章中,將會列出讓一些令 Linux 用戶印象最深刻且精美的 Linux 發行版,包括對初學者友好和流行的發行版。 1. elementary OS elementary OS 是一款基於 Ubuntu 精心打磨美化的桌面 Linux 發行版,號稱是最漂亮的 Linux 發行版。事實上,Ele ...
  • 之前搭建openvpn和easy2.0組合,第一次幫朋友搭建easy3.0組合感覺比2.0麻煩一些,參考了很多技術文章 搭建yum install -y install openvpn easy-rsa net-tools bridge-utilscd /usr/share/easy-rsa/3./ ...
  • 廢話不多說,直接進入主題。 1、安裝mailx [root@localhost ~]#yum install malix -y #yum安裝malix [root@localhost ~]# vi /etc/malix.rc #配置郵箱,配置第三方軟體發送郵件。 2、在配置文件的最後添加第三方郵件的 ...
  • 通常的Cortex-M內核MCU一般都會內嵌並行NOR Flash,這個並行NOR Flash是直接掛在Cortex-M內核高性能AHB匯流排上的,知名IDE如果支持這款MCU,也都會同時集成對應Flash的下載演算法,方便用戶直接在IDE里下載代碼進Flash和XIP調試,但是i.MXRT內部並沒有F... ...
  • 1.poweroff 功能描述:可以關閉Linux系統,關閉記錄會被寫入/var/log/wtmp日誌文件中 命令語法:poweroff [選項] 選項含義: -n:關閉之前不同步 -p:當被稱為halt時關閉電源 -v:增加輸出,包括消息 -q:降低輸出錯誤唯一的消息 -w:並不實際關閉系統,只是 ...
  • 1.電腦組成 2.開發介面標準 ABI--(Application Binary Interface) ABI描述了應用程式與OS之間的底層介面,允許編譯好的目標代碼在使用相容ABI的系統中無需改動就能運行。 API--(Application Programming Interface) API ...
一周排行
    -Advertisement-
    Play Games
  • GoF之工廠模式 @目錄GoF之工廠模式每博一文案1. 簡單說明“23種設計模式”1.2 介紹工廠模式的三種形態1.3 簡單工廠模式(靜態工廠模式)1.3.1 簡單工廠模式的優缺點:1.4 工廠方法模式1.4.1 工廠方法模式的優缺點:1.5 抽象工廠模式1.6 抽象工廠模式的優缺點:2. 總結:3 ...
  • 新改進提供的Taurus Rpc 功能,可以簡化微服務間的調用,同時可以不用再手動輸出模塊名稱,或調用路徑,包括負載均衡,這一切,由框架實現並提供了。新的Taurus Rpc 功能,將使得服務間的調用,更加輕鬆、簡約、高效。 ...
  • 本章將和大家分享ES的數據同步方案和ES集群相關知識。廢話不多說,下麵我們直接進入主題。 一、ES數據同步 1、數據同步問題 Elasticsearch中的酒店數據來自於mysql資料庫,因此mysql數據發生改變時,Elasticsearch也必須跟著改變,這個就是Elasticsearch與my ...
  • 引言 在我們之前的文章中介紹過使用Bogus生成模擬測試數據,今天來講解一下功能更加強大自動生成測試數據的工具的庫"AutoFixture"。 什麼是AutoFixture? AutoFixture 是一個針對 .NET 的開源庫,旨在最大程度地減少單元測試中的“安排(Arrange)”階段,以提高 ...
  • 經過前面幾個部分學習,相信學過的同學已經能夠掌握 .NET Emit 這種中間語言,並能使得它來編寫一些應用,以提高程式的性能。隨著 IL 指令篇的結束,本系列也已經接近尾聲,在這接近結束的最後,會提供幾個可供直接使用的示例,以供大伙分析或使用在項目中。 ...
  • 當從不同來源導入Excel數據時,可能存在重覆的記錄。為了確保數據的準確性,通常需要刪除這些重覆的行。手動查找並刪除可能會非常耗費時間,而通過編程腳本則可以實現在短時間內處理大量數據。本文將提供一個使用C# 快速查找並刪除Excel重覆項的免費解決方案。 以下是實現步驟: 1. 首先安裝免費.NET ...
  • C++ 異常處理 C++ 異常處理機制允許程式在運行時處理錯誤或意外情況。它提供了捕獲和處理錯誤的一種結構化方式,使程式更加健壯和可靠。 異常處理的基本概念: 異常: 程式在運行時發生的錯誤或意外情況。 拋出異常: 使用 throw 關鍵字將異常傳遞給調用堆棧。 捕獲異常: 使用 try-catch ...
  • 優秀且經驗豐富的Java開發人員的特征之一是對API的廣泛瞭解,包括JDK和第三方庫。 我花了很多時間來學習API,尤其是在閱讀了Effective Java 3rd Edition之後 ,Joshua Bloch建議在Java 3rd Edition中使用現有的API進行開發,而不是為常見的東西編 ...
  • 框架 · 使用laravel框架,原因:tp的框架路由和orm沒有laravel好用 · 使用強制路由,方便介面多時,分多版本,分文件夾等操作 介面 · 介面開發註意欄位類型,欄位是int,查詢成功失敗都要返回int(對接java等強類型語言方便) · 查詢介面用GET、其他用POST 代碼 · 所 ...
  • 正文 下午找企業的人去鎮上做貸後。 車上聽同事跟那個司機對罵,火星子都快出來了。司機跟那同事更熟一些,連我在內一共就三個人,同事那一手指桑罵槐給我都聽愣了。司機也是老社會人了,馬上聽出來了,為那個無辜的企業經辦人辯護,實際上是為自己辯護。 “這個事情你不能怪企業。”“但他們總不能讓銀行的人全權負責, ...