时间:2021-05-22
简介
Nginx 是一个高性能的 HTTP 服务器和反向代理服务器.
最常用的两个功能是反向代理和负载均衡.
反向代理
反向代理是正向代理的反面.
普通的代理服务器是需要用户主动去设置的, 用户在自己的电脑上设置并连接代理服务器,
从而可以隐藏自己的 IP, 使得应用服务器不知道客户端的 IP 地址.
而反向代理是作为应用服务器的代理, 安装在服务器上. 客户端实际上访问的反向代理服务器,
反向代理服务器再去访问实际的应用服务器, 然后将获取到的响应传送给客户端.
使用 Nginx 配置反向代理非常简单, 基础配置如下:
upstream web { server 127.0.0.1:8081;}server { listen 80; server_name web.coolcat.com; location / { proxy_set_header Host $http_host; proxy_set_header X-Forwarded-Host $http_host; proxy_set_header X-Forwarded-For $proxy_add_x_forwarded_for; proxy_set_header X-Real-IP $remote_addr; client_max_body_size 5m; proxy_pass http://web; }}上面的配置文件中设置了一个域名 web.coolcat.com,
对这个域名的所有请求都会转发到 http://web 上.
通过配置 upstream, 我们可以发现, 实际上的流量都被转发到了
127.0.0.1:8081 上了.
如此一来, 就实现了反向代理.
负载均衡
负载均衡和反向代理是分不开的, 负载均衡通常都是基于反向代理做的.
所谓的负载均衡, 指的是将多个请求转发到不同的后端服务器上.
upstream web { server 127.0.0.1:8081;}在上面的反向代理配置中, 只设置了一个后端服务器地址,
如果再添加几个, 就实现了最简单的负载均衡了.
轮询
轮询策略按顺序分配请求.
upstream web { server 192.168.1.1:8081; server 192.168.1.2:8081;}加权轮询
加权策略按比例分配请求.
upstream web { server 192.168.1.1:8081 weight=4; server 192.168.1.2:8081 weight=6;}上面的两个服务器的访问概率就是四六开.
最少连接
最少连接将请求分配给当前连接数最少的服务器.
upstream web { least_conn; server 192.168.1.1:8081; server 192.168.1.2:8081;}ip_hash
来自同一个 IP 的连接都会分配给同一个服务器, 通常用于 会话保持.
upstream web { ip_hash; server 192.168.1.1:8081; server 192.168.1.2:8081;}通用 hash
使用 hash 自定义要计算的 key. 示例中使用请求地址.
可以选择 consistent 参数可以指定使用一致性哈希算法.
参考:
Using nginx as HTTP load balancer
Module ngx_http_upstream_module
总结
Nginx 是很常用的代理服务器, 它的功能非常强大, 性能也很好.
更多的资料请参考官方文档.
当前部分的代码
作为版本v0.14.0
以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持。
声明:本页内容来源网络,仅供用户参考;我单位不保证亦不表示资料全面及准确无误,也不保证亦不表示这些资料为最新信息,如因任何原因,本网内容或者用户因倚赖本网内容造成任何损失或损害,我单位将不会负任何法律责任。如涉及版权问题,请提交至online#300.cn邮箱联系删除。
Nginx代理与负载均衡详解nginx除了可以做网站的虚拟主机之外,还可以做代理器,并且,nginx在代理器的基础上可以做到负载均衡。一、代理器:所谓代理器,即
上一篇文章介绍了nginx的基本配置和使用方法,并且简单的介绍了一下如何利用nginx结合tomcat进行使用,达到反向代理的作用。现在我们要使用nginx达到
本文介绍了通过Nginx反向代理实现IP访问分流的示例代码,分享给大家。具体如下:通过Nginx做反向代理来实现分流,以减轻服务器的负载和压力是比较常见的一种服
详解Nginx和PHP的两种部署方式的对比2种部署方式简介第一种前置1台nginx服务器做HTTP反向代理和负载均衡后面N太服务器的Nginx做Web服务,并调
一、Nginx服务器解决方法服务器使用的是Nginx,要在响应的头部添加Access-Control-Allow-Origin字段,添加方法是用add_head