Loading [MathJax]/jax/output/CommonHTML/config.js
前往小程序,Get更优阅读体验!
立即前往
首页
学习
活动
专区
圈层
工具
发布
首页
学习
活动
专区
圈层
工具
社区首页 >专栏 >Nginx配置使用详解(图文真棒)

Nginx配置使用详解(图文真棒)

作者头像
入门笔记
发布于 2022-06-03 02:29:00
发布于 2022-06-03 02:29:00
2.6K00
代码可运行
举报
文章被收录于专栏:入门小站入门小站
运行总次数:0
代码可运行

1、常用命令

需要进入 [nginx]的安装目录中的sbin目录(也可以配置环境变量,在任何目录都可以执行下面的命令),里面有一个 nginx 脚本文件

代码语言:javascript
代码运行次数:0
运行
AI代码解释
复制
1、启动nginx
    ./nginx
2、关闭nginx
 ./nginx -s stop
3、重新加载nginx (nginx.conf)
 ./nginx -s reload
4、查看版本号
 ./nginx -v

2、Nginx 配置文件 (nginx.conf)

2.1 概述

默认在Linux上安装的Nginx,配置文件在安装的nginx目录下的conf目录下,名字叫做nginx.conf

nginx.conf 主要由三部分组成

  • 全局块,
  • events 块
  • http 块

2.2 配置文件结构

2.3 真实配置文件概览

代码语言:javascript
代码运行次数:0
运行
AI代码解释
复制
# 全局快
------------------------------------------------------------------------------
#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块
events {
    worker_connections  1024;
}

# http块 
http {
------------------------------------------------------------------------------# 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块
server {
# server全局块
        listen       80;
        server_name  localhost;

        #charset koi8-r;

        #access_log  logs/host.access.log  main;

# location块
        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;
        #}
}
 
# 可以配置多个server块 

}

2.2 全局块

就是配置文件从头开始到 events 块之间的内容,主要设置的是影响nginx服务器整体运行的配置指令比如 worker_process, 值越大,可以支持的并发处理量也越多,但是还是和服务器的硬件相关

2.3events 块

events 块涉及的指令主要影响 Nginx 服务器与用户的网络连接,常用的设置包括是否开启对多 work process 下的网络连接进行序列化,是否允许同时接收多个网络连接,选取哪种事件驱动模型来处理连接请求,每个 word process 可以同时支持的最大连接数等。

上述例子就表示每个 work process 支持的最大连接数为 1024. 这部分的配置对 Nginx 的性能影响较大,在实际中应该灵活配置

2.4http 块

包括 http 全局块,以及多个 server 块

2.4.1http 全局块

http 全局块配置的指令包括文件引入、 MIME-TYPE 定义、日志自定义、连接超时时间、单链接请求数上限等。

2.4.2server 块

  • 这块和虚拟主机有密切关系,虚拟主机从用户角度看,和一台独立的硬件主机是完全一样的,该技术的产生是为了节省互联网服务器硬件成本。
  • 每个 http 块可以包括多个 server 块,而每个 server 块就相当于一个虚拟主机
  • 而每个 server 块也分为全局 server 块,以及可以同时包含多个 location 块
2.4.2.1server 全局块

最常见的配置是本虚拟机主机的监听配置和本虚拟主机的名称或 IP 配置

代码语言:javascript
代码运行次数:0
运行
AI代码解释
复制
#这一行表示这个server块监听的端口是80,只要有请求访问了80端口,此server块就处理请求
listen       80;
#  表示这个server块代表的虚拟主机的名字
server_name  localhost;
2.4.2.2location 块
  • 一个 server 块可以配置多个 location 块。
  • 主要作用是根据请求地址路径的匹配,匹配成功进行特定的处理
  • 这块的主要作用是基于 Nginx 服务器接收到的请求字符串(例如 server_name/uri-string),对虚拟主机名称(也可以是 IP 别名)之外的字符串(例如 前面的 /uri-string)进行匹配,对特定的请求进行处理。地址定向、数据缓存和应答控制等功能,还有许多第三方模块的配置也在这里进行。
代码语言:javascript
代码运行次数:0
运行
AI代码解释
复制
# 表示如果请求路径是/就是用这个location块进行处理
location / {
            root   html;
            index  index.html index.htm;
        }

3、反向代理

3.1 正向代理与反向代理概述

