nginx 负载均衡实践
好久没写文章了,因为最近在安卓上写一个小东西,写完后,我发现我们编程的实在是没什么意思.
不管你在哪个平台编程,都是调用人家提供的API,现在开源时代,什么都有现成的,程序员满街都是,我想搞点提神醒脑的玩意.
于是我研究了一下nginx,反向代理,动静分离,负载均衡,这个挺好,我就开始了我的研究.
我决定用vmware搭建几个虚拟机,给他们整上centOS7,用其中的一台当代理服务器暴露出去,再安排二个虚拟机装上apche当负载均衡服务器,进行传说中高大上的分布式计算服务器集群,然后再安装二个虚拟机作mysql主从数据库,然后亲自实践一个前后端分离主从分离,动静分离的网站+APP实践.
话说从DOS时代过来的人,玩linux真他妈的好使,一点不觉得别扭,反而有一种遇到知己的感觉.
一个linux装完就几分钟,而且不占内存,轻量级.
第一步当然是下载ISO镜像啦,然后到虚拟机中新建一个20G的linux虚拟机,直接安装,到最后一步,建一个root用户密码即可,不需要建立其他二级用户,直接上ROOT开干.
第二步就是编译安装nginx了,话说这个nginx开源的真彻底,没有二进制文件给你直接运行的,要你装C的编译环境现场编译安装,一个字,酸爽.
装好之后,启动nginx,啥也不做,直接在虚拟机中即可访问到127.0.0.1,说明80端口成功开始监听http服务了,nginx开始运作了.不过我的目的不是在linux上访问,而是在外网访问,起码我的真实主机和家里的手机,其他电脑也要能访问啊,为了达到这一步,运行了各种奇怪的linux命令,配置了半天网络,还整了个静态IP,最后在vmware中设置80端口转发到虚拟机IP地址80端口,这样不管是手机还是其他电脑,输入局域网IP,即可访问到虚拟机中的nginx的欢迎主页.
这个虚拟机直接暴露给外网访问的,我还要搭建二台apache服务器,用来负载均衡.安装centOS的过程是一模一样的,不同点在于第一台只需安装nginx,后二台安装的却是apache+PHP,用来解析PHP代码,提供给nginx访问.
安装apache倒是顺利,但也在启动啊,防火墙等地方费了不少精神,因为说什么centOS版本太高,以前的/etc/init.d/下面没有iptables这个服务,为这个iptables搞了很长的时间,关于iptables的一些命令,一会能运行,一会不能运行的,真是坑的很.
于第二天的时候,我把这个虚拟机给删除了,用了原生的systemctl来管理服务,用了firewalld来管理防火墙,毕竟iptables这个是过时了,必须与时俱进.
然后还要安装ftp服务器
yum install vsftpd
firewalld开启80 21端口后,就能在外网进行访问了
firewall-cmd --add-service=ftp --permanent ##永久开放ftp服务
firewall-cmd --remove-service=ftp --permanent ##永久移除ftp服务
firewall-cmd --add-port=80/tcp --permanent ##永久添加80端口
然后用systemctl重启防火墙
sytemctl restart firewalld
新版本centos主意是要注意二点,一个是系统服务管理变成了systemctl,就不要再用旧的service命令了,尽量只用新的,混着用容易拉低咱们的智商.
第二个是防火墙不是iptables了,变成了用firewalld服务,用firewall-cmd命令来管理,习惯就好,有些教程他妈的一上来就删除firewalld,重新安装iptables,这都是一些不思进取的废物,千万不要学这些行为.
我们一定要擦亮眼睛,不要人云亦云.
接下来,输入命令 yum install php php-devel -y 全自动安装PHP5.4,而且安装完是即时生效的,不用像windows中配置什么路径乱七八糟的.
为保险起见,还是重启httpd服务,systemctl restart httpd
apache安装后,网页文件存放在 /var/www/html中,在这个目录中建一个index.php文件,里面输入
<?php phpinfo(); ?>保存,打开即可以看到效果了.
我目前的配置是这样的,在真正的主机上输入localhost,经vmware的端口转发到虚拟机nginx上,然后nginx做负载均衡转发到二台apache虚拟机上.
所以我在真实主机上输入localhost即可看到虚拟机中的网页显示效果了.
这只是用虚拟机在模拟负载均衡,如果有钱,咱们直接在家里就能建数据中心了,全部是真实的主机,那就爽歪歪了.
咱们可以安装一个apache下的压力测试工具来测试下性能
yum install httpd-tools -y
进行测试:模拟1000个用户发送20000个请求
ab -n 20000 -c 1000 http://localhost/test.php
发现效果还不错,90%的请求能在130ms内响应,一秒能处理2000+并发
现在是有三个虚拟机了,还差二个用来放mysql,继续建呗
这两台比较单一,就是安装mysql后,新建用户并给予远程登录的权限,开启3306端口
create user‘name’@’192.168.*.*|%’identified by‘pwd’
GRANT ALL PRIVILEGES ON 数据库名.* TO '用户名'@'ip地址' IDENTIFIED BY '密码' WITH GRANT OPTION;
FLUSH PRIVILEGES; //更新授权
firewall-cmd --add-port=3360/tcp --permanent
现在跑到主机上远程连接测试,成功!
接下来,要设置第一台虚拟机nginx动静分离了
编辑nginx.conf文件,增加location路由
location / --->首先全部导入apache服务器
location ~* \.(png|jpg|bmp|webp|js|css)$ {
root html/web1/; #nginx的根是/usr/local/nginx/html,这里将静态资源的请求全部发往web1目录下取
#也就是thinkphp的Public目录被上传到了web1下了
expires 3d;
}
现在,我将关闭其中的一台apache服务器,因为我要安装我的php网站了,而安装过程只需在其中一台上安装即可,也就是配置mysql的地址帐号密码等信息,并不需要二台同时安装,安装一台后,直接把安装过后的网站文件全站复制到另一台apache服务器中即可.
这个过程就不写了,没什么技术含量
完成后,在主机输入localhost成功进入网站页面,而且是真的动静分离+负载均衡了!
接下来要做的事,就是将mysql库设置主从,这样一个小型分布式服务器集群就算完成了.
最后,就是要接入数据库中间件,彻底将数据库隔离开来以保安全