Nginx的配置文件使用说明

本文涉及的产品
传统型负载均衡 CLB,每月750个小时 15LCU
网络型负载均衡 NLB,每月750个小时 15LCU
应用型负载均衡 ALB,每月750个小时 15LCU
简介: 您好,我是码农飞哥,感谢您阅读本文!本文主要介绍Nginx的使用配置,Nginx是在实际开发中肯定会用到负载均衡的Web服务器。了解其配置对日常开发以及项目的部署有很大的用处。

您好,我是码农飞哥,感谢您阅读本文!本文主要介绍Nginx的使用配置,Nginx是在实际开发中肯定会用到负载均衡的Web服务器。了解其配置对日常开发以及项目的部署有很大的用处。

纯静态-html支持

在配置Nginx的静态资源时有root和alias两种方式,比如现在在D:/test目录下有个文件laydate.js。默认配置的主机名是localhost;通过这两种方式分别配置:

1.通过root的方式

location /test {
    root D:/;
  }

当访问http://localhost/test/laydate.js 实际上访问的地址是D:/test,也就是说文件必须要在root配置的地址+匹配的/test地址下才能找到,否则,则找不到。

2. 通过alias的方式

location /demo {
    alias D:/test;
  }

当访问http://localhost/demo/laydate.js 实际访问的地址是D:/test,也就说文件只需要在alias配置的路径下即可。目录与demo无关。

有一个特殊点是,如果访问的文件在nginx的子目录下,比如html目录在nginx下:D:\develop\nginx-1.11.12\html,则只需要配置相对路径即可:

location /{
    root html;
  }

完整的配置参考如下

events {
    worker_connections  1024;
}
http {
    server{
  listen  80;
  #服务器的域名,可以改成你需要的任何域名
  server_name localhost
  # 日志记录
  access_log  logs/test-access.log;
  location /{
  index index.html;
  root html;
  }
  location /test {
  root D:/;
  }
  location /demo {
  alias D:/test;
  }
   }
 }

配置负载均衡

Nginx的一个重要功能就是用作负载均衡的Web服务器。在分布式场景下经常要将一个域名的请求均衡到本机不同的端口,或者均衡到不同的主机上。

http {
 upstream myproject {
 server 127.0.0.18000 weight=3;
 server 127.0.0.18001;
 server 127.0.0.18002;
 }
 server {
 listen 80;
 server_name www.domain.com;
 location / {
 #请求转向后端定义的均衡模块,这个配置就是upstream myproject,直接找到location/根目录下的proxy_pass,反向代理
 proxy_pass http//myproject;
 }
  location /exp-h5 {
 proxy_pass http//myproject/exp-h5/;
 }
 }
}

通过upstream属性主要的作用就是配置多个IP地址,均衡后端的实例,nginx的upstream支持五种算法分配方式:

算法分配方式 分配方式解释
轮询(默认) 每个请求按时间顺序逐一分配到后端不同的服务器,如果后端某台服务器down掉,自动剔除,待恢复后自动添加上
weight权重 指定轮询权重,权重越高处理的请求就越多,weight和访问比率成正比,用于后端服务器性能不均的情况,weight默认为1,weight越大,负载的权重就越大
ip hash 每个请求根据访问的IP的hash结果分配,这样每个访客固定访问同一个后端服务器,可以解决session的问题,一般用于登录会话
fair(第三方) 按后端服务器的响应时间来分配请求,响应时间短的优先分配
url hash(第三方) 按照访问url的hash结果来分配请求,使每个url定向到同一个后端服务器,后端服务器为缓存时比较有效。

举个栗子:

weight权重配置
upstream testproxys{
        server  172.20.22.36:50001 weight=1 max_fails=2 fail_timeout=30s;   
        server  172.20.21.41:50001 weight=1 max_fails=2 fail_timeout=30s;
   }

upstream的fail_timeout和max_fails参数是用来判断负载均衡upstream中某个server是否失效。

在30s与该服务连接尝试失败了两次,则认为该服务已经失效,在接下来30s内,nginx不会将请求分发给失效的服务。失效时间与响应时间无关,不会影响响应时间。

ip hash
 upstream bakend {
         ip_hash;
         server 192.168.0.14:88;
         server 192.168.0.15:80;
    }

fair(第三方)

upstream backend {
    server server1;
    server server2;
    fair;
}

url_hash(第三方)

upstream backend {
    server squid1:3128;
    server squid2:3128;
    hash   $request_uri;
    hash_method crc32;
}

