实践NGINX Load Balancing – HTTP Load Balancer

原创 2016年09月17日 15:57:37

nginx是一款由俄罗斯人开发的web服务器/反向代理服务器/email服务器/负载均衡器软件,并在一个BSD-like 协议下发行,目前比较流行,最初近适用于Linux平台,目前已有Windows平台版本,优点是资源消耗少、并发处理能力强。

具体的使用的场景参考:Nginx官方参考文档。

具体平台版本见:http://nginx.org/packages/


实验环境:

1,Win7(192.168.84.1)加虚拟机CentOS7(192.168.84.128)

2,Win7下tomcat:apache-tomcat-7.0.68,CentOS7下tomcat:apache-tomcat-7.0.70

3,CentOS7中安装Nginx版本:nginx-1.10.1


CentOS7中安装nginx-1.10.1:

我下载的是源码编译版:nginx-1.10.1.tar.gz,编译安装稳定版需要安装好gcc、gcc-c++、openssl-devel、pcre-devel、zlib-devel,并下载pcre-devel、zlib-devel的源码。

1,解压nginx源码后的目录下,执行:

./configure \
--conf-path=/etc/nginx/nginx.conf \
--error-log-path=/var/log/nginx/error.log \
--http-log-path=/var/log/nginx/access.log \
--pid-path=/var/run/nginx/nginx.pid \
--lock-path=/var/lock/nginx.lock \
--with-zlib=/home/merrick/zlib-1.2.8 \
--with-pcre=/home/merrick/pcre-8.38 \
--user=nginx \
--group=nginx \
--with-http_ssl_module \
--with-http_flv_module \
--with-http_stub_status_module \
--with-http_gzip_static_module \
--http-client-body-temp-path=/var/tmp/nginx/client/ \
--http-proxy-temp-path=/var/tmp/nginx/proxy/ \
--http-fastcgi-temp-path=/var/tmp/nginx/fcgi/ 

</pre><p></p><pre>
2,编译,安装:

[root@localhost nginx-1.10.1]# make & make install

3,启动,停止:

启动:/usr/local/nginx/sbin/nginx

停止:查到nginx主进程号后(master进程),执行kill -QUIT 主进程号



配置负载均衡:

1,配置/etc/nginx/nginx.conf(参考https://www.nginx.com/resources/admin-guide/load-balancer/):

worker_processes  1;

events {
    worker_connections  1024;
}

http {
    include       mime.types;
    default_type  application/octet-stream;

    log_format  main  '$remote_addr - $remote_user [$time_local] "$request" '
    #                  '$status $body_bytes_sent "$http_referer" '
    #                  '"$http_user_agent" "$http_x_forwarded_for"';

    #access_log  logs/access.log  main;

    sendfile        on;
    #tcp_nopush     on;

    #keepalive_timeout  0;
    keepalive_timeout  65;

    #gzip  on;
    
    upstream backend{
	
	server 192.168.84.128:8080 weight=5 max_fails=2 fail_timeout=600s;
	server 192.168.84.1:8080 weight=4 max_fails=2 fail_timeout=600s;

    }	


    server {
        listen 192.168.84.128:80;
        server_name  localhost;

        #charset koi8-r;
	access_log  logs/host.access.log  main;

        location / {
	    
     	    proxy_pass http://backend;
	    
         #   root   html;
         #   index  index.html index.htm;
        }

	location /NginxStatus {
		stub_status on;
		access_log off;
		
	}
	

        error_page   500 502 503 504  /50x.html;
        	location = /50x.html {
            	root   html;
       }}

2,启动win7下和centos7下的tomcat

3,在win7下访问centos7的80主页测试几次:

可以看到访问nginx这个代理服务器时会随机转到两个web主页:







使用balancer_by_lua_block做应用层负载均衡

首先感谢章义春大神的openresty,解决了web开发的一些痛点并简化了web开发的复杂度。 需求: 根据url的一个参数,做负载均衡,使得某一个用户总是会被分配到固定的业务服务器上处理,方便后续的...
  • lubber__land
  • lubber__land
  • 2016年11月22日 16:25
  • 2688

Web负载均衡(Load Balance)

负载均衡(Load Balance)是集群技术(Cluster)的一种应用。
  • smithdoudou88
  • smithdoudou88
  • 2014年08月29日 09:54
  • 820

flume-ng负载均衡load-balance、failover集群搭建

转自:http://blog.csdn.net/morning_pig/article/details/9093149 集群采用3台机器: [html] view plai...
  • lskyne
  • lskyne
  • 2014年07月10日 19:25
  • 8975

负载均衡(Load Balancing)学习笔记(一)

概述在分布式系统中,负载均衡(Load Balancing)是一种将任务分派到多个服务端进程的方法。例如,将一个HTTP请求派发到实际的Web服务器中执行的过程就涉及负载均衡的实现。一个HTTP请求到...
  • lihao21
  • lihao21
  • 2016年12月27日 23:42
  • 3227

Load Balancing in a Cluster (集群中的负载均衡)

Load Balancing in a Cluster This section describes the load balancing support that a WebLogic Server...
  • wonder4
  • wonder4
  • 2006年11月22日 13:34
  • 6092

openstackLoadBalance技术

http://blog.csdn.net/matt_mao/article/details/12982963
  • tycoon1988
  • tycoon1988
  • 2014年08月05日 17:26
  • 783

服务器 负载均衡 load balance

负载均衡概念 负载均衡( Load Balance LB )建立在现有网络结构之上,它提供了一种廉价有效透明的方法扩展网络设备和服务器的带宽、增加吞吐量、加强网络数据处理能力、提高网络的灵活性和可用...
  • kennyrose
  • kennyrose
  • 2012年05月11日 12:33
  • 3213

using nginx as http load balancer

使用nginx作为http负载均衡 负载均衡机制 默认的负载均衡配置 最小连接负载均衡 持久性会话 权重负载均衡 健康检查 拓展阅读 介绍负载均衡是一个通用的技术, 横跨多...
  • BeardedJ
  • BeardedJ
  • 2015年11月05日 15:34
  • 382

hbase源码分析-负载均衡过程

HBase 可以根据当前集群的负载以region为单位进行rebalance。在HMaster中,后台会起一个线程定期检查是否需要进行rebalance,线 程叫做BalancerChore。线程每隔...
  • qq234568970
  • qq234568970
  • 2016年08月22日 14:30
  • 985

OpenStack Neutron LoadBalance源码解析(一)

在OpenStackGrizzly版本中,Neutron(当时叫Quantum)组件引入了一个新的网络服务:LoadBalance(LBaaS),关于LoadBalance的框架和基础知识方面网上已经...
  • canxinghen
  • canxinghen
  • 2014年12月25日 11:12
  • 3197
内容举报
返回顶部
收藏助手
不良信息举报
您举报文章:实践NGINX Load Balancing – HTTP Load Balancer
举报原因:
原因补充:

(最多只允许输入30个字)