3.1.1 正向代理

  • 正向代理代理的是客户端,需要在客户端配置,我们访问的还是真实的服务器地址

3.1.2 反向代理

  • 反向代理代理的是服务器端,客户端不需要任何配置,客户端只需要将请求发送给反向代理服务器即可,代理服务器将请求分发给真实的服务器,获取数据后将数据转发给你。隐藏了真实服务器,有点像网关。

3.1.3 区别与总结

正向代理与反向代理的区别

最根本的区别是代理的对象不同

  • 正向代理代理的是客户端,需要为每一个客户端都做一个代理服务器,客户端访问的路径是目标服务器
  • 反向代理代理的是真实服务器,客户端不需要做任何的配置,访问的路径是代理服务器,由代理服务器将请求转发到真实服务器

3.2 配置

3.2.1 应用一

实现效果访问 http://192.168.80.102:80(Nginx 首页), 最终代理到 http://192.168.80.102:8080(Tomcat 首页)

首先启动一台 Tomcat 服务器 (已经安装了 Tomcat)

进入 Tomcat 的安装目录下的bin目录下,使用./startup.sh命令,启动 Tomcat

在 Nginx 的配置文件中进行配置

1、新建一个 server 块,在 server 全局块中配置监听 80 端口

2、在 location 块中配置 / 路径请求代理到 tomcat 的地址

下面三个配置的含义就是 ,当访问 Linux 的 http://192.168.80.102:80 这个地址时,由于配置 Nginx 监听的是 80 端口,所以会进入这个 server 块进行处理,然后看你的访问路径,根据 location 块配置的不同路径进入对应的处理,由于配置了 / 请求,所以进入 / 的 location 处理,然后配置了 proxy_pass,所以进行代理到指定的路径。

代码语言:javascript
代码运行次数:0
运行
AI代码解释
复制
server {
# 监听端口80 即当访问服务器的端口是80时,进入这个server块处理
        listen       80;
# server_name当配置了listen时不起作用        
        server_name  localhost;

# location后面代表访问路径 当是/ 请求时 代理到tomcat的地址
        location / {
# 使用 proxy_pass(固定写法)后面跟要代理服务器地址            
            proxy_pass http://192.168.80.102:8080;
        }
}

经过测试,当输入http://192.168.80.102:80时,Nginx给我们代理到了Tomcat,所以显示了Tomcat的页面,即配置成功

3.2.2 应用二

应用一访问的是 / 路径,给我们代理到指定的服务器

应用二实现:

  • 让 Nginx 监听 9001 端口
  • 我们实现当访问 http://192.168.80.102:9001/edu(Nginx 地址) 时,nginx 给我们代理到 http://192.168.80.102:8081,
  • 当访问 http://192.168.80.102:9001/vod 时,nginx 给我们代理到 http://192.168.80.102:8082

启动两个 Tomcat 服务器

  • 端口分别是 8081 和 8082,
  • 在 8001 的服务器的 webapps 下创建一个 edu 目录,编写一个 test.html
  • 在 8002 的服务器的 webapps 下创建一个 vod 目录,编写一个 test.html

由于虚拟机的 ip 是 192.168.80.102,所以保证访问 http://192.168.80.102:8081/edu/test.html 和 http://192.168.80.102:8082/vod/test.html 都可以成功访问

编写 Nginx 配置文件

代码语言:javascript
代码运行次数:0
运行
AI代码解释
复制
server {
# 监听9001端口
        listen       9001;
# 进行路径匹配,匹配到edu代理到8081
        location ~/edu/ {
            proxy_pass http://192.168.80.102:8081;
        }
# 进行路径匹配,匹配到vod代理到8082
        location ~/vod/ {
            proxy_pass http://192.168.80.102:8082;
        }
}

经过测试,访问成功!!!

3.3 server_name 作用及访问流程

客户端通过域名访问服务器时会将域名与被解析的 ip 一同放在请求中。当请求到了 nginx 中时。nginx会先去匹配ip,如果listen中没有找到对应的ip,就会通过域名进行匹配,匹配成功以后,再匹配端口。当这三步完成,就会找到对应的 server 的 location 对应的资源。

4、负载均衡

4.1 概述

