Nginx负载均衡简单实例

负载均衡 建立在现有网络结构之上,它提供了一种廉价有效透明的方法扩展网络设备和服务器的带宽、增加吞吐量、加强网络数据处理能力、提高网络的灵活性和可用性。(百度百科的解释)
在我看来就是防止一台服务器在承受不住大流量的访问而产生宕机时,解决宕机的一种方案。也就是利用N台服务器来平均分担主服务器的流量,将流量转向到其他服务器。


Nginx安装教程(https://lnmp.org/install.html

实验环境

由于没有实体的服务器,所以本次实验直接在VMware虚拟机里安装了三台服务器

1、硬件:

I5-CPU
16G的内存(虚拟机里的服务器开启的越多,占用的内存越多)

2、软件:

VM_12
CentOS_7
Nginx

3、配置安排

实验域名:long.com
A服务器IP:192.168.7.240(主)
B服务器IP:192.168.7.237(从)
C服务器IP:192.168.7.231(从)


部署安排:

A服务器为主服务器,域名直接解析在该服务器上;访问long.com之后,由A服务器负载均衡到B服务器和C服务器上。

1、域名解析:

打开hosts文件
vi /etc/hosts
末尾添加
192.168.7.240 long.com
保存退出,然后使用 ping long.com 测试是否设置成功

2、A服务器的nginx.conf设置

获取 nginx.conf 路径
ps aux | grep nginx
打开 nginx.conf 文件
vi /usr/local/nginx/conf/nginx.conf

在http段添加以下代码
upstream long.com { server 192.168.7.237:80; server 192.168.7.231:80; } server{ listen 80; server_name long.com; location / { proxy_pass http://long.com; proxy_set_header Host $host; proxy_set_header X-Real-IP $remote_addr; proxy_set_header X-Forwarded-For $proxy_add_x_forwarded_for; } }
注意:可用 nginx -t -c /usr/local/nginx/conf/nginx.conf测试nginx.conf配置文件是否正确
保存并重启nginx服务器

3、B、C服务器的nginx.conf设置

打开 nginx.conf,在http段加入以下代码。
server{ listen 80; server_name long.com; index index.html; root /home/wwwroot/default; }
保存并重启nginx 之后分别在B、C服务器的 /home/wwwroot/default(这是我的Nginx服务器的访问文件存放目录) 目录下写一个不同内容的index.html文件,以作区分。

4、测试

在A服务器中输入命令 curl long.com 可得在B或C服务器添加的index.html文件内容
完成以上操作,可实现long.com的负载均衡


以上例子中,我们都是应用到了主服务器负载均衡到其它服务器上,那么主服务器本身能不能也加在服务器列表中,这样就不会白白浪费一台纯当做转发功能的服务器。
现在我们让A服务器也提供站点服务。
首先我们先来分析一下,如果添加主服务器到upstream中,那么可能会有以下两种情况发生:
1、主服务器转发到了其它IP上,其它IP服务器正常处理;
2、主服务器转发到了自己IP上,然后又进到主服务器分配IP那里,假如一直分配到本机,则会造成一个死循环。

怎么解决这个问题呢?

因为80端口已经用来监听负载均衡的处理,那么本服务器上就不能再使用80端口来处理long.com的访问请求,要用一个新的端口 8080。于是我们把主服务器的 nginx.conf 加入以下一段代码:
server { listen 8080; server_name long.com; index index.html index.htm index.php; root /home/wwwroot/default; }
注意:添加之后,应该有两个 server
重启 nginx 之后输入 curl long.com:8080 验证A服务器是否能访问
能正常访问,那么我们就可以把主服务器添加到upstream中,但是端口要改一下,如下代码:
upstream long.com { server 192.168.7.237:80; server 192.168.7.231:80; server 127.0.0.1:8080; }
这里可以添加主服务器IP192.168.7.240或者127.0.0.1均可以,都表示访问自己。
重启Nginx,然后再来访问long.com看看会不会分配到主服务器上。

参考别人教程,再结合自己的总结,综合而成!

最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
平台声明:文章内容(如有图片或视频亦包括在内)由作者上传并发布,文章内容仅代表作者本人观点,简书系信息发布平台,仅提供信息存储服务。

推荐阅读更多精彩内容

  • 负载均衡是我们大流量网站要做的一个东西,下面我来给大家介绍在Nginx服务器上进行负载均衡配置方法,希望对有需要的...
    owen_he阅读 459评论 0 0
  • Spring Cloud为开发人员提供了快速构建分布式系统中一些常见模式的工具(例如配置管理,服务发现,断路器,智...
    卡卡罗2017阅读 135,248评论 19 139
  • 1 负载均衡 先来简单了解一下什么是负载均衡,单从字面上的意思来理解就可以解释N台服务器平均分担负载,不会因...
    尾巴哥de日常阅读 989评论 0 3
  • 闹市听得到山羊的叫声 水里看得见杜鹃在游泳 草鞋在地板上行走 桌子在房间里唱歌 我拿着笔写未完成的故事 故事里你是...
    二向箔倩阅读 308评论 0 4
  • 我是沈非,我在简书。 管先生是一位上市企业的财务总监,并且是元老级别的那种,洞悉了企业里所有所有的一切,能见光的,...
    中雨工作室阅读 23,595评论 12 14