Table des matières
auth_request:
nginx 指令顺序:
proxy_pass 和 echo 不能同时在一个 location 中
Maison php教程 php手册 lua nginx 指令顺序

lua nginx 指令顺序

Jun 06, 2016 pm 08:13 PM
lua nginx 任务 回来 学习 指令 commande

十一回来的任务就是学习 lua, agentzh; chaoslawful http://openresty.org/download/agentzh-nginx-tutorials-en.html http://wiki.nginx.org/HttpLuaModule auth_request: auth_request directive discards the response body of the subrequest it manages

十一回来的任务就是学习 lua, agentzh; chaoslawful

 http://openresty.org/download/agentzh-nginx-tutorials-en.html
 http://wiki.nginx.org/HttpLuaModule
Copier après la connexion

auth_request:

   auth_request directive discards the response body of the subrequest it manages, and only checks 
the response status code of the subrequest. When the status code looks good, like 200, 
auth_request will just allow Nginx continue processing the main request; 
otherwise it will immediately abort the main request by returning a 403 error page,   
      location /main {                                                        
        set $var main;                                                      
        auth_request /sub;                                                  
        echo "main: $var";                                                  
    }                                                                       
    location /sub {                                                         
        set $var sub;                                                       
        echo "sub: $var";                                                   
    } 
   curl http://localhost:518/main
   结果:main : sub
Copier après la connexion

nginx 指令顺序:

   location /test {                                                        
        set $a 32;                                                          
        echo $a;                                                            
        set $a 56;                                                          
        echo $a;                                                            
    } 
 curl -i http://locahost:516/test
 56
 56
Copier après la connexion

这个和我接触过的语言有很大的不一样,为什么会导致这种情况呢,这就要看nginx 的请求处理阶段了.

先看三个阶段执行顺序:

  1.rewrite : set;set_unescape_uri;set_by_lua;
  2.access : access_by_lua(tail);
  3.content  : echo;ngx_auth_request;content_by_lua
  rewrite_by_lua :phase->rewrite tail(这个可能会导致你期待的结果和实际结果不一致)
  more_set_input_headers: phase->rewrite tail
Copier après la connexion

nginx 分属于不同阶段处理的配置指令之间是不能穿插运行的

对两个字符串作加法运算会触发 Lua 对加数进行自动类型转换(Lua 会把两个加数先转换为数值类型再求和) 或者使用 tonumber()

即使运行在同一个请求处理阶段,分属不同模块的配置指令也可能会分开独立运行(除非像 ngx_set_misc 等模块那样针对 ngx_rewrite 模块提供特殊支持)

Nginx 的 rewrite 阶段是一个比较早的请求处理阶段,这个阶段的配置指令一般用来对当前请求进行各种修改(比如对 URI 和 URL 参数进行改写),或者创建并初始化一系列后续处理阶段可能需要的 Nginx 变量。当然,也不能阻止一些用户在 rewrite 阶段做一系列更复杂的事情,比如读取请求体,或者访问数据库等远方服务,毕竟有 rewrite_by_lua 这样的指令可以嵌入任意复杂的 Lua 代码。

nginx 内部标准变量:

   $remote_addr 获取字符串形式的 客户端Ip地址
Copier après la connexion

绝大多数 Nginx 模块在向 content 阶段注册配置指令时,本质上是在当前的 location 配置块中注册所谓的“内容处理程序”(content handler)。每一个 location 只能有一个“内容处理程序”,因此,当在 location 中同时使用多个模块的 content 阶段指令时,只有其中一个模块能成功注册“内容处理程序”

proxy_pass 和 echo 不能同时在一个 location 中

Nginx 处理请求的过程一共划分为 11 个阶段,按照执行顺序依次是

   post-read、server-rewrite、find-config、rewrite、post-rewrite、
    preaccess、access、post-access、try-files、content 以及 log.