防盗链

防盗链是为了防止网站被非法的访问。

location ~* \.(gif|jpg|png|swf|flv)${
    valid_referers none blocked *.csdn.net server_names ~\.google\. ~\.baidu\.;
    if ($invalid_referer) {
     rewrite ^/ http://www.csdn.net/403.jpg;
        return 403;
    }
}

如果页面的来源不是*.csdn.net(自己的网站)就会返回true,并跳转到403页面,特殊的如果server_names(服务器)是google或者baidu,则返回false。


总结

本文简单介绍了Nginx的一些基本配置。

参考

Nginx配置静态资源的root和alias配置

Nginx中文文档

nginx常用配置参数介绍-upstream

相关实践学习
SLB负载均衡实践
本场景通过使用阿里云负载均衡 SLB 以及对负载均衡 SLB 后端服务器 ECS 的权重进行修改,快速解决服务器响应速度慢的问题
负载均衡入门与产品使用指南
负载均衡(Server Load Balancer)是对多台云服务器进行流量分发的负载均衡服务,可以通过流量分发扩展应用系统对外的服务能力,通过消除单点故障提升应用系统的可用性。 本课程主要介绍负载均衡的相关技术以及阿里云负载均衡产品的使用方法。
相关文章
|
8月前
|
存储 Ubuntu 应用服务中间件
【Nginx】centos和Ubuntu操作系统下载Nginx配置文件并启动Nginx服务详解
【Nginx】centos和Ubuntu操作系统下载Nginx配置文件并启动Nginx服务详解
106 1
|
3月前
|
缓存 负载均衡 应用服务中间件
nginx的配置文件详解
本文详细解释了nginx配置文件中的关键指令和区块,如http、server、location、upstream、events等,并通过一个示例配置文件展示了如何设置HTTP服务器、gzip压缩、反向代理、URL重写、错误页面和负载均衡等,强调了配置的灵活性和实际应用。
64 4
|
8月前
|
负载均衡 应用服务中间件 API
Nginx配置文件详解Nginx负载均衡Nginx静态配置Nginx反向代理
Nginx配置文件详解Nginx负载均衡Nginx静态配置Nginx反向代理
192 4
|
3月前
|
负载均衡 应用服务中间件 Linux
nginx学习,看这一篇就够了:下载、安装。使用:正向代理、反向代理、负载均衡。常用命令和配置文件,很全
这篇博客文章详细介绍了Nginx的下载、安装、配置以及使用,包括正向代理、反向代理、负载均衡、动静分离等高级功能,并通过具体实例讲解了如何进行配置。
194 4
nginx学习,看这一篇就够了:下载、安装。使用:正向代理、反向代理、负载均衡。常用命令和配置文件,很全
|
3月前
|
缓存 负载均衡 算法
nginx学习:配置文件详解,负载均衡三种算法学习,上接nginx实操篇
Nginx 是一款高性能的 HTTP 和反向代理服务器,也是一个通用的 TCP/UDP 代理服务器,以及一个邮件代理服务器和通用的 HTTP 缓存服务器。
149 0
nginx学习:配置文件详解,负载均衡三种算法学习,上接nginx实操篇
|
7月前
|
缓存 负载均衡 应用服务中间件
深入解析Nginx配置文件
Nginx是一个高性能HTTP服务器和反向代理,其配置文件`nginx.conf`包含全局、事件、HTTP、Server和Location块。全局块设置如用户和工作进程数,事件块设定连接数,HTTP块涉及MIME类型、日志和包含其他配置。Server块定义虚拟主机,Location块处理URI匹配。Nginx常用于反向代理和负载均衡,如`proxy_pass`指令转发请求至后端服务器组。理解这些配置有助于服务器优化和测试。
|
3月前
|
域名解析 网络协议 应用服务中间件
nginx server_name配置文件覆盖不生效
nginx server_name配置文件覆盖不生效
|
3月前
|
应用服务中间件 nginx
nginx 配置文件
nginx 配置文件
|
5月前
|
运维 应用服务中间件 网络安全
运维系列.Nginx配置文件结构功能总结
运维系列.Nginx配置文件结构功能总结
88 0
运维系列.Nginx配置文件结构功能总结
|
6月前
|
Ubuntu 应用服务中间件 Linux
Linux学习之Ubuntu 20中OpenResty的nginx目录里内容和配置文件
总的来说,OpenResty的Nginx配置文件是一个强大的工具,它允许你以非常灵活的方式定义你的Web服务的行为。
120 2