前言:
如今信息时代,对于web服务器的要求很高,既要性能,又要稳定性,又经济最好免费,还要满足公司的各大奇葩业务需求,越来越挑剔,就像你去买手机,中意的是外观好看,功能强大,拍照清晰,存储大,不死机不闪退,充电快,质量好能当‘砖头’使,操作简单顺手,价格便宜,最主要看电影玩游戏爽,总之使用起来要爽,哈哈。。。 互联网上主流的web服务器有 nginx, Apache, Squid, IIS, kangle, WebSphere, WebLogic, Tomcat, Jboss, TrafficServer等等, 我玩过的就nginx,Apache, TrafficServer三款,其它不熟, Apache由于不可扩展,不可定制,固满足不了公司一些需求,TrafficServer 开源产品 c++编写,功能强大,可搭建集群,国人用得不多,知道的人也不多,大公司在用(阿里),小公司用不起,bug太多,难维护, Nginx现在用的人越来越多,优点如下:
1.模块化的功能集,第三方模块丰富,占用资源小,稳定性强,
2.可扩展性强,官方文档资料全,安装配置简单,官方代码贡献者活跃,不断有更新,
3.Nginx从头开始都是纯C实现,采用多进程和异步机制(异步非阻塞),内存消耗极小,官方统计,单台能达到50000并发请求量。
4.支持负载均衡,跨平台,能满足公司很多需求。
笔者的系统centos6.5
首先装好linux系统 ,此处略。
nginx: 192.168.4.72 #nginx安装的位置及apache位置
apache: 192.168.4.69 #要代理的两台服务器
apache: 192.168.4.68
一、安装gcc
yum install gcc-c++ -y
二、安装nginx所需要的依赖库
yum -y install zlib-devel openssl-devel pcre-devel
三、如有安装老版本,则卸载。
查看:find -name nginx
卸载:yum remove nginx
四、下载nginx源码并解压.(源码去官网下载, 以下是官方链接)
wget -c http://nginx.org/download/nginx-1.6.2.tar.gz
tar -zxvf nginx-1.6.2.tar.gz
mv nginx-1.6.2 nginx
cd nginx
./configure --user=nginx --group=nginx --prefix=/usr/local/nginx
--with-http_addition_module
--with-http_flv_module --with-http_gzip_static_module
--with-http_realip_module --with-http_ssl_module
--with-http_stub_status_module --with-http_sub_module
--with-http_dav_module
注:这里--with开头的选项为nginx自带的模块,需要什么就添加,默认是不安装,
make
make install
五、建立nginx用户及用户组
vim /usr/local/nginx/conf/nginx.conf
user nginx nginx; #这里是nginx运行的用户
worker_processes 2; #设置nginx服务的worker子进程,比如设为2:
error_log logs/error.log; #去掉前面的#,记录nginx错误日志,方便检查bug:
pid logs/nginx.pid; #nginx的pid位置
http {
include mime.types;
default_type application/octet-stream;
#把下面的#去掉,这是日志配置:
log_format main '$remote_addr - $remote_user [$time_local] "$request" '
'$status $body_bytes_sent "$http_referer" '
'"$http_user_agent" "$http_x_forwarded_for"';
access_log logs/access.log main; #日志存放位置
#这里很关键,很多小伙伴问我 “负载均衡乍配置,为啥我配置的不能访问呢“,这里的upstream就是配置负载均衡的,当然得两台以上才叫负载,我这里的ip69和68都是
#用的apache, 也许你们的是tomcat, 没关系,按这样配置一样可以,
upstream proxy_test {
server 192.168.4.69:80 weight=1; #如果你要测试,把这里换成你自己要代理后端的ip
server 192.168.4.68:80 weight=1;
#ip_hash; #当负载两台以上用ip来hash解决session的问题,一台就别hash了。
}
这是server段的配置
server {
listen 80;
server_name www.test.com; #要访问的域名,我这里用的测试域名,如果有多个,用逗号分开
charset utf8;
location / {
proxy_pass http://proxy_test; #这里proxy_test是上面的负载的名称,映射到代理服务器,可以是ip加端口, 或url
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平滑重启:nginx -s reload #加载刚刚加入的配置。
七、测试:
后端服务器开启,在192.168.4.69和68的网页文件位置添加测试文件test.html, 内容69上: this is test 69, 68上:this is test 68,这样方便查看访问到哪台了。
在本地配置好host,在\Windows\System32\drivers\etc\hosts 用记事本打开,在最后一行加入:192.168.4.72 www.test.com
然后使用cmd,ping www.test.com 是否能ping通这个192.168.4.72地址,如果ok,则继续
打开浏览器用www.test.com去访问后端服务器的文件,
如: www.test.com/test.html,
浏览器打开显示有this...说明配置ok了。
然后F5刷新一下,如果是68和69不停的切换,说明负载ok了。
如果还有什么不懂的,加我们的技术群解答(284215611)