高性能系列高性能反向代理服务器Nginx负载均衡实践
Posted 程序猿小秘圈
tags:
篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了高性能系列高性能反向代理服务器Nginx负载均衡实践相关的知识,希望对你有一定的参考价值。
nginx (engine x) 是一个高性能的HTTP和反向代理服务器,也是一个IMAP/POP3/SMTP服务器。Nginx是由伊戈尔·赛索耶夫为俄罗斯访问量第二的Rambler.ru站点(俄文:Рамблер)开发的,第一个公开版本0.1.0发布于2004年10月4日。
其将源代码以类BSD许可证的形式发布,因它的稳定性、丰富的功能集、示例配置文件和低系统资源的消耗而闻名。2011年6月1日,nginx 1.0.4发布。
Nginx是一款轻量级的Web 服务器/反向代理服务器及电子邮件(IMAP/POP3)代理服务器,并在一个BSD-like 协议下发行。其特点是占有内存少,并发能力强,事实上nginx的并发能力确实在同类型的网页服务器中表现较好,中国大陆使用nginx网站用户有:百度、京东、新浪、网易、腾讯、淘宝等。
于是我研究了一下nginx,反向代理,动静分离,负载均衡,这个挺好,我就开始了我的研究.
我决定用vmware搭建几个虚拟机,给他们整上centOS7,用其中的一台当代理服务器暴露出去,再安排二个虚拟机装上apche当负载均衡服务器,进行传说中高大上的分布式计算服务器集群,然后再安装二个虚拟机作mysql主从数据库,然后亲自实践一个前后端分离主从分离,动静分离的网站+APP实践.
话说从DOS时代过来的人,玩linux真他妈的好使,一点不觉得别扭,反而有一种遇到知己的感觉.
一个linux装完就几分钟,而且不占内存,轻量级.
第一步当然是下载ISO镜像啦,然后到虚拟机中新建一个20G的linux虚拟机,直接安装,到最后一步,建一个root用户密码即可,不需要建立其他二级用户,直接上ROOT开干.
第二步就是编译安装nginx了,话说这个nginx开源的真彻底,没有二进制文件给你直接运行的,要你装C的编译环境现场编译安装,一个字,酸爽.
这个虚拟机直接暴露给外网访问的,我还要搭建二台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’
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;
}
以上是关于高性能系列高性能反向代理服务器Nginx负载均衡实践的主要内容,如果未能解决你的问题,请参考以下文章