nginx-代理服务

目录

相关指令

相关模块

安装新模块proxy_pass指令

案例

proxy_set_header指令

案例

被代理服务器配置

代理服务器配置

proxy_redirect指令

案例

服务端配置

代理服务器配置

正向代理

需求分析

环境准备

配置

主机配置

服务器配置

主配置文件

web文件配置

不使用代理

代理服务器配置

使用代理

反向代理

需求分析

环境准备

配置

服务器配置

server1

server2

server3

验证配置

server1

​编辑server2

​编辑

server3

代理服务器配置

测试配置

server1

server2

server3


相关指令

相关模块

以下与代理服务相关的命令均来源于模块ngx_http_proxy_module,使用此模块进行解析,该模块在安装nginx时已经默认添加到nginx中,可以使用 nginx -V 进行查看,是否安装此模块,如果没有安装,可以参考下面文章学习在nginx中添加新的模块的方法。

安装新模块

proxy_pass指令

该指令用来设置被代理服务器的地址,可以是主机名称,ip地址加端口号的形式

| 语法 | proxy_pass URL; |
| 默认值 | --- |

位置 location块
[proxy_pass指令表]

URL为要设置的被代理服务器地址,包含传输协议(http,https//),主机名称或者ip地址加端口号,URI等要素。

案例

使用代理服务器(192.168.188.10)对服务器(192.168.188.11)进行代理

bash 复制代码
proxy_pass http://www.baidu.com;
proxy_pass http://192.168.188.11/;

后面的"/"的影响,以下面配置为例:

bash 复制代码
server {
    listen 80;
    server_name localhost;
    location /server {    
        #使用不加"/"的写法:此时访问的代理服务器地址为:http://192.168.200.146/server;
        proxy_pass http:/192.168.200.146;  
        #使用加上"/"的写法,此时访问的代理服务器地址为:http//192.168.200.146/index;
        proxy_pass http:/192.168.200.146/;  
    }
}

proxy_set_header指令

该指令可以更改nginx服务器接收到客户端请求的请求头信息,然后将新的请求头发送给代理的服务器

| 语法 | proxy_set_header field value; |
| 位置 | proxy_set_header Host $proxy_host; peoxy_set_header Connection close; |

默认值 http块,server块,location块
[proxy_set_header指令表]
案例

改变服务器头信息中的username参数,观察代理服务器的输出情况

被代理服务器配置
bash 复制代码
server {
    listen 8080;
    server localhost;
    default_type text/plain;
    return 200 $http_username;
}
代理服务器配置
bash 复制代码
server {
    listen 8081;
    server localhost;
    location /server {
        #192.168.188.18为被代理服务器的ip地址
        proxy_pass http://192.168.188.10:8080/;
        proxy_set_header username Tom;     
        }
}

proxy_redirect指令

使用该指令来重置头信息中的"Location"和"Refresh"的值

使用该命令的好处:

如果不使用该命令,在我们进行访问代理服务器进行跳转时,网站URL也会进行跳转,将服务器ip地址暴露,为了隐藏服务器,因此使用此命令重置Location和Refresh的值

| 语法 | proxy_redirect redirect replacement; proxy_redirect default; proxy_redirect off; |
| 默认值 | proxy_redirect off; |

位置 http块,server块,location块
[proxy_redirect指令表]
案例

隐藏服务器的ip地址,使服务器对用户来说是透明的

服务端配置
bash 复制代码
server {
    listen 8081;
    server_name localhost;
    if (-f $request_filename) {
        return 302 http://192.168.188.10/;
}

}
代理服务器配置
bash 复制代码
server {
    listen 8080;
    server_name localhost;
    location / {
        proxy_pass http://192.168.188.10:8081;
        proxy_pass http:/192.168.200.146/ http://192.168.200.133/;

    }
}

正向代理

需求分析

在不使用代理时,客户端直接访问服务器,在使用代理服务器是,客户端通过访问代理服务器来获取服务器的资源。此时,服务端对客户端来说不是透明存在的。正向代理需要在客户端上进行代理服务器的配置

环境准备

默认web服务使用80端口

ip地址 角色
192.168.188.1 客户端
192.168.188.10 代理服务器
192.168.188.11 服务器
[正向代理资源需求表]

配置

主机配置

在本地主机启用网络代理功能,将代理服务器的ip地址和端口号进行配置

服务器配置
主配置文件
bash 复制代码
server {
    listen 80;
    server_name localhost;   
    error_log /var/log/nginx/www.qfedu.com-error_log error;  
    location / {
        access_log  /var/log/nginx/server.log server;
        root /usr/share/nginx/html;
        index a.html;
    }
}
web文件配置
bash 复制代码
<h1>this is '192.168.188.11'</h1>
不使用代理

使用主机进行访问时,服务器上面的日志显示的客户端为192.168.188.1,显示的服务端为192.168.188.11

代理服务器配置
bash 复制代码
server {
    listen       80;
    resolver 8.8.8.8;
    server_name  localhost;

    location / {
        proxy_pass http://$host$request_uri;
    }
使用代理

使用代理服务器来进行对服务器的访

反向代理

需求分析

Nginx反向代理是一种网络架构技术,通过该技术,Nginx服务器充当客户端和内部服务器之间的中介。客户端发送的请求首先被Nginx接收,然后Nginx根据配置规则将这些请求转发给内部网络中的其他服务器。服务器处理完请求后,将响应发送回Nginx,Nginx再将这个响应返回给原始客户端。

环境准备

|---------------------|-------|---------|
| 服务地址 | 角色 | 服务名 |
| 192.168.188.1 | 客户 | --- |
| 192.168.188.10 | 代理服务器 | --- |
| 192.168.188.11:8081 | 服务器 | server1 |
| 192.168.188.11:8082 | 服务器 | server2 |
| 192.168.188.11:8083 | 服务器 | server3 |
[反向代理准备表]

此时用192.168.188.11的三个端口来模拟三个不同的服务,用户通过访问代理服务器,代理服务器将用户的访问请求发送给服务器,再由服务器返回信息给代理,最后由代理服务器将资源返还给客户端。此时,三个服务为不同服务,后面三个服务相同时,即为nginx的负载均衡配置,后再后面进行讲解

配置

服务器配置

在192.168.188.11的三个端口8081-8083上面配置相关服务,并自定义web页面和日志信息,便于进行验证

server1
bash 复制代码
server {
    listen 8081;
    server_name 192.168.188.11;

    location / {
        access_log  /var/log/nginx/server1.log server;
        root /usr/share/nginx/html;
        index server1.html;
    }
}
server2
bash 复制代码
server {
    listen 8082;
    server_name 192.168.188.11;

    location / {
        access_log  /var/log/nginx/server2.log server;
        root /usr/share/nginx/html;
        index server2.html;
    }
}
server3
bash 复制代码
server {
    listen 8083;
    server_name 192.168.188.11;

    location / {
        access_log  /var/log/nginx/server3.log server;
        root /usr/share/nginx/html;
        index server3.html;
    }
}
验证配置
server1
server2
server3
代理服务器配置

在代理服务器192.168.188.10上面使用proxy_pass命令来对上面三个服务进行代理,使用户可以访问代理服务器来获取服务器资源

bash 复制代码
server {
    listen       80;

    server_name  localhost;

    location /server1 {
        proxy_pass http://192.168.188.11:8081/;
        }
    location /server2 {
        proxy_pass http://192.168.188.11:8082/;
        }
    location /server3 {
        proxy_pass http://192.168.188.11:8083/;
        }
}
测试配置
server1

此时,使用客户端192.168.188.1来访问代理服务器192.168.188.10下的server1,从server1的日志可以看出,代理服务器去访问服务器server1从而返回数据给客户端

server2

此时,使用客户端192.168.188.1来访问代理服务器192.168.188.10下的server2,从server2的日志可以看出,代理服务器去访问服务器server2从而返回数据给客户端

server3

此时,使用客户端192.168.188.1来访问代理服务器192.168.188.10下的server3,从server3的日志可以看出,代理服务器去访问服务器server3从而返回数据给客户端

相关推荐
大秦王多鱼8 分钟前
Kafka 消费端反复 Rebalance: `Attempt to heartbeat failed since group is rebalancing`
运维·分布式·kafka·apache
MXsoft61831 分钟前
基于监控易一体化运维软件的浪潮服务器监控指标详解
运维·数据库
Danileaf_Guo32 分钟前
用BGP的路由聚合功能聚合大陆路由,效果显著不?
运维·网络·智能路由器
{⌐■_■}1 小时前
【gRPC-gateway】option定义规则及HttpBody响应
java·服务器·开发语言·golang·gateway
垚垚 Securify 前沿站4 小时前
Linux Samba 低版本漏洞(远程控制)复现与剖析
linux·运维·网络·安全·web安全·网络安全·系统安全
我的青春不太冷4 小时前
深入探讨:服务器如何响应前端请求及后端如何查看前端提交的数据(基础语法版)
服务器·前端·状态模式
张小小大智慧4 小时前
计算机网络部分知识点(王道考研笔记)
运维·网络·智能路由器
指尖动听知识库4 小时前
嵌入式经典面试题之操作系统(一)
java·linux·服务器
自信不孤单5 小时前
网络编程套接字(上)
服务器·网络·udp·socket·ip地址·端口号