使用python測試prometheus的實現(xiàn)
為了更直觀的了解prometheus如何工作,本文使用prometheus的python庫來做一些相應(yīng)的測試。
python庫的github地址是https://github.com/prometheus
根據(jù)提示,使用pip安裝prometheus_client
pip3 install prometheus_client
然后根據(jù)文檔中的示例文件并簡單修改,運行一個client
文件命名為prometheus_python_client.py
from prometheus_client import start_http_server, Summary
import random
import time
import sys
# Create a metric to track time spent and requests made.
REQUEST_TIME = Summary ('request_processing_seconds', 'Time spent processing request')
# Decorate function with metric.
@REQUEST_TIME.time ( )
def process_request(t):
? ? """A dummy function that takes some time."""
? ? time.sleep (t)
if __name__ == '__main__':
? ? try:
? ? ? ? if sys.argv[1].isdigit():
? ? ? ? ? ? port = sys.argv[1]
? ? ? ? else:
? ? ? ? ? ? port = 8080
? ? except:
? ? ? ? port = 8080
? ? # Start up the server to expose the metrics.
? ? start_http_server (8080)
? ? # Generate some requests.
? ? while True:
? ? ? ? process_request (random.random ( ))在后臺運行client
pytho3 prometheus_python_client.py 8080 &
此時可以訪問本機的8080端口,可以看到相應(yīng)的metric
curl 127.0.0.1:8080/metrics
得到如圖所示結(jié)果

為了能監(jiān)控到這個端口為8080的目標(biāo),需要在prometheus的配置文件prometheus.yml進(jìn)行一些修改
在scrape_configs塊部分加上一個新的job
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: 'python-client' ? ? scrape_interval: 5s ? ? static_configs: ? ? ? - targets: ['localhost:8080'] ? ? ? ? labels: ? ? ? ? ? group: 'python-client-group'
重啟prometheus,并訪問其web頁面,在Expression中輸入一個python client的metric并執(zhí)行
可以看到對應(yīng)的結(jié)果正如在scrape_configs中所配置的相一致。

到此這篇關(guān)于使用python測試prometheus的實現(xiàn)的文章就介紹到這了,更多相關(guān)python測試prometheus內(nèi)容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!
相關(guān)文章
Python cookbook(數(shù)據(jù)結(jié)構(gòu)與算法)通過公共鍵對字典列表排序算法示例
這篇文章主要介紹了Python cookbook(數(shù)據(jù)結(jié)構(gòu)與算法)通過公共鍵對字典列表排序算法,結(jié)合實例形式分析了Python基于operator模塊中的itemgetter()函數(shù)對字典進(jìn)行排序的相關(guān)操作技巧,需要的朋友可以參考下2018-03-03
Python的json模塊中json.load()和json.loads()的區(qū)別
這篇文章主要介紹了Python的json模塊中json.load()和json.loads()的區(qū)別,json.load用于從一個文件對象中讀取JSON數(shù)據(jù)并將其解析為Python對象,而json.loads用于解析一個JSON格式的字符串并將其轉(zhuǎn)換為Python對象,根據(jù)你的具體需求選擇使用哪個方法,需要的朋友可以參考下2024-12-12

