Heim > Backend-Entwicklung > PHP-Tutorial > So verwenden Sie Elasticsearch zur Leistungsüberwachung von PHP-Anwendungen

So verwenden Sie Elasticsearch zur Leistungsüberwachung von PHP-Anwendungen

PHPz
Freigeben: 2023-07-09 20:40:01
Original
749 Leute haben es durchsucht

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.

  1. Elasticsearch und PHP-Client installieren.
    Bevor wir Elasticsearch verwenden können, müssen wir zunächst Elasticsearch und den PHP-Client installieren. Sie können Elasticsearch von der offiziellen Elasticsearch-Website herunterladen und installieren und Composer verwenden, um den Elasticsearch-PHP-Client zu installieren.
  2. Erstellen Sie Indizes und Zuordnungen.
    Bevor wir mit der Überwachung beginnen, müssen wir einen Index erstellen und eine Zuordnung definieren, um unsere Leistungsüberwachungsdaten zu speichern. Hier ist ein einfaches Beispiel:
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'],
        ],
    ],
]);
Nach dem Login kopieren

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.

  1. Erfassen Sie Leistungsüberwachungsdaten.
    An wichtigen Stellen in der Anwendung können wir den Elasticsearch PHP-Client verwenden, um Leistungsüberwachungsdaten aufzuzeichnen. Hier ist ein Beispiel:
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,
]);
Nach dem Login kopieren

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.

  1. Leistungsdaten abfragen und analysieren.
    Sobald wir mit der Aufzeichnung von Leistungsdaten beginnen, können wir die leistungsstarken Abfrage- und Analysefunktionen von Elasticsearch nutzen, um diese Daten abzurufen und zu analysieren. Hier ist ein Beispiel:
// 构建查询
$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;
}
Nach dem Login kopieren

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!

Verwandte Etiketten:
Quelle:php.cn
Erklärung dieser Website
Der Inhalt dieses Artikels wird freiwillig von Internetnutzern beigesteuert und das Urheberrecht liegt beim ursprünglichen Autor. Diese Website übernimmt keine entsprechende rechtliche Verantwortung. Wenn Sie Inhalte finden, bei denen der Verdacht eines Plagiats oder einer Rechtsverletzung besteht, wenden Sie sich bitte an admin@php.cn
Beliebte Tutorials
Mehr>
Neueste Downloads
Mehr>
Web-Effekte
Quellcode der Website
Website-Materialien
Frontend-Vorlage