介绍
Nginx是一个
轻量级
的Web服务器/反向代理服务器及电子邮件(IMAP/POP3)代理服务器
。其特点是占用内存少
,并发能力强
目录结构
- config: 存放配置文件
- html: 存放静态资源
- logs: 存放日志
- sbin: 二进制文件,用于停止、启动Nginx服务器
常用命令
- 检查版本: 在
sbin
目录下./nginx -v
- 检查配置文件正确性:
sbin
目录下./nginx -t
- 启动Nginx:
./nginx
- 停止Nginx:
./nginx -s stop
- 重新加载配置文件:
./nginx -s reload
配置文件结构
Nginx配置文件整体分为三部分:
- 全局块: 从文件开始到event块之前,主要配置和运行Nginx有关的全局配置
- event块: 和网络连接相关的配置
- http块: 代理、缓存、日志记录、虚拟主机配置
- http全局块
- Server块(可以配置多个Server块,每个Server块中可以配置多个location块)
- Server全局块
- location块
Nginx反向代理
正向代理
是一个位于客户端和原始服务器之间的服务器,为了从原始服务器获得内容,客户端向代理发送一个请求并制定目标(原始服务器),然后代理向原始服务器转交请求并将获得的内容返回给客户端
正向代理的典型用途是为在防火墙内的局域网客户端提供访问internet的途径
正向代理一般是在客户端设置代理服务器,通过代理服务器转发请求,最终访问到目标服务器
例: 网络代理
反向代理
反向服务器位于用户与目标服务器之间,但是对于用户而言,反向代理服务器就相当于目标服务器,即用户直接访问反向代理服务器就可以获得目标服务器 的资源,反向代理服务器负责将请求转发给目标服务器
用户不需要知道目标服务器的地址,也无需在用户端做任何设定
简单来说就是: 用户访问 ip1
资源, ip1
将请求转发至 ip2
例:
# 配置反向代理
server {
listen 81;
server_name localhost;
location / {
proxy_pass http://ip2:8080; # 反向代理配置,将请求转发到指定服务
}
}
负载均衡
早期网站流量和业务功能比较简单,服务器压力较小,一台服务器就可以完成功能,随着互联网的发展,业务流量越来越大并且业务逻辑也越来越复杂,单台服务器性能及单点故障问题就凸显起来了,因此需要多台服务器组成应用集群
,进行性能的水平扩展以及避免单点故障的出现
例:
# 配置负载均衡
upstream targetserver { # upstream指令可以定义一组服务器
server ip1:8080 ;
server ip2:8081 ;
}
server {
listen 8080;
server_name localhost;
location / {
proxy_pass http://targetserver;
}
}
应用集群
将同一应用部署到多台机器上,组成应用集群,接收负载均衡器分发的请求,进行业务处理并返回相应数据
负载均衡器
将用户请求根据对应的负载均衡算法分发到应用集群中的一台服务器进行处理
负载均衡策略
- 轮询: 默认方式
- weight: 权重方式,根据权重分发请求,权重大的分配到请求的概率大
- ip_hash: 根据ip分配方式,根据客户端请求的ip地址
计算hash值
,根据hash值来分发请求,同一个hash值分发到同一个服务器上 - least_conn: 根据最少连接方式,那个服务器当前处理的连接少,请求优先转发到这台服务器
- url_hash: 根据url分配方式,根据客户端请求url的hash值,来分发请求,同一个url请求,会转发到同一台服务器
- fair: 根据响应时间方式,优先把请求分发给处理请求时间短的服务器