首页 > 系统相关 >3.2 nginxHTTP块配置

3.2 nginxHTTP块配置

时间:2024-07-09 15:23:59浏览次数:15  
标签:real ip 配置 server 404 html 3.2 location nginxHTTP

1 配置块的嵌套

http {
    upstream {...}
    split_clients {...}
    map {...}
    geo {...}
    server {
        if () {...}
        location {
            limit_except {...}
        }
        location {
            location {
                
            }
        }
    }
    server {
    }
}
 

2 指令的合并

  • 值指令:存储配置项的值
    • 可以合并
    • 示例:root,access_log,gzip
  • 动作类指令:指定行为
    • 不可以合并
    • 示例:rewrite,proxy_pass
    • 生效阶段:server_rewrite阶段,rewrite阶段,content阶段

存储值的指令继承规则:向上覆盖

  • 子配置不存在时,直接使用父配置块
  • 子配置存在时,直接覆盖父配置块
server {
    listen 8080;
    root /home/geek/nginx/html;
    access_log logs/geek.access.log main;
    location /test {
        root /home/geek/nginx/test;
        access_log logs/access.test.log main;
    }
    location /dlib {
        alias dlib/;
    }
    location / {
    }
}
 

3 HTTP请求处理时的11个阶段

4 正则表达式

5 提取用户真实ip

如何拿到真实的用户ip地址?

拿到真实用户ip后如何使用?

基于变量:如binary_remote_addr、remote_addr这样的变量,其值就为真实的IP!这样做连接限制(limit_conn模块)才有意义!

步骤

  1. 安装realip模块

    realip是Nginx内置模块,需要在编译Nginx时加上--with-http_realip_module参数来启用它。

  2. 配置语法

    set_real_ip_from 192.168.1.0/24; #真实服务器上一级代理的IP地址或者IP段,可以写多行。
    set_real_ip_from 192.168.2.1;
    real_ip_header X-Forwarded-For;  #从哪个header头检索出要的IP地址。
    real_ip_recursive on; #递归的去除所配置中的可信IP。
    
     

    这里详细讲下real_ip_recursive的用途:递归的去除所配置中的可信IP,排除set_real_ip_from里面出现的IP。如果出现了未出现这些IP段的IP,那么这个IP将被认为是用户的IP。

  3. 配置实例

    location / {
        root html/;
        proxy_set_header X-Forwarded-For $proxy_add_x_forwarded_for;
        set_real_ip_from 192.168.1.0/24;
        set_real_ip_from 192.168.2.1;
        real_ip_header X-Forwarded-For;
        real_ip_recursive on;
    }
    
     

6 定义404错误页面

6.1 Nginx自己的错误页面

Nginx访问一个静态的html 页面,当这个页面没有的时候,Nginx抛出404,那么如何返回给客户端404呢?

看下面的配置,这种情况下不需要修改任何参数,就能实现这个功能。

server {
    listen 80;
    server_name www.test.com;
    root /var/www/test;
    index index.html index.htm;
    location / {
        
    }
    # 定义错误页面码,如果出现相应的错误页面码,转发到那里。
    error_page 404 403 500 502 503 504 /404.html;
    # 承接上面的location
    location = /404.html {
        # 放错误页面的目录路径。
        root /usr/share/nginx/html;
    }
}
 

6.2 反向代理的错误页面

如果后台Tomcat处理报错抛出404,想把这个状态叫Nginx反馈给客户端或者重定向到某个连接,配置如下:

upstream www {
    server 192.168.1.201:8080 weight=20 max_fails=2 fail_timeout=30s
        ip_hash;
}
server {
    listen 80;
    server_name www.test.com;
    root /var/www/test;
    index index.html;
    location / {
        if($request_uri ~* '^/$') {
            rewrite .* http://www.test2.com/index.html redirect;
        }
        # 关键参数:这个变量开启后,我们才能自定义错误页面,当后端返回404,nginx拦截错误,定义错误页面
        proxy_intercept_errors on;
        proxy_pass http://www;
        proxy_set_header HOST $host;
    }
    error_page 404 /404.html;
    location = /404.html {
        root /usr/share/nginx/html;
    }
}
 

