Nginx反向代理实现负载均衡配置图解

Nginx反向代理实现负载均衡配置图解

 

[导读] 负载均衡配置是超大型机器需要考虑的一些问题,同时也是数据安全的一种做法,下面我来介绍在nginx中反向代理 负载均衡配置图解,大家可参考本文章来操作。 首先简单的介绍下nginx作为反向代理实现负载均衡。反向

负载均衡配置是超大型机器需要考虑的一些问题,同时也是数据安全的一种做法,下面我来介绍在nginx中反向代理 负载均衡配置图解,大家可参考本文章来操作。
首先简单的介绍下 nginx作为反向代理实现负载均衡。
反向代理方式是指以反向代理服务器来接受互联网上的连接请求,然后将请求转发给内部网络上的服务器,并将从服务器上得到的结果返回给互联网上请求连接的客户端,此时反向代理服务器对外就表现为一个服务器。让互联网上的主机通过不同的域名访问不同的内部网主机资源,使内部网主机免受外部网主机攻击,实现负载均衡和缓存功能,很大程度上减轻web服务器的负担?提高访问速度。
 
一个简单的Nginx作为反向代理实现负载均衡。
点击查看原图
就如上图所示,我简单的建了一个环境,以3台电脑(windows系统,这里是简单搭建所以用windows,建议还是用 linux系统)。
环境介绍如下:
1.Nginx服务器192.168.2.3,安装nginx作为反向代理服务器(80端口)。
2.1台电脑安装nginx+php 192.168.2.2(80端口),作为web服务器1
3.1台电脑安装 apache+php 192.168.2.8(80端口),作为web服务器2
 
(一)针对不同请求的负载均衡。
nginx仅仅处理静态页面,动态的页面(php请求)统统都交付给后台的apache来处理。也就是说,可以把我们网站的静态页面或者文件放置到nginx的目录下;动态的页面和 数据库访问都保留到后台的apache服务器上。
下面就用个例子来说明一下,分别访问html和php网页,test.html在nginx目录下,test.php在apache目录下。
修改默认的nginx.conf,大概在59~61行,去掉前面的#号,重启nginx。
 
#location ~ .php$ {#    proxy_pass   http://127.0.0.1;#}改为        location ~ .php$ {            proxy_pass   http://127.0.0.1:8080;}

