So verwenden Sie Elasticsearch zur Leistungsüberwachung von PHP-Anwendungen
Einführung:
Wenn wir PHP-Anwendungen entwickeln und warten, müssen wir häufig deren Leistung überwachen und Probleme schnell erkennen und lösen. Elasticsearch ist eine leistungsstarke Open-Source-Suchmaschine, die nicht nur zum Durchsuchen von Daten, sondern auch zur Protokollanalyse und -überwachung verwendet werden kann. In diesem Artikel erfahren Sie, wie Sie Elasticsearch zur Leistungsüberwachung von PHP-Anwendungen nutzen und demonstrieren dies anhand von Codebeispielen.
use ElasticsearchClientBuilder; // 创建Elasticsearch客户端 $client = ClientBuilder::create()->build(); // 创建索引 $client->indices()->create([ 'index' => 'php_performance_monitoring', ]); // 定义映射 $client->indices()->putMapping([ 'index' => 'php_performance_monitoring', 'body' => [ 'properties' => [ 'timestamp' => ['type' => 'date'], 'duration' => ['type' => 'float'], 'endpoint' => ['type' => 'keyword'], 'response_code' => ['type' => 'integer'], ], ], ]);
Im obigen Beispielcode haben wir einen Index mit dem Namen „php_performance_monitoring“ erstellt und eine Zuordnung definiert, die die Felder für die Leistungsüberwachungsdaten enthält, die wir aufzeichnen müssen.
use MonologLogger; use MonologHandlerElasticsearchHandler; // 创建Monolog日志实例 $logger = new Logger('performance'); // 创建Elasticsearch处理程序 $handler = new ElasticsearchHandler($client, [ 'index' => 'php_performance_monitoring', 'type' => 'log', ]); // 添加处理程序到日志实例 $logger->pushHandler($handler); // 记录性能监控数据 $logger->info('Performance monitoring', [ 'timestamp' => time(), 'duration' => 0.753, 'endpoint' => '/api/v1/users', 'response_code' => 200, ]);
Im obigen Beispiel haben wir die Monolog-Bibliothek zur Verwaltung der Protokolle verwendet. Wir haben einen Elasticsearch-Handler erstellt und ihn der Protokollierungsinstanz hinzugefügt. Anschließend können wir die info
-Methode verwenden, um unsere Leistungsüberwachungsdaten zu protokollieren, einschließlich Zeitstempel, Anforderungsdauer, Endpunkte und Antwortcodes.
// 构建查询 $query = [ 'index' => 'php_performance_monitoring', 'size' => 10, 'body' => [ 'query' => [ 'match' => [ 'endpoint' => '/api/v1/users', ], ], 'sort' => [ 'timestamp' => [ 'order' => 'desc', ], ], ], ]; // 执行查询 $response = $client->search($query); // 处理查询结果 foreach ($response['hits']['hits'] as $hit) { $timestamp = $hit['_source']['timestamp']; $duration = $hit['_source']['duration']; $responseCode = $hit['_source']['response_code']; // 处理结果数据 echo "Timestamp: " . date('Y-m-d H:i:s', $timestamp) . PHP_EOL; echo "Duration: " . $duration . "s" . PHP_EOL; echo "Response Code: " . $responseCode . PHP_EOL; echo PHP_EOL; }
Der obige Beispielcode zeigt, wie eine Abfrage erstellt wird, um Leistungsdaten für einen bestimmten Endpunkt abzurufen und die Abfrageergebnisse zu verarbeiten.
Zusammenfassung:
Durch die Verwendung von Elasticsearch zur Leistungsüberwachung von PHP-Anwendungen können wir Leistungsdaten schnell aufzeichnen und analysieren, um potenzielle Leistungsprobleme zu erkennen und zu lösen. In diesem Artikel haben wir gelernt, wie man Elasticsearch installiert, konfiguriert und verwendet, um Leistungsdaten aufzuzeichnen, und haben anhand von Codebeispielen gezeigt, wie man diese Daten abfragt und analysiert. Ich hoffe, dieser Artikel ist hilfreich für die Leistungsüberwachung Ihrer PHP-Anwendungen.
Das obige ist der detaillierte Inhalt vonSo verwenden Sie Elasticsearch zur Leistungsüberwachung von PHP-Anwendungen. Für weitere Informationen folgen Sie bitte anderen verwandten Artikeln auf der PHP chinesischen Website!