Nginx基本配置

本文详细介绍了Nginx的配置文件结构、关键组件如全局块、events块、http块和server/location块的功能。涵盖了反向代理、负载均衡以及动静分离的配置方法,帮助读者理解Nginx的高级配置策略。

Nginx

目录

Nginx

配置文件

组成

全局块: 配置文件开头到 events块之间的部分。

events块

http块: http 块也可以包括 http 全局块、server 块。

http 全局块

server 块

全局 server 块

location 块

反向代理

负载均衡

分配方式

动静分离


配置文件

nginx配置文件位置: nginx-x.x.x/ conf/ nginx.conf (x.x.x代表nginx版本号,该层目录是nginx安装目录)

组成

全局块: 配置文件开头到 events块之间的部分。

主要包括配置运行 Nginx 服务器的用户(组)、允许生成的 worker process 数,进程 PID 存放路径、日志存放路径和类型以 及配置文件的引入等。

events块

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

http块: http 块也可以包括 http 全局块、server 块。

Nginx 服务器配置中最频繁的部分,代理、缓存和日志定义等绝大多数功能和第三方模块的配置都在这里。

http 全局块

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

server 块

每个 http 块可以包括多个 server 块,而每个 server 块就相当于一个虚拟主机。 而每个 server 块也分为全局 server 块,以及可以同时包含多个 locaton 块。

全局 server 块

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

location 块

主要作用是基于 Nginx 服务器接收到的请求字符串(例如 server_name/uri-string),对虚拟主机名称(也可以是 IP 别名)之外的字符串(例如 前面的 /uri-string)进行匹配,对特定的请求进行处理。地址定向、数据缓 存和应答控制等功能,还有许多第三方模块的配置也在这里进行。

反向代理

以下演示了访问 www.123.com 直接跳转到 www.baidu.comwww.123.com/bilibili 直接跳转到 www.bilibili.com

 server {
         listen       80; //监听的端口号
         server_name  www.default.com; //监听的访问域名
 ​
         location / {
             proxy_pass http://www.baidu.com; //需要跳转的地址
         }
         
         location /bilibili {
             proxy_pass http://www.bilibili.com;
         }   
     }

location指令的正则指令

1、= :用于不含正则表达式的 uri 前,要求请求字符串与 uri 严格匹配,如果匹配 成功,就停止继续向下搜索并立即处理该请求。 2、~:用于表示 uri 包含正则表达式,并且区分大小写。 3、~:用于表示 uri 包含正则表达式,并且不区分大小写。 4、^~:用于不含正则表达式的 uri 前,要求 Nginx 服务器找到标识 uri 和请求字 符串匹配度最高的 location 后,立即使用此 location 处理请求,而不再使用 location 块中的正则 uri 和请求字符串做匹配。 注意:如果 uri 包含正则表达式,则必须要有 ~ 或者 ~ 标识。

负载均衡

在http块中配置负载均衡

http块配置 upstream

 upstream servername{
     server 地址1;
     server 地址2;
 }

后可通过location块中的proxy_pass指定servername

分配方式

1、轮询(默认) 每个请求按时间顺序逐一分配到不同的后端服务器,如果后端服务器 down 掉,能自动剔除。 2、weight weight 代表权,重默认为 1,权重越高被分配的客户端越多 指定轮询几率,weight 和访问比率成正比,用于后端服务器性能不均的情况。

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

4、fair(第三方) 按后端服务器的响应时间来分配请求,响应时间短的优先分配。

动静分离

配置http块中的location

 location /静态资源目录 {
     root /静态资源根目录/
     
     index index.html index.htm; //指定了当请求的 URL 是以 /地址 结尾时,Nginx 应该优先返回哪个     文件作为默认页面。在这里,Nginx 会先尝试返回 index.html,如果找不到则返回 index.htm。
     
     autoindex on; //开启了自动目录索引功能
 }
评论
成就一亿技术人!
拼手气红包6.0元
还能输入1000个字符
 
红包 添加红包
表情包 插入表情
 条评论被折叠 查看
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值