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的环境以及上传好程序。确保两台服务器数据保持一致!
3.1关闭Selinux
#vi /etc/selinux/config
SELINUX=enforcing 修改为disabled
#:wq
#shutdown -r now
3.2 文件存放:
软件源代码存放位置:/usr/local/src
远吗编译安装位置:/usr/local/软件名字
3.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
3.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
5.1 备份 nginx 配置文件
#cp /usr/local/nginx/conf/nginx.conf /usr/local/nginx/conf/nginx.conf.bak
5.2设置 nginx 运行账号
#vi /usr/local/nginx/conf/nginx.conf #编辑
找到 user nobody;修改为user www www; #在第一行
5.3 禁止 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界面
5.4 添加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;
##############################
5.5 添加 Web 服务器列表文件
#cd /usr/local/nginx/conf/
#进入目录
#touch vhost.conf
#建立文件
#vi /usr/local/nginx/conf/nginx.conf
#编辑
找到上一步添加的代码,在下面添加一行
include vhost.conf;
5.6 设置 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; #增加
5.7 设置 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;
}
```
**5.8 新建虚拟主机配置文件**
#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负载均衡配置完成。
共有 0 条评论