nginx负载均衡配置

一、什么是nginx
Nginx (engine x) 是一个高性能的HTTP和反向代理web服务器.Nginx是由伊戈尔·赛索耶夫为俄罗斯访问量第二的Rambler.ru站点开发的,第一个公开版本0.1.0发布于2004年10月4日。Nginx因它的稳定性、丰富的功能集、示例配置文件和低系统资源的消耗而闻名。
Nginx是一款轻量级的Web 服务器/反向代理服务器及电子邮件(IMAP/POP3)代理服务器,在BSD-like 协议下发行。其特点是占有内存少,并发能力强,事实上nginx的并发能力在同类型的网页服务器中表现较好,中国大陆使用nginx网站用户有:百度、京东、新浪、网易、腾讯、淘宝等。
本篇博客主要介绍基于ubuntu-16.04的nginx负载均衡,如下图所示nignx作为代理服务器把一个个web服务器(常用tomcat服务器)串联起来根据一定的负载均衡策略,将客户端浏览器的请求按照配置的策略分发到每个web服务器,从而实现负载均衡提高web服务器的稳定性。
nginx负载均衡示意图
在这里插入图片描述
二、安装nginx

实验环境:
1、一台虚拟机(我这里用的是ubuntu-16.04)
2、三台tomcat服务器(web服务器)

1、下载nignx安装包
nginx官网下载nginx安装包 点击下载nginx
如图本实验使用的是nginx-1.6.3版本
在这里插入图片描述
2、安装依赖包
由于nginx是C语言开发的需要编译后使用,所以需要安装一个编译工具

apt-get install gcc
apt-get install libpcre3 libpcre3-dev
apt-get install zlib1g zlib1g-dev
#Ubuntu14.04的仓库中没有发现openssl-dev,由下面openssl和libssl-dev替代
#apt-get install openssl openssl-dev
sudo apt-get install openssl 
sudo apt-get install libssl-dev

3、安装nginx

cd /usr/local
mkdir nginx
cd nginx
#使用xftp把nginx安装包上传到 /usr/local/nginx/  目录下
tar -xvf nginx-1.6.3.tar.gz  #解压nginx安装包

在这里插入图片描述
4、编译nginx

# 进入nginx目录
cd /usr/local/nginx-1.6.3/
# 执行命令
./configure
# 执行make命令
make
# 执行make install命令
make install

在这里插入图片描述
5、启动nginx

#进入nginx启动目录
cd /usr/local/nginx/sbin
# 启动nginx
./nginx

在这里插入图片描述
这样就成功安装好了nginx。
三、配置负载均衡
1、官网负载均衡模板介绍
nginx官网负载均衡模块配置模块地址:
http://nginx.org/en/docs/http/ngx_http_upstream_module.html
在这里插入图片描述
如图官网上关于负载均衡配置的例子模板已经给出,我们只需要稍作修改就可以了。
2、配置负载均衡
配置负载均衡我们只需要对nginx.conf文件进行修改就可以了,如下图修改 /usr/local/nginx/conf 目录下的nginx.conf就可以实现负载均衡了。
在这里插入图片描述
官网上给的负载均衡配置的例子upstream就是对应的web服务器群

upstream backend {
    server backend1.example.com       weight=5;
    server backend2.example.com:8080;
    server unix:/tmp/backend3;

    server backup1.example.com:8080   backup;
    server backup2.example.com:8080   backup;
}

server {
    location / {
        proxy_pass http://backend;
    }
}

如下图,把web服务器的IP地址+端口号写在upstream模块中就想到于形成了一个web服务器群(这里是按照权重配置的),如图表示当用户每请求www.studynginx.com对应的ip(在/etc/ 目录下的hosts文件中已经配置域名-ip映射)时,nginx作为反向代理服务器会把请求按照6:4:3的比例分发到端口号为8080、8081、8082三台web服务器上,从而实现负载均衡。
在这里插入图片描述

四、负载均衡策略

1.轮询(默认)
每个请求按时间顺序逐一分配到不同的后端服务器,如果后端服务器down掉,能自动剔除。

upstream backserver {
server 100.100.100.101:81;
server 100.100.100.102:82;
server 100.100.100.103:83;
}

2、指定权重
weight和访问比率成正比,weight值越大访问率越高,用于后端服务器性能不均的情况(后端服务器的性能越强其权重越大,访问的概率也就越大,反之则相反)。

upstream backserver {
server 100.100.100.101:81 weight=6;
server 100.100.100.102:82 weight=4;
server 100.100.100.103:83 weight=3  backup;
}

3、IP绑定 ip_hash
每个请求按访问ip的hash结果分配,这样每个客户端(同一个IP地址)固定访问一个后端服务器,即一个客户端只能被指定分发到一台web服务器上,解决会话保持问题。(session问题)

upstream backserver {
ip_hash;
server 100.100.100.101:81;
server 100.100.100.102:82;
server 100.100.100.103:83;
}

4、fair(第三方)
按后端服务器的响应时间来分配请求,响应时间短的优先分配。后端服务器响应快的优先分配请求,反之则相反。

upstream backserver {
server 100.100.100.101:81;
server 100.100.100.102:82;
server 100.100.100.103:83;
fair;
}

5、url_hash(第三方)
按访问url的hash结果来分配请求,每个url经过hash之后会得到一个值,这个值对应相应的后端服务器。(例如:hash(url)=0 -> A后端服务器,hash(url)=1 -> B后端服务器,hash(url)=2 -> C后端服务器 …)这样就使每个url定向到同一个后端服务器(同一个url hash之后得到相同的hash值),后端服务器为缓存时比较有效。

upstream backserver {
server 100.100.100.101:81;
server 100.100.100.102:82;
server 100.100.100.103:83;
hash $request_uri;
hash_method crc32;
}
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值