Analyse d'un exemple de fichier de configuration Nginx
Fonctions communes de Nginx
1. proxy http, proxy inverse : comme l'une des fonctions les plus couramment utilisées des serveurs Web, en particulier le proxy inverse.
Ici, je vais vous donner deux photos pour expliquer l'agent positif et l'agent réactif. Vous pouvez lire les informations pour les détails spécifiques.
nginx offre des performances stables lorsqu'il est utilisé comme proxy inverse et peut fournir des fonctions de transfert avec une configuration flexible. nginx peut adopter différentes stratégies de transfert basées sur différentes correspondances régulières, comme accéder au serveur de fichiers à la fin du fichier image et accéder au serveur Web pour les pages dynamiques, à condition que vous n'ayez aucun problème à écrire des règles régulières et que vous ayez des règles correspondantes. solutions de serveur, vous pouvez faire ce que vous voulez. Et nginx effectue un saut de page d'erreur, un jugement d'exception, etc. sur les résultats renvoyés. Si le serveur distribué est anormal, il peut retransmettre la requête vers un autre serveur puis supprimer automatiquement le serveur anormal.
2. Load Balancing
nginx propose deux types de stratégies d'équilibrage de charge : les stratégies intégrées et les stratégies étendues. Les stratégies intégrées sont l'interrogation, l'interrogation pondérée et le hachage IP. La stratégie d'expansion est aussi imaginative qu'inimaginable. Il n'y a rien auquel vous ne puissiez penser qu'elle ne puisse faire. Vous pouvez vous référer à tous les algorithmes d'équilibrage de charge pour les trouver un par un et les implémenter.
Les trois images ci-dessus, comprennent la mise en œuvre de ces trois algorithmes d'équilibrage de charge
algorithme de hachage IP, effectue une opération de hachage sur l'IP demandée par le client, puis distribue la demande pour la même IP client au même client basé sur le résultat du hachage. Le traitement sur un serveur peut résoudre le problème de la session non partagée.
3. Mise en cache Web
nginx peut effectuer différents traitements de cache sur différents fichiers, avec une configuration flexible, et prend en charge fastcgi_cache, qui est principalement utilisé pour mettre en cache les programmes dynamiques fastcgi. En coopération avec le tiers ngx_cache_purge, le contenu du cache d'URL spécifié peut être ajouté et supprimé pour être géré.
4. Adresse associée à nginx
Code source :
Site officiel :
Structure du fichier de configuration nginx
Si vous avez téléchargé votre fichier d'installation, vous souhaiterez peut-être ouvrir le fichier nginx.conf dans le dossier conf, La configuration de base du serveur nginx et la configuration par défaut sont également stockées ici.
Dans le bit de symbole de commentaire de nginx.conf #
La structure du fichier nginx, les étudiants qui débutent peuvent y jeter un deuxième regard.
Configuration par défaut
#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 '$remote_addr - $remote_user [$time_local] "$request" ' # '$status $body_bytes_sent "$http_referer" ' # '"$http_user_agent" "$http_x_forwarded_for"'; #access_log logs/access.log main; sendfile on; #tcp_nopush on; #keepalive_timeout 0; keepalive_timeout 65; #gzip on; server { listen 80; server_name localhost; #charset koi8-r; #access_log logs/host.access.log main; location / { root html; index index.html index.htm; } #error_page 404 /404.html; # redirect server error pages to the static page /50x.html # error_page 500 502 503 504 /50x.html; location = /50x.html { root html; } # proxy the php scripts to apache listening on 127.0.0.1:80 # #location ~ \.php$ { # proxy_pass http://127.0.0.1; #} # pass the php scripts to fastcgi server listening on 127.0.0.1:9000 # #location ~ \.php$ { # root html; # fastcgi_pass 127.0.0.1:9000; # fastcgi_index index.php; # fastcgi_param script_filename /scripts$fastcgi_script_name; # include fastcgi_params; #} # deny access to .htaccess files, if apache's document root # concurs with nginx's one # #location ~ /\.ht { # deny all; #} } # another virtual host using mix of ip-, name-, and port-based configuration # #server { # listen 8000; # listen somename:8080; # server_name somename alias another.alias; # location / { # root html; # index index.html index.htm; # } #} # https server # #server { # listen 443 ssl; # server_name localhost; # ssl_certificate cert.pem; # ssl_certificate_key cert.key; # ssl_session_cache shared:ssl:1m; # ssl_session_timeout 5m; # ssl_ciphers high:!anull:!md5; # ssl_prefer_server_ciphers on; # location / { # root html; # index index.html index.htm; # } #} }
structure de fichier nginx
... #全局块 events { #events块 ... } http #http块 { ... #http全局块 server #server块 { ... #server全局块 location [pattern] #location块 { ... } location [pattern] { ... } } server { ... } ... #http全局块 }
1 Bloc global : configurez les instructions qui affectent nginx globalement. Généralement, il existe un groupe d'utilisateurs pour exécuter le serveur nginx, le chemin de stockage du pid du processus nginx, le chemin de stockage des journaux, l'introduction du fichier de configuration, le nombre de processus de travail autorisés à être générés, etc.
2. Bloc Événements : La configuration affecte le serveur nginx ou la connexion réseau avec l'utilisateur. Il existe un nombre maximum de connexions par processus, quel modèle basé sur les événements choisir pour gérer les demandes de connexion, s'il faut autoriser l'acceptation simultanée de plusieurs connexions réseau, activer la sérialisation de plusieurs connexions réseau, etc.
3. Bloc http : vous pouvez imbriquer plusieurs serveurs, configurer des proxys, des caches, des définitions de journaux et d'autres fonctions et configurations de modules tiers. Tels que l'introduction du fichier, la définition du type MIME, la personnalisation des journaux, l'utilisation ou non de sendfile pour transférer des fichiers, le délai d'expiration de la connexion, le nombre de demandes de connexion uniques, etc.
4. Bloc serveur : configurez les paramètres pertinents de l'hôte virtuel. Il peut y avoir plusieurs serveurs dans un seul http.
5. Bloc localisation : Configurez le routage des demandes et le traitement des différentes pages.
Ce qui suit est un fichier de configuration accessible à tous, pour faciliter la compréhension, et il est également installé sur une machine de test que j'ai construite pour vous donner un exemple.
########### 每个指令必须有分号结束。################# #user administrator administrators; #配置用户或者组,默认为nobody nobody。 #worker_processes 2; #允许生成的进程数,默认为1 #pid /nginx/pid/nginx.pid; #指定nginx进程运行文件存放地址 error_log log/error.log debug; #制定日志路径,级别。这个设置可以放入全局块,http块,server块,级别以此为:debug|info|notice|warn|error|crit|alert|emerg events { accept_mutex on; #设置网路连接序列化,防止惊群现象发生,默认为on multi_accept on; #设置一个进程是否同时接受多个网络连接,默认为off #use epoll; #事件驱动模型,select|poll|kqueue|epoll|resig|/dev/poll|eventport worker_connections 1024; #最大连接数,默认为512 } http { include mime.types; #文件扩展名与文件类型映射表 default_type application/octet-stream; #默认文件类型,默认为text/plain #access_log off; #取消服务日志 log_format myformat '$remote_addr–$remote_user [$time_local] $request $status $body_bytes_sent $http_referer $http_user_agent $http_x_forwarded_for'; #自定义格式 access_log log/access.log myformat; #combined为日志格式的默认值 sendfile on; #允许sendfile方式传输文件,默认为off,可以在http块,server块,location块。 sendfile_max_chunk 100k; #每个进程每次调用传输数量不能大于设定的值,默认为0,即不设上限。 keepalive_timeout 65; #连接超时时间,默认为75s,可以在http,server,location块。 upstream mysvr { server 127.0.0.1:7878; server 192.168.10.121:3333 backup; #热备 } error_page 404 https://www.baidu.com; #错误页 server { keepalive_requests 120; #单连接请求上限次数。 listen 4545; #监听端口 server_name 127.0.0.1; #监听地址 location ~*^.+$ { #请求的url过滤,正则匹配,~为区分大小写,~*为不区分大小写。 #root path; #根目录 #index vv.txt; #设置默认页 proxy_pass http://mysvr; #请求转向mysvr 定义的服务器列表 deny 127.0.0.1; #拒绝的ip allow 172.18.5.54; #允许的ip } } }
Ce qui précède est la configuration de base de nginx Vous devez faire attention aux points suivants :
1.$remote_addr et $http_x_forwarded_for sont utilisés pour enregistrer l'adresse IP du client ; pour enregistrer le nom de l'utilisateur client ; 3.$time_local : utilisé pour enregistrer l'heure d'accès et le fuseau horaire ; 4.$request : utilisé pour enregistrer l'URL et le protocole http de la requête
5.$status : utilisé pour enregistrer le nom de l'utilisateur client ; le statut de la demande est de 200, 6.$ body_bytes_s ent : enregistre la taille du contenu principal du fichier envoyé au client ; 7. $http_referer : utilisé pour enregistrer le lien accédé à partir de cette page ; informations du navigateur client ;
2. Phénomène de troupeau choquant : Lorsqu'une connexion réseau arrive, plusieurs processus en veille sont réveillés par des collègues, mais un seul processus peut obtenir la connexion, ce qui affectera les performances du système.
3. Chaque commande doit se terminer par un point-virgule.
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!

