基本概念
代理
正向代理
正向代理中,客户端知道要访问的服务器地址。客户端向代理服务器发送一个请求,并且指定目标服务器,之后代理向目标服务器转交并将获得的内容返回客户端。如客户端将自己的请求用shadowsock
作为代理发出去。-
反向代理
反向代理中,多个客户端向服务器发送请求,反向代理服务器接收到之后,按照一定规则分发给后端的业务处理服务器进行处理。主要用于服务器集群分布式部署的情况,反向代理隐藏了服务器的信息。如服务端的nginx
把请求转发给服务器,然后再响应。
负载均衡
负载均衡是分布式系统架构设计中必须考虑的因素,通常是指将请求和数据分摊到多个操作单元上执行。常见的互联网分布式架构分为客户端层、反向代理nginx
层、站点层、服务层、数据层 。参考
通过在后端引入一个负载均衡器和额外的web服务器,来缓解多用户访问服务器造成的加载速度缓慢或无法连接。负载均衡器根据负载均衡算法选择相应的后端服务器:
- 轮询:为第一个请求选择列表中的第一个服务器,然后按顺序向下移动列表直到结尾,然后循环。
- 最小连接:优先选择连接数最少的服务器,在普遍会话较长的情况下推荐使用
- 根据请求源的IP的散列(
hash
),这种方式可以一定程度上保证用户能连接到相同的服务器
主要配置项
-
events :配置影响
nginx
服务器或与用户的网络连接 -
http:可以嵌套多个
server
,配置代理、缓存、日志定义等绝大多数功能和第三方模块的配置 -
server 配置虚拟主机的相关参数,一个
http
可以有多个server
-
location 配置请求的路由,以及各种页面的处理情况。定义了对于一组指定的
URI
如何匹配和进行处理。 -
upstream 配置后端服务器具体地址,指定后端服务器地址列表,在
server
中拦截响应请求,并将请求转发到upstream
中配置的服务器列表。
//当访问www.example.com时,nginx会将请求转发到http:\\localhost:3000上
server{
listen 80;
server_name www.example.com;
root html;
index index.html
location /test {
proxy_set_header Host $http_host //请求host
proxy_set_header Upgrade $http_upgrade //声明支持webSocket
proxy_set_header X-Real-IP $remote_addr //请求IP
proxy_set_header X-Forwarded-For $proxy_add_x_forwarded_for //用于追加HTTP请求的来源,设置会将直连的客户端IP追加在请求原有X-Fordward-For值的右边
proxy_pass http:\\localhost:3000 //代理服务器
}
}
server { //代表一个虚拟主机,可以有多个
listen 8000;
listen somename:8080;
server_name somename alias another.alias; //匹配请求的指定域名或IP
location / { //配置请求的路由,匹配对应的URI
root html; //查找资源的路径(文件夹目录)
index index.html index.htm; //默认查找
}
}
常用指令:
-
ps -ef|grep nginx
查看nginx
目录 -
start nginx
启动nginx
-
nginx -t
/nginx -s reload
修改配置文件后重启nginx
-
nginx -s quit
停止nginx
Nginx 应该叫做「HTTP Server」,一个 HTTP Server 关心的是 HTTP 协议层面的传输和访问控制,所以在 Apache/Nginx 上你可以看到代理、负载均衡等功能。客户端通过 HTTP Server 访问服务器上存储的资源(HTML 文件、图片文件等等)。通过 CGI 技术,也可以将处理过的内容通过 HTTP Server 分发,但是一个 HTTP Server 始终只是把服务器上的文件如实的通过 HTTP 协议传输给客户端。
所以在 Apache/Nginx 上你可以看到代理、负载均衡等功能。客户端通过 HTTP Server 访问服务器上存储的资源(HTML 文件、图片文件等等)。通过 CGI 技术,也可以将处理过的内容通过 HTTP Server 分发,但是一个 HTTP Server 始终只是把服务器上的文件如实的通过 HTTP 协议传输给客户端。
HTTP Server本质上来说都是这样几件事:
监听端口接收(accept)
socket连接解析HTTP请求
使用通用或专用协议对请求进行分发
接收分发的请求产生的运行结果
将结果格式化成HTTP Response并写到socket里面
关闭连接或者Keep-Alive
Nginx作为Web服务器, 需要定义server虚拟主机,让这些虚拟主机去处理对于特定域名或IP地址的请求。