nginx 负载均衡实践

2017-11-25  本文已影响0人  都是一家人

好久没写文章了,因为最近在安卓上写一个小东西,写完后,我发现我们编程的实在是没什么意思.

不管你在哪个平台编程,都是调用人家提供的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库设置主从,这样一个小型分布式服务器集群就算完成了.

最后,就是要接入数据库中间件,彻底将数据库隔离开来以保安全

上一篇下一篇

猜你喜欢

热点阅读