Outils d'IA chauds

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

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

Undress AI Tool
Images de déshabillage gratuites

Clothoff.io
Dissolvant de vêtements AI

AI Hentai Generator
Générez AI Hentai gratuitement.

Article chaud

Outils chauds

Bloc-notes++7.3.1
Éditeur de code facile à utiliser et gratuit

SublimeText3 version chinoise
Version chinoise, très simple à utiliser

Envoyer Studio 13.0.1
Puissant environnement de développement intégré PHP

Dreamweaver CS6
Outils de développement Web visuel

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

Pour permettre au serveur Tomcat d'accéder au réseau externe, vous devez : modifier le fichier de configuration Tomcat pour autoriser les connexions externes. Ajoutez une règle de pare-feu pour autoriser l'accès au port du serveur Tomcat. Créez un enregistrement DNS pointant le nom de domaine vers l'adresse IP publique du serveur Tomcat. Facultatif : utilisez un proxy inverse pour améliorer la sécurité et les performances. Facultatif : configurez HTTPS pour une sécurité accrue.

Étapes pour exécuter ThinkPHP Framework localement : Téléchargez et décompressez ThinkPHP Framework dans un répertoire local. Créez un hôte virtuel (facultatif) pointant vers le répertoire racine ThinkPHP. Configurez les paramètres de connexion à la base de données. Démarrez le serveur Web. Initialisez l'application ThinkPHP. Accédez à l'URL de l'application ThinkPHP et exécutez-la.