简单来说就是使用分布式的场景,将原先的一台服务器做成一个集群,然后将请求分发到各个服务器上,但是,如何将请求每次转发到不同的服务器呢,Nginx 就可以做到。原来我们都是直接访问服务器,现在我们可以使用 Nginx 进行反向代理,然后我们访问 Nginx,由Nginx将我们的请求分发到不同的服务器上,以实现负载均衡

4.2 配置

实现:

访问 http://192.168.80.102:80/edu/test.html,Nginx 将请求分配到 8081 和 8082 两台 tomcat 服务器上。

1、开启两台tomcat

分别在 webapps 下的 edu 下编写一个 test.html,文件内容可以不一致,为了明显看到负载均衡的效果

2、配置文件

代码语言:javascript
代码运行次数:0
运行
AI代码解释
复制
# 在http块中的全局块中配置
# upstream固定写法 后面的myserver可以自定义
upstream myserver{
    server 192.168.80.102:8081;
    server 192.168.80.102:8082;
}

# server配置
    server {
      # 监听80端口
        listen 80;   
     #location块
        location / {
# 反向代理到上面的两台服务器 写上自定义的名称
        proxy_pass http://myserver;
        }
    }

访问 http://192.168.80.102:80/edu/test.html 时,可以分发到 8081 和 8082 两台服务器,测试成功

4.3 负载均衡规则

4.3.1 轮询 (默认)

每个请求按时间顺序逐一分配到不同的后端服务器,如果后端服务器 down 掉,能自动剔除

4.3.2weight 权重

weight 代表权重默认为 1, 权重越高被分配的客户端越多

