Maison Opération et maintenance Nginx Comment utiliser Nginx pour la journalisation et l'analyse des requêtes HTTP

Comment utiliser Nginx pour la journalisation et l'analyse des requêtes HTTP

Aug 02, 2023 am 08:32 AM
nginx http请求 分析 日志记录

如何使用Nginx进行HTTP请求的日志记录和分析

引言:
在日常的Web开发中,我们经常需要对HTTP请求进行日志记录和分析,以便监测网站的访问情况、排查问题以及优化性能。Nginx作为一款功能强大的HTTP服务器和反向代理服务器,提供了丰富的日志记录功能,并且相对于其他服务器,它的性能更加出色。本文将介绍如何配置和使用Nginx来进行HTTP请求的日志记录和分析。

一、配置Nginx日志记录格式

为了记录更详细的信息,我们可以自定义Nginx的日志记录格式。在Nginx的配置文件中,找到"http"上下文,并在其中添加以下内容:

http {
    log_format my_log_format '$remote_addr - $remote_user [$time_local] "$request" '
                             '$status $body_bytes_sent "$http_referer" "$http_user_agent" '
                             '"$gzip_ratio"';

    access_log /var/log/nginx/access.log my_log_format;
}
Copier après la connexion

这里我们定义了一个名为"my_log_format"的日志记录格式,包括了远程地址、远程用户、访问时间、请求内容、状态码、发送的字节数、来源URL、User-Agent、Gzip比率等信息。然后将该格式应用到Nginx的访问日志文件中。

二、配置Nginx进行日志分割

随着网站访问量的增加,日志文件往往会变得非常庞大。为了方便管理和分析日志,我们可以配置Nginx进行日志分割。在Nginx的配置文件中添加以下内容:

http {
    access_log /var/log/nginx/access.log my_log_format;
    error_log /var/log/nginx/error.log;

    logrotate daily;
    rotate 7;
    size 10M;
    missingok;
    notifempty;
    compress;
    delaycompress;
}
Copier après la connexion

这里我们配置Nginx每天进行日志分割,保留最近7天的日志文件。每个文件最大为10MB,达到上限后将进行压缩并新生成一个日志文件。另外,如果文件不存在也会继续进行日志记录,并且空文件不会触发日志分割。

三、使用ELK Stack进行日志分析

ELK Stack是一套开源的日志分析解决方案,由Elasticsearch、Logstash和Kibana三个工具组成。我们可以使用ELK Stack来对Nginx的日志进行分析和可视化。下面是配置步骤:

1.安装Elasticsearch

首先,需要安装和配置Elasticsearch作为日志存储和索引的数据库。具体安装步骤请参考Elasticsearch官方文档:https://www.elastic.co/guide/en/elasticsearch/reference/current/index.html

2.安装Logstash

其次,安装并配置Logstash作为数据收集和加工的工具。具体安装步骤请参考Logstash官方文档:https://www.elastic.co/guide/en/logstash/current/index.html

3.编写Logstash配置文件

创建一个新的配置文件(例如nginx.conf),并添加以下内容:

input {
    file {
        path => "/var/log/nginx/access.log"
        start_position => "beginning"
    }
}

filter {
    grok {
        match => { "message" => "%{IPORHOST:clientip} %{HTTPDUSER:ident} %{USER:auth} [%{HTTPDATE:timestamp}] "%{WORD:verb} %{URIPATHPARAM:request} HTTP/%{NUMBER:httpversion}" %{NUMBER:response} %{NUMBER:bytes} "%{URI:referrer}" "%{DATA:useragent}" "%{DATA:gzipratio}"" }
    }
}

output {
    elasticsearch {
        hosts => "localhost"
        index => "nginx-logs-%{+YYYY.MM.dd}"
    }
}
Copier après la connexion

这里我们指定了日志文件的路径、日志格式和Elasticsearch的地址,并将日志存储到以日期为后缀的索引中。

4.启动Logstash

启动Logstash并加载配置文件:

$ bin/logstash -f nginx.conf
Copier après la connexion

5.安装Kibana

最后,安装和配置Kibana作为日志可视化的工具。具体安装步骤请参考Kibana官方文档:https://www.elastic.co/guide/en/kibana/current/index.html

配置完成后,打开Kibana的web界面,通过搜索和过滤功能,可以实时查看和分析Nginx的访问日志。

结论:
通过配置Nginx进行HTTP请求的日志记录和分析,我们可以监控网站的访问情况、排查问题以及优化性能。同时,结合ELK Stack可以实现日志的集中存储、分析和可视化,提高运维效率和网站性能分析的准确性。希望本文对大家能有所帮助。

Ce qui précède est le contenu détaillé de. pour plus d'informations, suivez d'autres articles connexes sur le site Web de PHP en chinois!

Déclaration de ce site Web
Le contenu de cet article est volontairement contribué par les internautes et les droits d'auteur appartiennent à l'auteur original. Ce site n'assume aucune responsabilité légale correspondante. Si vous trouvez un contenu suspecté de plagiat ou de contrefaçon, veuillez contacter admin@php.cn

Outils d'IA chauds

Undresser.AI Undress

Undresser.AI Undress

Application basée sur l'IA pour créer des photos de nu réalistes

AI Clothes Remover

AI Clothes Remover

Outil d'IA en ligne pour supprimer les vêtements des photos.

Undress AI Tool

Undress AI Tool

Images de déshabillage gratuites

Clothoff.io

Clothoff.io

Dissolvant de vêtements AI

AI Hentai Generator

AI Hentai Generator

Générez AI Hentai gratuitement.

Article chaud