Pour résoudre l'erreur "Bienvenue sur nginx!", vous devez vérifier la configuration de l'hôte virtuel, activer l'hôte virtuel, recharger Nginx, si le fichier de configuration de l'hôte virtuel est introuvable, créer une page par défaut et recharger Nginx, puis le message d'erreur. disparaîtra et le site Web sera affiché normalement.

Il existe cinq méthodes de communication de conteneur dans l'environnement Docker : réseau partagé, Docker Compose, proxy réseau, volume partagé et file d'attente de messages. En fonction de vos besoins d'isolation et de sécurité, choisissez la méthode de communication la plus appropriée, par exemple en utilisant Docker Compose pour simplifier les connexions ou en utilisant un proxy réseau pour augmenter l'isolation.

La conversion d'un fichier HTML en URL nécessite un serveur Web, ce qui implique les étapes suivantes : Obtenir un serveur Web. Configurez un serveur Web. Téléchargez le fichier HTML. Créez un nom de domaine. Acheminez la demande.

Étapes de déploiement de serveur pour un projet Node.js : Préparez l'environnement de déploiement : obtenez l'accès au serveur, installez Node.js, configurez un référentiel Git. Créez l'application : utilisez npm run build pour générer du code et des dépendances déployables. Téléchargez le code sur le serveur : via Git ou File Transfer Protocol. Installer les dépendances : connectez-vous en SSH au serveur et installez les dépendances de l'application à l'aide de npm install. Démarrez l'application : utilisez une commande telle que node index.js pour démarrer l'application ou utilisez un gestionnaire de processus tel que pm2. Configurer un proxy inverse (facultatif) : utilisez un proxy inverse tel que Nginx ou Apache pour acheminer le trafic vers votre application

Étapes de dépannage en cas d'échec de l'installation de phpMyAdmin : Vérifiez la configuration système requise (version PHP, version MySQL, serveur Web) ; activez les extensions PHP (mysqli, pdo_mysql, mbstring, token_get_all) ; vérifiez les paramètres du fichier de configuration (hôte, port, nom d'utilisateur, mot de passe) ; autorisations (propriété du répertoire, autorisations de fichiers) ; vérifier les paramètres du pare-feu (liste blanche des ports du serveur Web) ; consulter les journaux d'erreurs (/var/log/apache2/error.log ou /var/log/nginx/error.log) ; phpMonAdmin

Les instructions les plus couramment utilisées dans Dockerfile sont : FROM : créer une nouvelle image ou dériver une nouvelle image RUN : exécuter des commandes (installer le logiciel, configurer le système) COPY : copier des fichiers locaux dans l'image ADD : similaire à COPY, il peut automatiquement décompresser tar ou obtenir des fichiers URL CMD : Spécifiez la commande au démarrage du conteneur EXPOSE : Déclarez le port d'écoute du conteneur (mais pas public) ENV : Définissez la variable d'environnement VOLUME : Montez le répertoire hôte ou le volume anonyme WORKDIR : Définissez le répertoire de travail dans le conteneur ENTRYPOINT : spécifiez ce qu'il faut exécuter lorsque le conteneur démarre. Fichier exécutable (similaire à CMD, mais ne peut pas être écrasé)
