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

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

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值