分别访问,出现如下图已经能够针对不同请求访问服务器了

 
点击查看原图
这样当我们访问192.168.2.3/index.html的时候,前端的nginx会自动进行响应;当访问192.168.2.3/test.php的时候(这个时候nginx目录下根本就没有该文件),但是通过上面的设置location ~ .php$(表示 正则表达式匹配以.php结尾的文件,详情参看location是如何定义和匹配的,官网文档http://wiki.nginx.org/NginxHttpCoreModule) ,nginx服务器会自动pass给192.168.2.3的apache服务器了。该服务器下的test.php就会被自动解析,然后将test.php的结果页面返回给nginx,然后nginx进行显示。
 
 
实现多个服务器针对不同请求的负载均衡的例子:
访问静态页面test.html,最前端的nginx直接进行响应;
访问php页面test.php,192.168.2.3:8080的Apache进行响应;
访问目录phpMyAdmin下的页面的话,192.168.2.2:80 的Apache进行响应
修改原始默认的nginx.conf的server模块部分(大概在59~61行):
#location ~ .php$ {#    proxy_pass   http://127.0.0.1;#}修改为        location ^~ /phpMyAdmin/ {             proxy_pass 192.168.2.2:80 ;}        location ~ .php$ {              proxy_pass 192.168.2.3:8080 ;}
 
上面第一个部分location ^~ /phpMyAdmin/,表示不使用 正则表达式匹配(^~),而是直接匹配,也就是如果客户端访问的URL是以http://192.168.2.3/phpMyAdmin/ 开头的话(本地的nginx目录下根本没有phpMyAdmin目录),nginx会自动pass到192.168.2.2:80 的Apache服务器,该服务器对phpMyAdmin目录下的页面进行解析,然后将结果发送给nginx显示。
 
 
(二)访问同一页面的负载均衡
访问http://192.168.2.3/test.php 这个同一页面的时候,我们实现三台服务器的负载均衡(实际情况中,这两个服务器上的数据要求同步一致)。
重新配置nginx.conf,使用默认nginx.conf。
1.首先删除server下的一些配置,大概是36~46行,以下配置行删除。
 
listen       80;        server_name  localhost;#charset koi8-r;#access_log  logs/host.access.log  main;        location / {            root   html;            index  index.html index.htm;}
2.在配置文件nginx.conf的http模块中添加服务器集群server cluster的定义。
 
upstream myCluster {        server 192.168.2.3:8080 ;        server 192.168.2.2:80 ;        server 192.168.2.8:80 ;}
表示这个server cluster包含3台服务器
 
3.然后在server模块中定义负载均衡
 
location ~ .php$ {        proxy_pass http://myCluster ;         proxy_redirect off;         proxy_set_header Host $host;        proxy_set_header X-Real-IP $remote_addr;        proxy_set_header X-Forwarded-For $proxy_add_x_forwarded_for;}
 
proxy_pass http://myCluster ; 这里的名字和上面的cluster的名字相同
 
配置好后,当访问http://192.168.2.3/test.php 页面,nginx目录下根本没有该文件,但是它会自动将其pass到myCluster定义的服务器群,分别由上述的3台服务器中的一台来做处理。
点击查看原图
 
 
上面在定义upstream的时候每个server之后没有定义权重,表示两者均衡;如果希望某个更多响应的话,可以加weight
upstream myCluster {        server 192.168.2.3:8080 weight=5;        server 192.168.2.2:80 ;        server 192.168.2.8:80 ;}
 
这样表示5/7的几率访问第一个server,1/7访问第二个、第三个。另外还可以定义max_fails和fail_timeout等参数。
 
所以我们使用nginx的反向代理服务器reverse proxy server的功能,将其布置到多台apache server的前端。
nginx仅仅用来处理静态页面响应和动态请求的代理pass,后台的apache服务器来对前台pass过来的动态页面进行处理并返回给nginx。
实际应用中,各个服务器分别保留相同的程序和数据,需要考虑两者的数据同步。 

转载于:https://www.cnblogs.com/u0mo5/p/4209140.html

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
### 回答1: Nginx是一款高性能的Web服务器和反向代理服务器,可以用来处理静态文件、动态文件、HTTP请求和负载均衡等。在Linux系统中,配置Nginx反向代理可以实现多个Web服务器的负载均衡和高可用性,提高Web应用的性能和稳定性。 要配置Nginx反向代理,需要先安装Nginx软件包,并编辑Nginx配置文件。在配置文件中,需要指定反向代理的目标服务器和端口号,以及反向代理的监听端口和域名等信息。还可以配置缓存、SSL证书、HTTP头等选项,以满足不同的需求。 配置完成后,需要重新加载Nginx配置文件,使其生效。可以使用Nginx的命令行工具来检查配置文件的语法和启动、停止、重启Nginx服务。在反向代理生效后,可以通过访问Nginx的监听端口和域名来访问目标服务器上的Web应用。 总之,Nginx反向代理配置是Linux系统中Web服务器和负载均衡的重要组成部分,可以提高Web应用的性能和可用性,是Web开发人员和系统管理员必须掌握的技能之一。 ### 回答2: Nginx反向代理Nginx服务器所提供的高级功能之一,它可以将用户请求反向代理到不同的服务器上,以便在网络拓扑结构中,像隐藏真实服务器一样的方式进行访问。当客户端发起请求时,请求会首先进入Nginx服务器,然后Nginx服务器通过配置将请求转发到真实的服务器上。 反向代理可以提高网站的性能和安全性,其中之一的原因是因为它可以提供负载均衡,将流量均衡地分配到多个服务器上,从而降低单个服务器的负载压力。另外,反向代理还可以提供安全性,并通过网络分发内容来减轻网络流量,降低延迟时间。 在Linux服务器上进行Nginx反向代理配置的步骤如下: 1. 安装Nginx服务器,如果您的Linux服务器上没有安装Nginx,请使用apt-get或yum命令进行安装; 2. 配置Nginx反向代理,需要编辑Nginx配置文件nginx.conf,通过编辑upstream模块中的server列表设置真实服务器的IP地址和端口号,设置反向代理的通信协议和其他参数,如下面的示例: ``` http { upstream backend { server 192.168.1.10:80 weight=5; server 192.168.1.11:80 weight=5; } server { listen 80; server_name localhost; location / { proxy_pass http://backend; } } } ``` 上述配置文件中,我们定义了反向代理的后端服务器地址和端口号,以及设置了反向代理通信协议为http。另外,在server部分中,listen用于设置Nginx反向代理所监听的端口号,server_name用于设置使用的域名,location用于设置需要被代理的请求URL。 3. 保存并重新启动Nginx服务器,编辑结束后需要保存并退出nginx.conf,使用命令service nginx restart来重启Nginx服务器,使其立即生效。 通过以上步骤,我们就可以成功地在Linux服务器上进行Nginx反向代理配置反向代理可以提供更高效的性能和更好的安全性。这是企业网站架构中必不可少的一部分。 ### 回答3: Nginx是一个高性能的Web服务器和反向代理服务器,许多互联网公司都采用Nginx作为Web服务器来提供动态和静态Web内容。反向代理指的是客户端请求不是直接发送给资源服务器,而是通过反向代理服务器进行处理,这样可以有效提高Web服务器的性能和安全性。下面来讲一下如何在Linux系统上配置Nginx反向代理。 1. 安装Nginx 在Linux系统上安装Nginx非常简单,只需要在终端中输入以下命令: sudo apt-get update sudo apt-get install nginx 2. 配置反向代理Nginx配置文件中添加反向代理配置Nginx配置文件通常位于/etc/nginx下,我们可以编辑/etc/nginx/sites-available/default文件。具体配置如下: server { listen 80; server_name www.example.com; location / { proxy_pass http://localhost:8080; proxy_set_header Host $host; proxy_set_header X-Real-IP $remote_addr; proxy_set_header X-Forwarded-For $proxy_add_x_forwarded_for; } } 其中,listen指定监听一个端口(如80),server_name指定服务器名字(如www.example.com),location表示要代理的URL,proxy_pass指定要反向代理的服务器地址(如http://localhost:8080)。 3. 重启Nginx 在完成反向代理配置后,需要重启Nginx,执行以下命令: sudo service nginx restart 4. 配置HTTPS 如果需要在网站上使用HTTPS,需要添加SSL证书并修改Nginx配置文件。首先,使用以下命令安装SSL证书: sudo apt-get install certbot python-certbot-nginx 之后,执行以下命令以为指定域名添加SSL证书: sudo certbot --nginx -d www.example.com 最后,我们需要将Nginx配置文件中的监听80端口改为443端口,并添加SSL支持。具体的Nginx配置如下: server { listen 443 ssl; server_name www.example.com; ssl_certificate /etc/letsencrypt/live/www.example.com/fullchain.pem; ssl_certificate_key /etc/letsencrypt/live/www.example.com/privkey.pem; location / { proxy_pass http://localhost:8080; proxy_set_header Host $host; proxy_set_header X-Real-IP $remote_addr; proxy_set_header X-Forwarded-For $proxy_add_x_forwarded_for; } } 5. 重启Nginx 完成以上所有配置后,执行以下命令以重启Nginx: sudo service nginx restart 总的来说,配置Nginx反向代理并不是很复杂,只要掌握基本的配置方法并按照实际需求进行修改即可。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值