实践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主页:







Nginx Load Balancer Config

用Nginx实现负载均衡 发表于 2015 年 04 月 04 日 由 LinuxSong 由于Nginx的简单轻巧,如今越来越多的人采用Nginx当作Web服务器,Nginx除了...
  • screaming
  • screaming
  • 2016-05-19 12:50:22
  • 265

Nginx 负载均衡

1.负载均衡概览;2.代理流量到服务器组;3.选择一个负载均衡方法;4.服务器权值;5.服务器慢启动;6.开启会话持久;7.限制连接数目;8.被动的健康检测;9.主动的健康检测;10.多工作进程共享数...
  • agangdi
  • agangdi
  • 2014-11-13 21:05:04
  • 6572

使用nginx做load balance

1. 安装nginx apt-get update apt-get install nginx 2. 配置侦听端口 /etc/nginx/site-available/default  -- 修改s...
  • shengang1978
  • shengang1978
  • 2017-09-06 18:41:14
  • 540

nginx压力测试http_load

1.wget http://www.acme.com/software/http_load/http_load-12mar2006.tar.gz 2. tar zxvf http_load-12ma...
  • beiwangnull
  • beiwangnull
  • 2014-04-30 14:38:47
  • 837

使用balancer_by_lua_block做应用层负载均衡

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

利用 openresty balancer_by_lua 实现一个简单的 ip_hash upstream 调度

以下基于 OpenResty balancer_by_lua 配置指令, 利用 ngx.crc32_long 根据源地址与目的端口生成hash, 实现一个简单的 ip_hash upstream. 仅...
  • force_eagle
  • force_eagle
  • 2016-08-16 20:27:52
  • 4966

实践NGINX Load Balancing – HTTP Load Balancer

nginx是一款由俄罗斯人开发的web服务器/反向代理服务器/email服务器/负载均衡器软件,并在一个BSD-like 协议下发行,目前比较流行,最初近适用于Linux平台,目前已有Windows平...
  • fall10
  • fall10
  • 2016-09-17 15:57:37
  • 607

Nginx SSL+tomcat集群,request.getScheme() 取到https正确的协议

转自:http://feitianbenyue.iteye.com/blog/2056357 最近在做一个项目, 架构上使用了 Nginx +tomcat 集群, 且nginx下配置了SSL,tom...
  • number1killer
  • number1killer
  • 2017-09-06 11:57:53
  • 161

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

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

模拟——洛谷P3138 [USACO16FEB]负载平衡Load Balancing

https://www.luogu.org/problem/show?pid=3138 这一题你做一点预处理,然后直接枚举两条切线就好了; 很简单的一个离散; 好像也不算说明离散;#includ...
  • largecub233
  • largecub233
  • 2017-04-07 14:09:52
  • 314
收藏助手
不良信息举报
您举报文章:实践NGINX Load Balancing – HTTP Load Balancer
举报原因:
原因补充:

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