nginx负载均衡的4中配置策略
nginx的upstream目前支持4种方式的分配:
1、轮询(默认)
每个请求按时间顺序逐一分配到不同的后端服务器,如果后端服务器down掉,能自动剔除。
2、weight
指定轮询几率,weight和访问比率成正比,用于后端服务器性能不均的情况。
例如:
upstream tomcats {
server 10.1.1.107:88 weight=10 ;
server 10.1.1.132:80 weight=10 ;
}
3、ip_hash
每个请求按访问ip的hash结果分配,这样每个访客固定访问一个后端服务器,可以解决session的问题。
例如:
upstream tomcats {
ip_hash;
server 10.1.1.107:88;
server 10.1.1.132:80;
}
4、fair(第三方)
按后端服务器的响应时间来分配请求,响应时间短的优先分配。
5、url_hash(第三方)
按访问url的hash结果来分配请求,使每个url定向到同一个后端服务器,后端服务器为缓存时比较有效。
安装nginx版本为0.8.36
一。下载nginx
将该下载包拷贝到/usr/local/下(随意了,找个地方就好)
二。安装
cd /usr/local/
tar zxvf nginx-0.8.36.tar.gz
cd nginx-0.8.36
按照一些网络资料的介绍,执行如下命令即可完成安装
./configure
make
make install
但在实际安装过程中会,执行./configure时,根据系统的配置不同会有不同的错误提示,这里不罗嗦了,安装nginx需要安装openssl和 pcre,
openssl在linux下svn的安装中有过介绍,这里不再赘述,下面只介绍一下pcre的安装,如下:
下载pcre:http://sourceforge.net/projects/pcre/files/ ,选择pcre-8.02.tar.gz,拷贝到/usr/local/下
tar -zxvf pcre-8.02.tar.gz
cd pcre-8.02
./configure --prefix=/usr/local/pcre
make
make install
ok,pcre安装完成
接着我们安装nginx,
cd /usr/local/nginx-0.8.36
./configure --prefix=/usr/local/nginx --with-pcre=/usr/local/pcre-8.02 --with-http_ssl_module --with-openssl=/usr/local/openssl-0.9.8o
make
make install
ok,nginx安装完成。
三。配置
修改 /usr/local/nginx/conf/nginx.conf 来满足自己的需求,下面给一个负载的小实例
- user nginx;#确保存在这个用户
- worker_processes 2;
- error_log /var/log/nginx/error.log info;#确保路径存在
- pid logs/nginx.pid;
- events {
- worker_connections 1024;
- multi_accept on;
- use epoll;
- }
- 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 /var/log/nginx/access.log main;
- sendfile on;
- #tcp_nopush on;
- keepalive_timeout 30;
- #gzip on;
- server_names_hash_bucket_size 128;
- upstream tomcats {
- server 192.168.0.104:8888 weight=3;
- server 192.168.2.94:8888 weight=2;
- ip_hash;
- }
- server {
- listen 80;
- charset gb2312;
- add_header test private;
- location / {
- root /usr/local/test/boss/test;
- index index.html index.htm index.jsp;
- proxy_pass http://tomcats;
- proxy_redirect off;
- proxy_set_header Host $host;
- proxy_set_header X-Real-IP $remote_addr;
- proxy_set_header X-Forwarded-For $proxy_add_x_forwarded_for;
- client_max_body_size 50m;
- client_body_buffer_size 256k;
- proxy_connect_timeout 10;
- proxy_send_timeout 15;
- proxy_read_timeout 15;
- proxy_buffer_size 4k;
- proxy_buffers 4 32k;
- proxy_busy_buffers_size 64k;
- proxy_temp_file_write_size 64k;
- }
- error_page 500 502 503 504 /50x.html;
- location = /50x.html {
- root html;
- }
- }
- }
user nginx;#确保存在这个用户 worker_processes 2; error_log /var/log/nginx/error.log info;#确保路径存在 pid logs/nginx.pid; events { worker_connections 1024; multi_accept on; use epoll; } 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 /var/log/nginx/access.log main; sendfile on; #tcp_nopush on; keepalive_timeout 30; #gzip on; server_names_hash_bucket_size 128; upstream tomcats { server 192.168.0.104:8888 weight=3; server 192.168.2.94:8888 weight=2; ip_hash; } server { listen 80; charset gb2312; add_header test private; location / { root /usr/local/test/boss/test; index index.html index.htm index.jsp; proxy_pass http://tomcats; proxy_redirect off; proxy_set_header Host $host; proxy_set_header X-Real-IP $remote_addr; proxy_set_header X-Forwarded-For $proxy_add_x_forwarded_for; client_max_body_size 50m; client_body_buffer_size 256k; proxy_connect_timeout 10; proxy_send_timeout 15; proxy_read_timeout 15; proxy_buffer_size 4k; proxy_buffers 4 32k; proxy_busy_buffers_size 64k; proxy_temp_file_write_size 64k; } error_page 500 502 503 504 /50x.html; location = /50x.html { root html; } } }
注意,这里nginx监听80端口,所以要在iptables里打开80端口。
启动nqinx:
/usr/local/nginx/sbin/nginx -c /usr/local/nginx/conf/nginx.conf
接着访问这台机器的80的端口,如果请求成功,则说明配置成功。
为了操作方便,可以自己写一个nginx命令脚本,放到/etc/init.d下,并赋予其执行权限即可,详见附件,执行方法如下:
启动:service nginx start
停止:service nginx stop
重启:service nginx reconfigure
查看状态:service nginx status
nginx升级或重新编译时平滑启动的方法:
1.执行编译nginx,并覆盖原来的路径
2.kill -USR2 旧nginx主进程号:此时会在不关闭老进程的情况下启动一个新的nginx进程
3.kill -WINCH 旧nginx主进程号:查看老的工作进程是否还在使用,不使用时就关闭,如下
4.kill -QUIT 旧nginx主进程号:关闭旧nginx主进程
相关推荐
很多nextcloud在linux和ngix环境下安装时,提供的单独nextcloud的linux配置文件因为存在空格,导致nextcloud启动失败,这个nextcloud是去空格的配置文件
安装ngix
教你如何在linux下配置nginx服务器和php的环境
在CentOS下安装Ngix服务及集群PHP、Tomcat
通过该脚本可以直接安装nginx
移动端直播后台,负责接收流,推送流
nginx部署到linuix的详细配置,如果不对自己上百度吧
本书主要分为4个部分,第1部分为基础篇,介绍了Nginx服务器的安装与配置方法;第2部分为进阶篇,重点介绍了Nginx的配置优化方法、Nginx与PHP/Ruby/Python/JSP/Perl/Memcached的结合配置方法、Nginx HTTP反向代理与...
Tool / LibraryUbuntu 16.04.3Commanddos2unixtofrodos_1.7.13+ds-2.debian.tar.xzapt
Ngix解析与实战测试
redis,redis,tomcat集群实例,tomcat-session-jar文件夹下是需要的jar包,启动nginx,redis,tomcat后在浏览器中输入http://localhost/test/test2.jsp进行测试。
ngix + mysql + php 安装包 非常方便而且简洁的绿色安装包,解决了对新手来说复杂的配置
讲解如何使用Ngix做负载均衡服务器的文档,和一些讲解如何使用Ngix的资料
nginx配置,超级详细,适合入门,nginx配置,超级详细,适合入门,nginx配置,超级详细,适合入门
nginx图片服务器配置和https配置
本资源是windows下ngix的环境配置,可以用于rtmp推流。搭配ffmpeg的使用,可将视频文件转化成rtmp网络视频流,并在vlc上进行播放
fastdfs的使用,ngix的单机部署和集群部署,ngix程序包
Nginx安装过程
同时需要注意的是1.windows下nginx配置文件中的目录请使用“/”,而不是“”做目录分隔2.windows下的nginx只有一个有效的工作进程3.win
解压后有五个文件,atomic,nginx.conf,default.conf,nginx.sh,nginx_cn.zip . 由于nginx它加入GNU计划,所以在安装nginx之前必须要先...nginx.conf,default.conf为nginx全局配置文件及子配置文件 中文注释,以便配置