负载均衡 建立在现有网络结构之上,它提供了一种廉价有效透明的方法扩展网络设备和服务器的带宽、增加吞吐量、加强网络数据处理能力、提高网络的灵活性和可用性。(百度百科的解释)
在我看来就是防止一台服务器在承受不住大流量的访问而产生宕机时,解决宕机的一种方案。也就是利用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看看会不会分配到主服务器上。
参考别人教程,再结合自己的总结,综合而成!