Copier après la connexion
  1. ngx.arg ,在那个里面的example 有个错误,

    location /foo {
    set $a 32;
    set $b 56;
    set_by_lua $res
        'return tonumber(ngx.arg[1]) + tonumber(ngx.arg[2])'
        $a $b;
    echo $sum;
    } 你自己运行一下就会发现问题了 ,改一下变量名称就可以了,这个错误已经报告给春哥,春哥回复已经修改了
    
    Copier après la connexion
  2. ngx.ctx 里面

    location /test {
    rewrite_by_lua '
        ngx.say("foo = ", ngx.ctx.foo)  ---1
        ngx.ctx.foo = 76
    ';
    access_by_lua '
        ngx.ctx.foo = ngx.ctx.foo + 3
    ';
    content_by_lua '
        ngx.say(ngx.ctx.foo)   ---2
    ';
    }
    按照他的我没有得到他介绍的值,我只能单独的到--1,或者--2的值;
    
    Copier après la connexion
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)
3 Il y a quelques semaines By 尊渡假赌尊渡假赌尊渡假赌
R.E.P.O. Meilleurs paramètres graphiques
3 Il y a quelques semaines By 尊渡假赌尊渡假赌尊渡假赌
R.E.P.O. Comment réparer l'audio si vous n'entendez personne
3 Il y a quelques semaines By 尊渡假赌尊渡假赌尊渡假赌
Où trouver la courte de la grue à atomide atomique
1 Il y a quelques semaines By DDD

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 autoriser l'accès au réseau externe au serveur Tomcat Comment autoriser l'accès au réseau externe au serveur Tomcat Apr 21, 2024 am 07:22 AM

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.

Comment exécuter thinkphp Comment exécuter thinkphp Apr 09, 2024 pm 05:39 PM

É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.

Bienvenue sur nginx !Comment le résoudre ? Bienvenue sur nginx !Comment le résoudre ? Apr 17, 2024 am 05:12 AM

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.

Comment déployer le projet nodejs sur le serveur Comment déployer le projet nodejs sur le serveur Apr 21, 2024 am 04:40 AM

É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

Comment générer une URL à partir d'un fichier HTML Comment générer une URL à partir d'un fichier HTML Apr 21, 2024 pm 12:57 PM

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.

Quelles sont les instructions les plus courantes dans un fichier docker Quelles sont les instructions les plus courantes dans un fichier docker Apr 07, 2024 pm 07:21 PM

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é)

Nodejs est-il accessible de l'extérieur ? Nodejs est-il accessible de l'extérieur ? Apr 21, 2024 am 04:43 AM

Oui, Node.js est accessible de l’extérieur. Vous pouvez utiliser les méthodes suivantes : Utilisez Cloud Functions pour déployer la fonction et la rendre accessible au public. Utilisez le framework Express pour créer des itinéraires et définir des points de terminaison. Utilisez Nginx pour inverser les requêtes de proxy vers les applications Node.js. Utilisez des conteneurs Docker pour exécuter des applications Node.js et les exposer via le mappage de ports.

Soyez le premier à ouvrir le trésor de la mission. La nouvelle version de 'World of Warships' est maintenant ouverte. Soyez le premier à ouvrir le trésor de la mission. La nouvelle version de 'World of Warships' est maintenant ouverte. Apr 17, 2024 pm 06:04 PM

Soyez le premier à ouvrir le trésor de la mission et à planifier la bataille avec une longueur d'avance. La version 13.3 de « World of Warships » est désormais ouverte. Connaître toutes les informations importantes sur la nouvelle version des missions de combat et des types de combat aidera les capitaines à planifier la bataille globale et à obtenir rapidement les récompenses pertinentes. En version 13.3, le mode de combat asymétrique que les capitaines attendaient revient. Les capitaines doivent contrôler les navires de guerre contre les navires de guerre IA de niveau inférieur mais plus nombreux. Ce mode est très adapté au jeu en équipe. Jusqu'à 5 joueurs peuvent former une équipe pour combattre côte à côte. Une coopération plus tacite peut vous aider à vaincre l'adversaire rapidement. Lors du patch 13.3, tous les capitaines auront la possibilité de récupérer la Somme Collection et d'obtenir ce destroyer de rang IX. La condition requise pour cette tâche est également très simple, c'est-à-dire gagner le jeu avant la sortie de la prochaine version.

See all articles