使用Nginx轻松实现开源负载均衡

上传人:飞*** 文档编号:52160199 上传时间:2018-08-18 格式:PPT 页数:24 大小:540.50KB
返回 下载 相关 举报
使用Nginx轻松实现开源负载均衡_第1页
第1页 / 共24页
使用Nginx轻松实现开源负载均衡_第2页
第2页 / 共24页
使用Nginx轻松实现开源负载均衡_第3页
第3页 / 共24页
使用Nginx轻松实现开源负载均衡_第4页
第4页 / 共24页
使用Nginx轻松实现开源负载均衡_第5页
第5页 / 共24页
点击查看更多>>
资源描述

《使用Nginx轻松实现开源负载均衡》由会员分享,可在线阅读,更多相关《使用Nginx轻松实现开源负载均衡(24页珍藏版)》请在金锄头文库上搜索。

1、使用Nginx轻松实现开源负载均衡张宴(http:/)2008.9.20 北京个人简介 张宴,曾在新浪等公司任系统工程师、系统架构 师。工作内容主要涉及:服务器系统架构设计与 部署、系统运维与调优、网络故障解决、网站后 端以及接口类PHP程序开发、Unix开源软件二次开 发、服务器监控系统开发等。具有CDN部署,跨 IDC的数据传输,电信网通南北互通,以及门户类 FLV视频分享网站新浪播客架构设计经验。什么是Nginx? Nginx (“engine x”) 是俄罗斯人Igor Sysoev(塞 索耶夫)编写的一款高性能的 HTTP 和反向代理服务 器。 Nginx 已经在俄罗斯最大的门户网站

2、 Rambler Media(www.rambler.ru)上运行了3年时间,同时 俄罗斯超过20%的虚拟主机平台采用Nginx作为反向 代理服务器。 在国内,已经有 新浪博客、新浪播客、网易新闻、 六间房、、Discuz!、水木社区、豆瓣、 YUPOO、海内、迅雷在线 等多家网站使用 Nginx 作 为Web服务器或反向代理服务器。使用Nginx做七层负载均衡的理由 1、高并发连接:官方测试能够支撑5万并发连 接,在实际生产环境中跑到23万并发连接数 。 2、内存消耗少:在3万并发连接下,开启的10 个Nginx 进程才消耗150M内存(15M*10=150M )。 3、配置文件非常简单:风

3、格跟程序一样通俗 易懂。 4、成本低廉:Nginx为开源软件,可以免费使 用。而购买F5 BIG-IP、NetScaler等硬件负载 均衡交换机则需要十多万至几十万人民币。使用Nginx做七层负载均衡的理由 5、支持Rewrite重写规则:能够根据域名、 URL的不同,将 HTTP 请求分到不同的后端 服务器群组。 6、内置的健康检查功能:如果 Nginx Proxy 后端的某台 Web 服务器宕机了,不 会影响前端访问。 7、节省带宽:支持 GZIP 压缩,可以添加 浏览器本地缓存的 Header 头。 8、稳定性高:用于反向代理,宕机的概率 微乎其微。Nginx 负载均衡的典型应用 硬件、

4、软件七层 负载均衡对比: NetScaler 与 Nginx硬件、软件七层 负载均衡对比: NetScaler 与 Nginx五分钟搞定 Nginx 负载均衡编译安装Nginx1、创建供Nginx使用的组和帐号: /usr/sbin/groupadd www -g 48 /usr/sbin/useradd -u 48 -g www www2、编译安装rewrite模块支持包 wget ftp:/ftp.csx.cam.ac.uk/pub/software/programming/pcre/pcre- 7.7.tar.gz tar zxvf pcre-7.7.tar.gz cd pcre-7.7

5、/ ./configure make worker_processes 8;error_log /usr/local/nginx/logs/nginx_error.log crit; pid /usr/local/nginx/logs/nginx.pid;worker_rlimit_nofile 51200; events use epoll;worker_connections 51200; 创建nginx.conf配置文件(2)http include mime.types;default_type application/octet-stream;#charset gb2312;serv

6、er_names_hash_bucket_size 128;client_header_buffer_size 32k;large_client_header_buffers 4 32k;sendfile on;tcp_nopush on;keepalive_timeout 60;tcp_nodelay on;创建nginx.conf配置文件(3)#gzip on;#gzip_min_length 1k;#gzip_buffers 4 16k;#gzip_http_version 1.0;#gzip_comp_level 2;#gzip_types text/plain application

7、/x-javascript text/css application/xml;#gzip_vary on;创建nginx.conf配置文件(4)upstream server 192.168.1.10:80;server 192.168.1.11:80;server 192.168.1.12:80;server 192.168.1.13:81;upstream server 192.168.1.20:80 weight=3;server 192.168.1.21:80;server 192.168.1.22:80;创建nginx.conf配置文件(5)serverlisten 80;ser