代码语言:javascript
代码运行次数:0
运行
AI代码解释
复制
upstream myserver { 
 server 192.168.80.102:8081 weight=1 ;
 server 192.168.80.102:8082 weight=2 ;
}
server {  
    listen       80;  
    location / {
    proxy_pass http://myserver; 
}

4.3.3ip_hash

每个请求按访问 ip 的 hash 结果分配,这样每个访客固定访问一个后端服务器,可以解决 session 问题

代码语言:javascript
代码运行次数:0
运行
AI代码解释
复制
#配置负载均衡的服务器和端口
upstream myserver { 
 server 192.168.80.102:8081;
 server 192.168.80.102:8082;
    ip_hash;
}
server {  
    listen       80;  
    location / {
    proxy_pass http://myserver; 
   }
}

4.3.4fair

按后端服务器的响应时间来分配请求,响应时间短的优先分配。

代码语言:javascript
代码运行次数:0
运行
AI代码解释
复制
#配置负载均衡的服务器和端口
upstream myserver {   
 server 192.168.80.102:8081;
 server 192.168.80.102:8082;
    fair;
}
server {  
    listen       80;   
    location / {
    proxy_pass http://myserver; 
    }    
}

5、动静分离

5.1 概述

  • 将静态资源 css html js 等和动态资源 (jsp servlet) 进行分开部署,我们可以将静态资源直接部署在专门的服务器上,也可以直接放在反向代理服务器上(Nginx)所在在的服务器上 然后动态资源还是部署在服务器上,如 tomcat。
  • 然后请求来的时候,静态资源从专门的静态资源服务器获取,动态资源还是转发到后端服务器上。

5.2 配置

准备工作:在 Linux 的根目录下 / 的 staticResource 目录下创建两个文件夹,分别是 www 和 image,在 www 目录下创建一个 okc.html, 在 image 目录下放一张 ttt.jpg

实现效果,访问 http://192.168.80.102:80/www/okc.html 和 http://192.168.80.102:80/image/ttt.img 时可以成功访问资源

配置

代码语言:javascript
代码运行次数:0
运行
AI代码解释
复制
server {
        listen       80;
    # 当访问路径带了www时,进入这个location处理,去/staticResource目录下对应的www目录     去找okc.html
 #  即最终实现访问到这个路径
  #  http://192.168.80.102:80/staticResource/www/okc.html
        location /www/{
            root   /staticResource/;
            index  index.html index.htm;
        }
    # 跟上面一样
        location /image/{
            root  /staticResource/;
      }   
}

经过测试,成功访问

5.3root 与 alias 区别与访问路径

  • alias 实际访问文件路径不会拼接 URL 中的路径
  • root 实际访问文件路径会拼接 URL 中的路径

示例如下:

alias

代码语言:javascript
代码运行次数:0
运行
AI代码解释
复制
location ^~ /sta/ {  
   alias /usr/local/nginx/html/static/;  
}
  • 请求:http://test.com/sta/sta1.html
  • 实际访问:/usr/local/nginx/html/static/sta1.html 文件

root

代码语言:javascript
代码运行次数:0
运行
AI代码解释
复制
location ^~ /tea/ {  
   root /usr/local/nginx/html/;  
}
  • 请求:http://test.com/tea/tea1.html
  • 实际访问:/usr/local/nginx/html/tea/tea1.html 文件
本文参与 腾讯云自媒体同步曝光计划,分享自微信公众号。
原始发表:2022-05-08,如有侵权请联系 cloudcommunity@tencent.com 删除

本文分享自 入门小站 微信公众号,前往查看

如有侵权,请联系 cloudcommunity@tencent.com 删除。

本文参与 腾讯云自媒体同步曝光计划  ,欢迎热爱写作的你一起参与!

评论
登录后参与评论
暂无评论
推荐阅读
编辑精选文章
换一批
nginx配置负载均衡
前两天在学习负载均衡,然后就看到了nginx,当前做反向代理,负载均衡 nginx用的确实比较大。
简单的程序员
2020/04/18
1.2K0
【详解】Tomcat+Nginx集群与负载均衡
在现代Web应用开发中,高可用性和高性能是系统设计的重要目标。为了实现这些目标,通常会采用集群和负载均衡技术。本文将详细介绍如何使用Nginx作为反向代理服务器,结合多个Tomcat实例构建一个高可用、高性能的Web应用集群。
大盘鸡拌面
2025/01/23
800
使用nginx配置二级域名
打算使用 www.codeliu.com , test1.codeliu.com, test2.codeliu.com这三个域名,其中 test1.codeliu.com, test2.codeliu.com作为二级域名。
秃头哥编程
2019/06/05
7.6K0
使用nginx配置二级域名
nginx简单学习总结
  Nginx是一个高性能的HTTP和反向代理服务器,特点是占用内存少,并发能力强,事实上nginx的并发能力确实在同类型的网页服务器中表现较好
samRsa
2025/02/24
1600
nginx简单学习总结
09 . Nginx配置LNMP和LNMT架构
https://www.cnblogs.com/you-men/p/13045736.html
iginkgo18
2020/09/27
7400
09 . Nginx配置LNMP和LNMT架构
Nginx系列(三):nginx配置域名转发、反向代理、负载均衡
当表达式只是一个变量时,如果值为空或任何以0开头的字符串都会当做false直接比较变量和内容时,使用=或!=~正则表达式匹配,~*不区分大小写的匹配,!~区分大小写的不匹配 2. 全局环境变量
鳄鱼儿
2024/05/21
14.6K0
玩转nginx
1、nginx是什么: nginx是一个高性能的服务器,占用内存少,并发能力强。
贪挽懒月
2020/03/24
7220
玩转nginx
Nginx的相关问题
  答:虚拟主机是一种特殊的软硬件技术,它可以将网络上的每一台计算机分成多个虚拟主机,每个虚拟主机可以独立对外提供www服务,这样就可以实现一台主机对外提供多个web服务,每个虚拟主机之间是独立的,互不影响的。通过nginx可以实现虚拟主机的配置,nginx支持三种类型的虚拟主机配置,a、基于ip的虚拟主机, b、基于域名的虚拟主机 c、基于端口的虚拟主机。
别先生
2019/10/08
8680
Nginx的相关问题
Nginx配置反向代理
反向代理服务器决定哪台服务器提供服务。返回代理服务器不提供服务器。只是请求的转发。 正向代理如下
全栈程序员站长
2022/09/14
5470
Nginx配置反向代理
Nginx系列(4) —— 反向代理的配置
与反向代理所对应的是正向代理。正向代理中最为常见的例子就是vpn。当我们使用vpn访问其他网页时,我们的ip地址并不会暴露给我们直接连接的网站,而是vpn的代理ip。反向代理与正向代理的差异其实就是,当我们想要访问一个网站时,被访问的服务器的ip不会直接暴露在我们面前,而是反向代理服务器的ip地址。
求和小熊猫
2020/11/25
1.6K0
【Nginx27】Nginx学习:代理模块(一)基本配置与概念
来了来了它来了。要说 Nginx 最早最出名的名头是什么?相信不少老码农马上就会想到,最开始,Nginx 的名头就是一款性能最高的 反向代理 服务器。现在其实也是,但是这么说的人越来越少了。也就是说,其实 Nginx 最主要的功能就在于反向代理。如果是编程小白,刚刚从事编程相关工作,没有配置过负载集群,可能对这个概念还是比较陌生的。那么今天咱们就来先说说 代理、反向代理、正向代理 这些概念。
硬核项目经理
2023/09/19
1.2K0
【Nginx27】Nginx学习:代理模块(一)基本配置与概念
Nginx配置——反向代理
其他话不多说,下面来学习一下Nginx的反向代理。如果没有Linux和Nginx环境,可以参考前两篇文章。
全栈程序员站长
2022/09/14
7.6K0
Nginx配置——反向代理
建议收藏 | 彻底搞懂 Nginx 的五大应用场景
导读:Nginx本身也是一个静态资源的服务器,当只有静态资源的时候,就可以使用Nginx来做服务器,如果一个网站只是静态页面的话,那么就可以通过这种方式来实现部署。
码农架构
2021/07/09
9960
建议收藏 | 彻底搞懂 Nginx 的五大应用场景
nginx使用学习之正向代理、反向代理、负载均衡(配置实例详解)
Nginx 不仅可以做反向代理,实现负载均衡。还能用作正向代理来进行上网等功能。正向代理:如果把局域网外的 Internet 想象成一个巨大的资源库,则局域网中的客户端要访 问 Internet,则需要通过代理服务器来访问,这种代理服务就称为正向代理。
IT大咖说
2019/12/17
3.8K0
nginx使用学习之正向代理、反向代理、负载均衡(配置实例详解)
Nginx
Nginx (engine x) 是一个高性能的HTTP和反向代理web服务器,同时也提供了IMAP/POP3/SMTP服务。其特点是占用内存少,支持热部署,并发能力强,专为高并发而优化,事实上Nginx的并发能力在同类型的网页服务器中表现最好(来自百度百科)
晚上没宵夜
2022/05/09
4550
Nginx
Nginx(四)------nginx 负载均衡
  在上一篇博客我们介绍了 Nginx 一个很重要的功能——代理,包括正向代理和反向代理。这两个代理的核心区别是:正向代理代理的是客户端,而反向代理代理的是服务器。其中我们又重点介绍了反向代理,以及如何通过 Nginx 来实现反向代理。那么了解了Nginx的反向代理之后,我们要通过Nginx的反向代理实现另一个重要功能——负载均衡。
IT可乐
2018/09/28
8050
Nginx(四)------nginx 负载均衡
学完Nginx/OpenResty详解,反向代理与负载均衡配置,能涨薪多少
接下来介绍Nginx的重要功能:反向代理+负载均衡。单体Nginx的性能虽然不错,但也是有瓶颈的。打个比方:用户请求发起一个请求,网站显示的图片量比较大,如果这个时候有大量用户同时访问,全部的工作量都集中到了一台服务器上,服务器不负重压,可能就崩溃了。高并发场景下,自然需要多台服务器进行集群,既能防止单个节点崩溃导致平台无法使用,又能提高一些效率。一般来说,Nginx完成10万多用户同时访问,程序就相对容易崩溃。
愿天堂没有BUG
2022/10/28
2.5K0
学完Nginx/OpenResty详解,反向代理与负载均衡配置,能涨薪多少
Nginx入门
是一个高性能的http和反向代理web服务器,同时提供了 IMAP、POP3、SMTP服务。
暴躁的程序猿
2022/03/23
2820
Nginx超简单教程
Nginx是一个高性能的http和反向代理服务器,其特点是占用内存小,并发能力强。Nginx专为性能优化而开发,性能是其最重要的考量,能经受高负载的考验,有报告表明能支持高达50000个并发连接数。
Java旅途
2020/07/14
6780
Nginx反向代理的配置
最近搞个服务器,然后部署了个人网站,以及一些服务供自己玩耍,其中Nginx最让我很难受,配置总是要现用现百度。所以,我来了,咳咳,我带来了一些​常用的配置。​需要有 Linux 和 Nginx 环境。
Java技术债务
2022/08/09
1.4K0
相关推荐
nginx配置负载均衡
更多 >
领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档
查看详情【社区公告】 技术创作特训营有奖征文
本文部分代码块支持一键运行,欢迎体验
本文部分代码块支持一键运行,欢迎体验