6.3 Nginx解析php代码的错误页面

如果后端是php解析的,需要加一个变量

在http段中加一个变量

fastcgi_intercept_errors on就可以了。

 

标签:real,ip,配置,server,404,html,3.2,location,nginxHTTP
From: https://www.cnblogs.com/david-cloud/p/18291971

相关文章

  • 3.4 nginxLOCATION块配置
    nginx中location的匹配模式有以下几种:精确匹配:以=开头,只有完全匹配才能生效,例子location=/uri非正则匹配:以^~开头,^表示非、~表示正则,例子location^~/uri正则匹配:以~开头,表示区分大小写的正则匹配,例子location~pattern以!~开头,表示区分大小写不匹配的正则,例子loc......
  • 3.1 nginx全局块和events块配置
    1example#运行Nginx进程的用户usernginx;worker_processes8;worker_cpu_affinityauto;#定义存储某类型的全局错误的日志位置#nginx日志分为很多级别[debug|info|notice|warn|error|crit|alert|emerg]error_log/var/log/nginx/error.logerror;......
  • Rancher 安装配置
    安装添加HelmChart仓库helmrepoaddrancher-stablehttp://rancher-mirror.oss-cn-beijing.aliyuncs.com/server-charts/stable 为Rancher创建Namespacekubectlcreatenamespacecattle-system 添加TLS密文下载nginx使用的key和pem传到服务器,并......
  • Prometheus Operator 安装配置
    一、概述首先Prometheus整体监控结构略微复杂,一个个部署并不简单。另外监控Kubernetes就需要访问内部数据,必定需要进行认证、鉴权、准入控制,那么这一整套下来将变得难上加难,而且还需要花费一定的时间,如果你没有特别高的要求,还是建议选用开源比较好的一些方案。在k8s初期使用Hea......
  • Harbor 安装配置
    #下载helmchartshelmrepoaddharborhttps://helm.goharbor.iohelmrepoupdatehelmpullharbor/harbor--version=1.9.4tar-xvfharbor-1.9.4.tgz#配置tlssecret##下载nginx使用的key和pem传到服务器,并重命名为tls.xxx##使用openssl把pem证书转换......
  • 【饼图交通方式】用ECharts的graphic配置打造个性化
    利用ECharts的graphic配置打造个性化图表内容概要ECharts是一款强大的数据可视化工具,它提供了丰富的配置选项来定制图表。本文将重点介绍graphic配置的使用,展示如何通过在饼图中添加个性化的图形元素,例如中心图像,来增强图表的视觉效果。效果预览适用人群数据可视化工......
  • Calico 安装配置
    架构简单说一下Calico架构,Calico是一个基于三层的数据中心网络方案,可作为CNI插件为运行于Kubernetes中的容器提供基于TCP/IP三层的网络通信方案,也可与OpenStack这种IaaS云架构集成,利用BGP,IPIP等协议为工作负载提供网络联通功能,能够提供高效可控的VM、容器、物理......
  • Helm 安装配置
    安装下载二进制文件exporthelmversion=3.7.2wgethttps://get.helm.sh/helm-v${helmversion}-linux-amd64.tar.gztar-xvfhelm-v${helmversion}-linux-amd64.tar.gzmvlinux-amd64/helm/usr/bin/ 设置补全命令helmcompletionbash#将输出的文件拷贝到``/etc/......
  • 4.6 pipeline 生产配置实例
    pipeline配置java项目pipeline{agent{label'slave'}options{timestamps()disableConcurrentBuilds()buildDiscarder(logRotator(numToKeepStr:'20',daysToKee......
  • 3.2 Ansible lineinfile模块详解
    1简介之所以专门说一说这个模块,是因为lineinfile在实际使用中非常有用。lineinfile模块用于在源文件中插入、删除、替换行,和sed命令的功能类似,也支持正则表达式匹配和替换。实际上,在大多数时候,我们在linux上的操作,就是针对文件的操作,通过配置管理工具对配置文件作统一的配置修......