nginx实现负载均衡

分类:CentOS教程 阅读:51056 次

一、准备篇:

Nginx 负载服务器:

Centos 6.2

IP:192.168.1.93

WEB服务器:

Web1:192.168.1.155

Web2:192.168.1.205

实现目的:用户访问192.168.1.93时,通过Nginx负载到WEB1和WEB2

=============================================

二、配置Nginx负载均衡服务器

配置好WEB1和WEB2的环境以及上传好程序。确保两台服务器数据保持一致!

1.1关闭Selinux

#vi /etc/selinux/config

#SELINUX=enforcing 修改为disabled

#:wq

#shutdown -r now

2.2 文件存放:

软件源代码存放位置:/usr/local/src

远吗编译安装位置:/usr/local/软件名字

2.3 下载软件包

下载 nginx(目前稳定版)

http://nginx.org/download/nginx-1.0.15.tar.gz

下载 pcre

ftp://ftp.csx.cam.ac.uk/pub/software/programming/pcre/pcre-8.30.tar.gz

下载 ngx_cache_purge(清除指定 URL 缓存,方便以后扩展配置 nginx 缓存服务器)

http://labs.frickle.com/files/ngx_cache_purge-1.5.tar.gz

2.4 安装编译工具库

#yum install -y make apr* autoconf automake curl curl-devel gcc gcc-c++
zlib-devel openssl openssl-devel pcre-devel gd kernel keyutils patch perl
kernel-headers compat* cpp glibc libgomp libstdc++-devel
keyutils-libs-devel libsepol-devel libselinux-develkrb5-devel
zlib-devel libXpm* freetype libjpeg* libpng* php-common php-gd ncurses*
libtool* libxml2 libxml2-devel patch

======================================

三、安装篇

#groupadd www #添加 www 组

#useradd -g www www -s /bin/false #创建 nginx 运行账户 www 并加入到 www,不允许 www 用户直接登录系统 cd /usr/local/src #进入安装目录

#tar zxvf ngx_cache_purge-1.5.tar.gz #解压

#tar zxvf nginx-1.0.15.tar.gz #解压

#tar zxvf pcre-8.30.tar.gz  #解压
#cd nginx-1.0.15

#./configure ?prefix=/usr/local/nginx ?without-http_memcached_module
?user=www ?user=www ?group=www ?with-http_stub_status_module
?with-openssl=/usr/
?with-pcre=/usr/local/src/pcre-8.30 ?add-module=../ngx_cache_purge-1.5 #配置
注意:?with-pcre=/usr/local/src/pcre-8.30 指向的是源码包解压的路径,而
不是安装的路径,否则会报错
#make #编译
#make install #安装
#/usr/local/nginx/sbin/nginx #启动 Nginx

设置 nginx 开启启动
#echo “/usr/local/nginx/sbin/nginx” >> /etc/rc.local

=======================================================

四、配置篇

配置Nginx

#备份 nginx 配置文件

#cp/usr/local/nginx/conf/nginx.conf /usr/local/nginx/conf/nginx.conf.bak

4.1 设置 nginx 运行账号

#vi /usr/local/nginx/conf/nginx.conf #编辑
找到 user nobody;修改为user www www; #在第一行
4.2 禁止 nginx 空主机头
#vi /usr/local/nginx/conf/nginx.conf #编辑找到 server,在上面一行添加如下内容:
##############################
server {
listen 80 default;
server_name _;
location / {

root html;
return 404;
}
location ~/.ht {
deny all;
}
}
##############################

#/usr/local/nginx/sbin/nginx -s reload #平滑重启nginx服务

这样设置好以后,空头主机访问会直接跳转到nginx404界面

4.3 添加nginx虚拟主机包含文件

#cd /usr/local/nginx/conf/ #进入 nginx 安装目录
#mkdir vhost #建立虚拟目录
#vi /usr/local/nginx/conf/nginx.conf #编辑
找到上一步添加的代码,在最后添加如下内容:include vhost/*.conf;例如:
##############################
server {
listen 80 default;
server_name _;
location / {
root html;
return 404;
}
location ~/.ht {
deny all;
}
}
include vhost/*.conf;
##############################

4.4 添加 Web 服务器列表文件
#cd /usr/local/nginx/conf/ #进入目录
#touch vhost.conf #建立文件
#vi /usr/local/nginx/conf/nginx.conf #编辑
找到上一步添加的代码,在下面添加一行
include vhost.conf;
4.5 设置 nginx 全局参数
vi /usr/local/nginx/conf/nginx.conf #编辑
worker_processes 2; # 工作进程数,为 CPU 的核心数或者两倍
events
{
use epoll; #增加
worker_connections 65535; #修改为 65535,最大连接数。
}
#############以下代码在 http { 部分增加与修改##############
server_names_hash_bucket_size 128; #增加
client_header_buffer_size 32k; #增加
large_client_header_buffers 4 32k; #增加
client_max_body_size 300m; #增加
tcp_nopush on; #修改为 on
keepalive_timeout 60; #修改为 60
tcp_nodelay on; #增加
server_tokens off; #增加,不显示 nginx 版本信息
gzip on; #修改为 on
gzip_min_length 1k; #增加
gzip_buffers 4 16k; #增加
gzip_http_version 1.1; #增加
gzip_comp_level 2; #增加
gzip_types text/plain application/x-javascript text/css
application/xml; #增加
gzip_vary on; #增加

====================================================

4.6 设置 Web 服务器列表

#cd /usr/local/nginx/conf/ #进入目录
#vi vhost.conf #编辑,添加以下代码
upstream osyunweihost {
server 192.168.1.155:80 weight=1 max_fails=2 fail_timeout=30s;
server 192.168.1.205:80 weight=1 max_fails=2 fail_timeout=30s;
ip_hash;
}
4.7 新建虚拟主机配置文件

#cd /usr/local/nginx/conf/vhost #进入虚拟主机目录
#touch vhost.conf #建立虚拟主机配置文件
#vi vhost.conf #编辑
server
{
listen 80;
server_name www.a.com bbs.a.com sns.a.com;
location /
{
proxy_next_upstream http_502 http_504 error timeout
invalid_header;
proxy_pass http://ahost;
#proxy_redirect off;
proxy_set_header Host $host;
proxy_set_header X-Forwarded-For $remote_addr;
}
log_format access ‘$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;
location /NginxStatus {
stub_status on;
access_log on;
auth_basic “NginxStatus”;
#auth_basic_user_file pwd;
}
}
:wq! #保存配置
#/usr/local/nginx/sbin/nginx -s relooad #平滑重启 nginx

==================================================

五、测试篇

域名:
www.a.com
bbs.a.com
sns.a.com
分别解析到 192.168.1.93
客户访问这三个站点的时候,Nginx 根据客户访问的ip_hash 值,负载均衡到Web1和 Web2 服务器上。

至此Nginx负载均衡配置完成。