Maison > Opération et maintenance > Nginx > Servir du contenu statique à l'aide de nginx

Servir du contenu statique à l'aide de nginx

(*-*)浩
Libérer: 2019-11-30 14:37:38
original
3454 Les gens l'ont consulté

Servir du contenu statique à l'aide de nginx

Une tâche importante du serveur Web consiste à servir des fichiers (tels que des images ou des pages HTML statiques).

Sur demande, les fichiers seront servis à partir de différents répertoires locaux : /data/www (qui peut contenir des fichiers HTML) et /data/images (qui peuvent contenir des images). Cela nécessitera de modifier le fichier de configuration et de configurer le bloc serveur à l'intérieur du bloc http à l'aide de deux blocs d'emplacement. (Apprentissage recommandé : utilisation de nginx)

Tout d'abord, créez le répertoire /data/www et placez-y un fichier index.html contenant n'importe quel contenu texte, puis créez /data/ répertoire images et mettez-y quelques images. Créer deux répertoires -

[root@localhost ~]# mkdir -p /data/www
[root@localhost ~]# mkdir -p /data/images
[root@localhost ~]#
Copier après la connexion

Mettre deux fichiers dans les deux répertoires créés ci-dessus : /data/www/index.html et /data/images/logo.png, /data Le contenu du /www /index.html ne contient qu'une seule ligne, comme suit -

<h2> New Static WebSite Demo.</h2>
Copier après la connexion

Ensuite, ouvrez le fichier de configuration (/usr/local/nginx/conf/nginx.conf). Le fichier de configuration par défaut contient déjà plusieurs exemples de blocs serveur, dont la plupart sont commentés. Maintenant, commentez tous ces blocs et démarrez un nouveau bloc de serveur :

http {
    server {
    }
}
Copier après la connexion

Généralement, un fichier de configuration peut inclure plusieurs blocs de serveur distingués par le port sur lequel le serveur écoute et le nom du serveur. Une fois que nginx a déterminé quel serveur gérer la requête, il teste l'URI spécifié dans l'en-tête de la requête par rapport aux paramètres de la directive de localisation définie dans le bloc service .

Ajoutez le bloc d'emplacement suivant au bloc serveur :

http {
    server {
        location / {
            root /data/www;
        }
    }
}
Copier après la connexion

Le bloc d'emplacement spécifie le préfixe "/" qui est comparé à l'URI dans la requête . Pour les demandes correspondantes, l'URI sera ajouté au chemin spécifié dans la directive racine (c'est-à-dire /data/www) pour former le chemin d'accès au fichier demandé sur le système de fichiers local. S'il existe plusieurs blocs d'emplacement correspondants, nginx choisira celui avec le préfixe le plus long pour correspondre au bloc d'emplacement. Le bloc d'emplacement ci-dessus fournit la longueur de préfixe la plus courte de 1, ce bloc ne sera donc utilisé que si tous les autres blocs d'emplacement ne peuvent pas fournir de correspondance.

Ensuite, ajoutez un deuxième bloc d'emplacement :

http {
    server {
        location / {
            root /data/www;
        }
        location /images/ {
            root /data;
        }
    }
}
Copier après la connexion

Ce sera /images/(location/ correspond également à des requêtes comme celle-ci, mais avec un préfixe plus court, c'est-à-dire , "/images/" est plus long que "/") pour correspondre à la requête.

La configuration finale du bloc serveur devrait ressembler à ceci :

server {
    location / {
        root /data/www;
    }
    location /images/ {
        root /data;
    }
}
Copier après la connexion

Il s'agit déjà d'un serveur en écoute sur le port standard 80 et accessible sur la machine locale ( http://localhost/ ) configuration de travail. En réponse à une demande d'URI commençant par /images/, le serveur enverra les fichiers du répertoire /data/images. Par exemple, en réponse à une requête http://localhost/images/logo.png, nginx enverra le fichier /data/images/logo.png sur le service. Si le fichier n'existe pas, nginx enverra une réponse indiquant une erreur 404. Les demandes d'URI ne commençant pas par /images/ seront mappées vers le répertoire /data/www. Par exemple, en réponse à une demande http://localhost/about/example.html, nginx enverra le fichier /data/www/about/example.html.

Pour appliquer la nouvelle configuration, démarrez nginx si cela n'a pas déjà été fait ou envoyez un signal de rechargement au processus principal de nginx en exécutant la commande suivante :

[root@localhost ~]# /usr/local/nginx/sbin/nginx -t
nginx: the configuration file /usr/local/nginx/conf/nginx.conf syntax is ok
nginx: configuration file /usr/local/nginx/conf/nginx.conf test is successful
[root@localhost ~]# /usr/local/nginx/sbin/nginx -s reload
Copier après la connexion

If une erreur ou une exception empêche cela. Si cela fonctionne normalement, vous pouvez essayer de vérifier les fichiers access.log et error.log dans le répertoire /usr/local/nginx/logs ou /var/log/nginx pour trouver la raison.

Ouvrez un navigateur ou utilisez CURL pour accéder au serveur Nginx comme indiqué ci-dessous -

Servir du contenu statique à laide de nginx

Le contenu complet de la configuration du fichier nginx.conf est le suivant :

#user  nobody;
worker_processes  1;
#error_log  logs/error.log;
#error_log  logs/error.log  notice;
#error_log  logs/error.log  info;
#pid        logs/nginx.pid;
events {
    worker_connections  1024;
}
http {
    include       mime.types;
    default_type  application/octet-stream;
    #log_format  main  &#39;$remote_addr - $remote_user [$time_local] "$request" &#39;
    # &#39;$status $body_bytes_sent "$http_referer" &#39;
    # &#39;"$http_user_agent" "$http_x_forwarded_for"&#39;;
    #access_log  logs/access.log  main;
    sendfile        on;
    #tcp_nopush     on;
    #keepalive_timeout  0;
    keepalive_timeout  65;
    #gzip  on;
    ## 新服务(静态网站)
    server {
        location / {
            root /data/www;
        }
        location /images/ {
            root /data;
        }
    }
}
Copier après la connexion

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!

Étiquettes associées:
source:php.cn
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
Tutoriels populaires
Plus>
Derniers téléchargements
Plus>
effets Web
Code source du site Web
Matériel du site Web
Modèle frontal