浅入浅出之nginx

工作流程

  1. 用户通过域名发出访问Web服务器的请求,该域名被DNS服务器解析为反向代理服务器的IP地址
  2. 反向代理服务器接受用户的请求
  3. 反向代理服务器在本地缓存中查找请求的内容,找到后直接把内容发送给用户
  4. 如果本地缓存里没有用户所请求的信息内容,反向代理服务器会代替用户向源服务器请求同样的信息内容,并把信息内容发给用户,如果信息内容是缓存的还会把它保存到缓存中

正向代理

概念

正向代理(Forward Proxy)通常都被简称为代理,就是在用户无法正常访问外部资源,比方说受到GFW的影响无法访问twitter的时候,我们可以通过代理的方式,让用户绕过防火墙,从而连接到目标网络或者服务
Alt

反向代理

概念


反向代理(Reverse Proxy)方式是指以代理服务器来接受internet上的连接请求,然后将请求转发给内部网络上的服务器,并将从服务器上得到的结果返回给internet上请求连接的客户端,此时代理服务器对外就表现为一个服务器
Alt

nginx反向代理配置文件介绍

  • location块介绍
location /abc/dd/ {
    proxy_set_header Host $http_host;
    proxy_set_header X-Real-IP $remote_addr;
    proxy_set_header REMOTE-HOST $remote_addr;
    proxy_set_header X-Forwarded-For $proxy_add_x_forwarded_for;
    proxy_pass http://200.200.111.22:1234;
}

解释

  • location /abc/dd/ {:定义了一个 location 块,匹配以 /abc/dd/ 开头的请求路径。
  • proxy_set_header Host $http_host;:设置代理请求的 Host 头部,使用客户端请求中的 Host 头部值。
  • proxy_set_header X-Real-IP $remote_addr;:设置代理请求的 X-Real-IP 头部,传递客户端的真实 IP 地址。
  • proxy_set_header REMOTE-HOST $remote_addr;:设置代理请求的 REMOTE-HOST 头部,传递客户端的真实 IP 地址。
  • proxy_set_header X-Forwarded-For $proxy_add_x_forwarded_for;:设置代理请求的 X-Forwarded-For 头部,传递客户端的 IP 地址以及之前所有代理的 IP 地址(如果有的话)。
  • proxy_pass http://200.200.111.22:1234;:指定代理请求应该转发到的目标服务器地址。

作用

这段配置定义了一个 Nginx 代理,它将所有指向特定路径(/abc/dd/)的请求转发到目标服务器(http://200.200.111.22:1234),并在转发过程中设置了一些必要的 HTTP 头部,以传递客户端的真实 IP 地址和其他相关信息。

  • location块儿配置样例及解释
   location /eldercare/abc-h5 {
       alias   /opt/abc-h5/;
       try_files $uri $uri/ /eldercare/abc-h5/index.html;
       index  index.html index.htm;
   }

解释及作用

  • 这段配置文件是用于Nginx服务器的一个配置段,它定义了如何处理对特定URL路径的请求。下面是对这段配置的逐行解释:

  • location /eldercare/abc-h5 {

这一行定义了一个location块,用于匹配访问URL中以/eldercare/abc-h5开头的请求。

  • alias /opt/abc-h5/;

alias指令用于将请求的URL路径映射到服务器上的文件系统路径。这里的意思是,当请求的URL路径匹配/eldercare/abc-h5时,Nginx将会在文件系统上寻找/opt/abc-h5/目录下的文件来响应请求。

  • try_files $uri $uri/ /eldercare/abc-h5/index.html;

try_files指令用来按顺序尝试提供请求的文件。这里的意思是:

  1. 首先尝试匹配URI指定的文件($uri),即请求的完整路径。
  2. 如果没有找到文件,则尝试在URI后面添加/,寻找对应的目录下的索引文件($uri/)。
  3. 如果以上两者都没有找到,最后将返回/eldercare/abc-h5/index.html作为默认的文件(index index.html index.htm;

index指令用来指定当请求的URL没有指定具体文件时,默认提供的文件。这里指定了两个默认文件:index.htmlindex.htm。Nginx将会按顺序查找这些文件,如果找到了,就发送给客户端。

总结来说,这段配置意味着对于任何以/eldercare/abc-h5开头的请求,Nginx将会在服务器上的/opt/abc-h5/目录中查找相应的文件。如果请求的是一个目录,则会尝试提供该目录下的index.htmlindex.htm文件作为默认页面。如果没有找到请求的文件或目录,则会返回/eldercare/abc-h5/index.html文件。这通常用于单页面应用程序(SPA),其中客户端路由由前端JavaScript处理,并且所有的请求通常都应该返回相同的index.html

参考文章

nginx工作原理分析

nginx配置文件详解

当然,以下是一个以 Markdown 格式输出的 Nginx 常用指令和操作列表:

Nginx 常用指令和操作

启动 Nginx

nginx

测试配置文件

nginx -t

快速关闭 Nginx

nginx -s stop

优雅关闭 Nginx

nginx -s quit

重载配置文件

nginx -s reload

查看版本

nginx -v

查看编译时的参数

nginx -V

查看进程

ps aux | grep nginx

配置用户访问日志

access_log /path/to/log;

配置错误日志

error_log /path/to/log;

设置 web 根目录

root /path/to/webroot;

配置 server 块

server {
    listen 80;
    server_name example.com;
    location / {
        root /path/to/webroot;
        index index.html;
    }
}

配置 location 块

location / {
    try_files $uri $uri/ /index.html;
}

配置反向代理

location / {
    proxy_pass http://localhost:3000;
}

配置负载均衡

upstream backend {
    server backend1.example.com;
    server backend2.example.com;
}

server {
    location / {
        proxy_pass http://backend;
    }
}
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值