要在 PHP 中配置 Prometheus 告警,您需要遵循以下步驟:
安裝 Prometheus:首先,您需要在服務器上安裝 Prometheus。請參閱 Prometheus 官方文檔中的安裝指南。
安裝 PHP 的 Prometheus 客戶端庫:為了從 PHP 應用程序收集指標并將其暴露給 Prometheus,您需要使用一個 PHP Prometheus 客戶端庫。一個流行的選擇是 promphp/prometheus_client_php。要安裝此庫,請運行以下命令:
composer require promphp/prometheus_client_php
在 PHP 應用程序中集成 Prometheus 客戶端庫:在您的 PHP 代碼中,使用 Prometheus 客戶端庫收集和暴露指標。例如,您可以創建一個簡單的計數器來跟蹤請求次數:
use Prometheus\CollectorRegistry;
use Prometheus\RenderTextFormat;
use Prometheus\Storage\InMemory;
use Prometheus\Storage\Redis;
use Laminas\HttpHandlerRunner\Emitter\SapiEmitter;
use Psr\Http\Message\ServerRequestInterface;
$storage = new InMemory(); // 或者使用 Redis 存儲,如果您的應用程序是分布式的
$registry = new CollectorRegistry($storage);
$counter = $registry->registerCounter('my_app', 'requests_total', 'Total number of requests');
$counter->inc();
// ... 處理請求 ...
$renderer = new RenderTextFormat();
$result = $renderer->render($registry->getMetricFamilySamples());
header('Content-Type: text/plain');
echo $result;
配置 Prometheus:創建一個名為 prometheus.yml
的配置文件,其中包含有關如何抓取您的 PHP 應用程序指標的信息。例如:
global:
scrape_interval: 15s
scrape_configs:
- job_name: 'my_php_app'
static_configs:
- targets: ['localhost:9091'] # 將此更改為您的 PHP 應用程序的實際地址和端口
確保將 targets
更改為您的 PHP 應用程序的實際地址和端口。
啟動 Prometheus:使用以下命令啟動 Prometheus,并指向您的配置文件:
prometheus --config.file=prometheus.yml
配置告警規則:在 Prometheus 中,您可以定義告警規則以在特定條件下觸發通知。要配置告警規則,請在 Prometheus 配置文件(prometheus.yml
)中添加一個 rule_files
部分,并創建一個包含告警規則的新文件。例如,在 prometheus.yml
中添加以下內容:
rule_files:
- 'alerts.yml'
然后,創建一個名為 alerts.yml
的文件,其中包含您的告警規則。例如:
groups:
- name: php_app_alerts
rules:
- alert: HighRequestRate
expr: rate(my_app_requests_total[5m]) > 100
for: 1m
labels:
severity: critical
annotations:
summary: "High request rate in PHP app"
description: "The PHP app has received more than 100 requests per minute for the last 1 minute."
這將創建一個名為 “HighRequestRate” 的告警,當 PHP 應用程序在過去 5 分鐘內每分鐘收到超過 100 個請求時觸發。
配置 Alertmanager:要接收告警通知,您需要設置一個 Alertmanager 實例。首先,請參閱 Alertmanager 官方文檔中的安裝指南。然后,創建一個名為 alertmanager.yml
的配置文件,其中包含有關如何發送通知的信息。例如:
global:
resolve_timeout: 5m
route:
group_by: ['alertname']
group_wait: 10s
group_interval: 5m
repeat_interval: 3h
receiver: 'email-notifier'
receivers:
- name: 'email-notifier'
email_configs:
- to: 'your-email@example.com'
from: 'alerts@example.com'
smarthost: 'smtp.example.com:587'
auth_username: 'your-smtp-username'
auth_password: 'your-smtp-password'
send_resolved: true
根據您的電子郵件提供商和 SMTP 服務器設置更改相應的值。
啟動 Alertmanager:使用以下命令啟動 Alertmanager,并指向您的配置文件:
alertmanager --config.file=alertmanager.yml
現在,當滿足告警規則的條件時,您將收到有關 PHP 應用程序的電子郵件通知。請注意,這只是一個簡單的示例,您可能需要根據您的需求調整配置。