8、ver_name *;proxy_redirect off;#后端的Web服务器可以通过X-Forwarded-For获取用户真实IPproxy_set_header X-Forwarded-For $remote_addr;if ($request_uri * “.*.(js|css|gif|jpg|jpeg|png|bmp|swf)$“)proxy_pass http:/;if ($request_uri * “/view/(.*)$“)proxy_pass http:/;proxy_pass http:/;创建nginx.conf配置文件(6)#定义日志格式log_format acc

9、ess $remote_addr - $remote_user $time_local $request “$status“ $body_bytes_sent “$http_referer“ “$http_user_agent“ “$http_x_forwarded_for“;#打日志access_log /usr/local/nginx/logs/access.log access;创建nginx.conf配置文件(7)#允许客户端请求的最大的单个文件字节数client_max_body_size 10m;#缓冲区代理缓冲用户端请求的最大字节数 可以理解为先保存到本地再传给用户client_

10、body_buffer_size 128k;#跟后端服务器连接的超时时间_发起握手等候响应超时时间proxy_connect_timeout 600;#连接成功后_等候后端服务器响应时间_其实已经进入后端的排队之中等候处理proxy_read_timeout 600;#后端服务器数据回传时间_就是在规定时间之内后端服务器必须传完所有的数 据proxy_send_timeout 600;创建nginx.conf配置文件(8)#代理请求缓存区_这个缓存区间会保存用户的头信息以供Nginx进行规则处理_ 一般只要能保存下头信息即可proxy_buffer_size 8k;#同上 告诉Nginx保存单

11、个用的几个Buffer 最大用多大空间proxy_buffers 4 32k;#如果系统很忙的时候可以申请更大的proxy_buffers 官方推荐*2proxy_busy_buffers_size 64k;#proxy缓存临时文件的大小proxy_temp_file_write_size 64k; 配置文件编写完毕启动Nginx/usr/local/nginx/sbin/nginx t如果屏幕显示以下两行信息,说明配置文件正确: the configuration file /usr/local/nginx/conf/nginx.conf syntax is ok the configura

12、tion file /usr/local/nginx/conf/nginx.conf was tested successfully那么,则可以启动Nginx服务:ulimit -SHn 51200 /usr/local/nginx/sbin/nginx不中断服务平滑修改Nginx配置、修改/usr/local/nginx/conf/nginx.conf配置文件后,请执行以下命令检查配 置文件是否正确: /usr/local/nginx/sbin/nginx -t 如果屏幕显示以下两行信息,说明配置文件正确: the configuration file /usr/local/nginx/co

13、nf/nginx.conf syntax is ok the configuration file /usr/local/nginx/conf/nginx.conf was tested successfully、这时,输入以下命令查看Nginx主进程号: ps -ef | grep “nginx: master process“ | grep -v “grep“ | awk -F print $2 屏幕显示的即为Nginx主进程号,例如: 6302 这时,执行以下命令即可使修改过的Nginx配置文件生效: kill -HUP 6302或者用更简便的方法: kill -HUP cat /usr

14、/local/nginx/logs/nginx.pid编写每天定时切割Nginx日志的脚本1、创建脚本/usr/local/nginx/sbin/cut_nginx_log.sh,输入以下内容: #!/bin/bash # This script run at 00:00# The Nginx logs path logs_path=“/usr/local/nginx/logs/“mkdir -p $logs_path$(date -d “yesterday“ +“%Y“)/$(date -d “yesterday“ +“%m“)/ mv $logs_pathaccess.log $logs_

15、path$(date -d “yesterday“ +“%Y“)/$(date -d “yesterday“ +“%m“)/access_$(date -d “yesterday“ +“%Y%m%d“).log kill -USR1 cat /usr/local/nginx/logs/nginx.pid2、设置crontab,每天凌晨00:00切割nginx访问日志 crontab -e 输入以下内容: 00 00 * * * /bin/bash /usr/local/nginx/sbin/cut_nginx_log.sh总结1、对于中、小型企业,如果没有资金去购买昂贵的四/七层负载均衡交换机,那么 Nginx是不错的七层负载均衡选择,并且可以通过 Nginx + Keepalived 实现 Nginx 负载均衡器双机互备,任意一台机器发生故障,对方都能够将虚拟IP接管 过去。2、对于有资金购买四/七层负载均衡交换机的大型网站,Nginx也有其用武之地。以 门户类网站为例, F5 BIG-IP等四/七层交换机由于负责了全站多个产品的服务 ,并发数非常高,而内容转发规则等七层交换业务,用不到F5 BIG-IP

展开阅读全文
相关资源
正为您匹配相似的精品文档
相关搜索

最新文档


当前位置:首页 > 行业资料 > 其它行业文档

电脑版 |金锄头文库版权所有
经营许可证:蜀ICP备13022795号 | 川公网安备 51140202000112号