nginx实现负载均衡,nginx负载均衡确保两台服务器数据保


一、准备篇:

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负载均衡配置完成。

相关内容

    暂无相关文章