R.E.P.O. Crystals d'énergie expliqués et ce qu'ils font (cristal jaune)
4 Il y a quelques semaines By 尊渡假赌尊渡假赌尊渡假赌
R.E.P.O. Meilleurs paramètres graphiques
4 Il y a quelques semaines By 尊渡假赌尊渡假赌尊渡假赌
R.E.P.O. Comment réparer l'audio si vous n'entendez personne
4 Il y a quelques semaines By 尊渡假赌尊渡假赌尊渡假赌
WWE 2K25: Comment déverrouiller tout dans Myrise
1 Il y a quelques mois By 尊渡假赌尊渡假赌尊渡假赌

Outils chauds

Bloc-notes++7.3.1

Bloc-notes++7.3.1

Éditeur de code facile à utiliser et gratuit

SublimeText3 version chinoise

SublimeText3 version chinoise

Version chinoise, très simple à utiliser

Envoyer Studio 13.0.1

Envoyer Studio 13.0.1

Puissant environnement de développement intégré PHP

Dreamweaver CS6

Dreamweaver CS6

Outils de développement Web visuel

SublimeText3 version Mac

SublimeText3 version Mac

Logiciel d'édition de code au niveau de Dieu (SublimeText3)

Comment résoudre nginx403 Comment résoudre nginx403 Apr 14, 2025 am 10:33 AM

Comment corriger l'erreur interdite Nginx 403? Vérifier les autorisations de fichier ou de répertoire; 2. Vérifier le fichier .htaccess; 3. Vérifiez le fichier de configuration NGINX; 4. Redémarrer Nginx. D'autres causes possibles incluent les règles de pare-feu, les paramètres de Selinux ou les problèmes d'application.

Comment démarrer Nginx dans Linux Comment démarrer Nginx dans Linux Apr 14, 2025 pm 12:51 PM

Étapes pour démarrer Nginx dans Linux: Vérifiez si Nginx est installé. Utilisez SystemCTL Start Nginx pour démarrer le service NGINX. Utilisez SystemCTL Activer Nginx pour activer le démarrage automatique de Nginx au démarrage du système. Utilisez SystemCTL Status Nginx pour vérifier que le démarrage est réussi. Visitez http: // localhost dans un navigateur Web pour afficher la page de bienvenue par défaut.

Comment résoudre l'erreur Nginx403 Comment résoudre l'erreur Nginx403 Apr 14, 2025 pm 12:54 PM

Le serveur n'a pas l'autorisation d'accéder à la ressource demandée, ce qui donne une erreur NGINX 403. Les solutions incluent: vérifier les autorisations de fichiers. Vérifiez la configuration .htaccess. Vérifiez la configuration de Nginx. Configurez les autorisations Selinux. Vérifiez les règles du pare-feu. Dépanner d'autres causes telles que les problèmes de navigateur, les défaillances du serveur ou d'autres erreurs possibles.

Comment résoudre le problème du domaine croisé nginx Comment résoudre le problème du domaine croisé nginx Apr 14, 2025 am 10:15 AM

Il existe deux façons de résoudre le problème du domaine transversal NGINX: modifiez les en-têtes de réponse transversale: ajoutez des directives pour autoriser les demandes de domaine croisé, spécifier des méthodes et des en-têtes autorisés et définir le temps du cache. Utilisez le module CORS: Activez les modules et configurez les règles CORS pour permettre des demandes, des méthodes, des en-têtes et du temps de cache.

Comment résoudre l'erreur Nginx304 Comment résoudre l'erreur Nginx304 Apr 14, 2025 pm 12:45 PM

Réponse à la question: 304 Erreur non modifiée indique que le navigateur a mis en cache la dernière version de ressource de la demande du client. Solution: 1. Effacer le cache du navigateur; 2. Désactiver le cache du navigateur; 3. Configurer Nginx pour permettre le cache client; 4. Vérifier les autorisations du fichier; 5. Vérifier le hachage du fichier; 6. Désactiver le CDN ou le cache proxy inversé; 7. Redémarrez Nginx.

Comment vérifier l'état de course de Nginx Comment vérifier l'état de course de Nginx Apr 14, 2025 am 11:48 AM

Les méthodes pour afficher l'état en cours d'exécution de Nginx sont: utilisez la commande PS pour afficher l'état du processus; Afficher le fichier de configuration Nginx /etc/nginx/nginx.conf; Utilisez le module d'état NGINX pour activer le point de terminaison d'état; Utilisez des outils de surveillance tels que Prometheus, Zabbix ou Nagios.

Comment configurer Nginx dans Windows Comment configurer Nginx dans Windows Apr 14, 2025 pm 12:57 PM

Comment configurer Nginx dans Windows? Installez Nginx et créez une configuration d'hôte virtuelle. Modifiez le fichier de configuration principale et incluez la configuration de l'hôte virtuel. Démarrer ou recharger nginx. Testez la configuration et affichez le site Web. Activer sélectivement SSL et configurer les certificats SSL. Définissez sélectivement le pare-feu pour permettre le trafic Port 80 et 443.

Comment vérifier si Nginx est démarré Comment vérifier si Nginx est démarré Apr 14, 2025 pm 01:03 PM

Comment confirmer si Nginx est démarré: 1. Utilisez la ligne de commande: SystemCTl Status Nginx (Linux / Unix), netStat -ano | Findstr 80 (Windows); 2. Vérifiez si le port 80 est ouvert; 3. Vérifiez le message de démarrage NGINX dans le journal système; 4. Utilisez des outils tiers, tels que Nagios, Zabbix et Icinga.

See all articles