文档章节

nginx简单的负载均衡配置

五大三粗
 五大三粗
发布于 2015/04/24 16:00
字数 853
阅读 28
收藏 0

今天做了一个nginx简单的负载均衡测试,在这里跟大家分享一下。如下是我的示意图:

安装nginx的步骤在我的上几篇文章里面都有,在这里介绍了。

一、下面我们看nginx的配置文件"nginx.conf”

user  www www;
worker_processes 4;
error_log  /data1/logs/nginx_error.log  crit;
pid        /usr/local/webserver/nginx/nginx.pid;
#Specifies the value for maximum file descriptors that can be opened by this process.
worker_rlimit_nofile 65535;
events
{
  use epoll;
  worker_connections 65535;
}
http
{
  include       mime.types;
  default_type  application/octet-stream;
  #charset  gb2312;

  #设定负载均衡的服务器列表 

  #weigth参数表示权值,权值越高被分配到的几率越大 
  upstream Myserver {
  server 192.168.100.100:80 weight=5 max_fails=2 fail_timeout=20s;
  server 192.168.100.200:80 weight=4 max_fails=2 fail_timeout=20s;
  }
  server_names_hash_bucket_size 128;
  client_header_buffer_size 32k;
  large_client_header_buffers 4 32k;
  client_max_body_size 8m;
  sendfile on;
  tcp_nopush     on;

  keepalive_timeout 60;
  tcp_nodelay on;
  fastcgi_connect_timeout 300;
  fastcgi_send_timeout 300;
  fastcgi_read_timeout 300;
  fastcgi_buffer_size 64k;
  fastcgi_buffers 4 64k;
  fastcgi_busy_buffers_size 128k;
  fastcgi_temp_file_write_size 128k;
  gzip on;
  gzip_min_length  1k;
  gzip_buffers     4 16k;
  gzip_http_version 1.0;
  gzip_comp_level 2;
  gzip_types       text/plain application/x-javascript text/css application/xml;
  gzip_vary on;
  #limit_zone  crawler  $binary_remote_addr  10m;
  server
  {
    listen       80;
    server_name  192.168.100.50;
    index index.html index.htm index.php;
    root  /home/www/;
    #limit_conn   crawler  20;

    # 对 ".php"的文件启用负载均衡

    location ~* .*.php$ {
    proxy_pass         http://Myserver;
    }
    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  /data1/logs/access.log  access; 
  }
}
2、后端的apache服务器基本不用配置,搭建好lamp的环境后,在apache的访问目录下新建一个"test.php"的php测试页。

#touch  test.php

#vi   test.php        //输入以下内容

<?

print   "192.168.100.100";

?>

保存退出。

(后端的两个apache服务器做相同的配置就ok!)

三、测试

在你的浏览器地址栏里面输入:http://192.168.100.50/test.php,会出现如下画面。


刷新一下浏览器会出现如下画面:

 ok!测试成功。

upstream有以下四种配置方式。我采用的是第一种。
1、 weight
指定轮询几率,weight和访问比率成正比,用于后端服务器性能不均的情况。
upstream Myserver {
server 192.168.100.100:80 weight=5 max_fails=2 fail_timeout=20s;
server 192.168.100.200:80 weight=4 max_fails=2 fail_timeout=20s;
}
2、ip_hash。当对后台动态应用服务器做负载均衡时,ip_hash指令能够将某个客户端ip的请求通过哈希算法定位到同一台后端服务器上,能够实现session共享,但是不能保证后台服务器的负载均衡。
upstream Myserver {
ip_hash
server 192.168.100.100:80 ;
server 192.168.100.200:80 ;
}
3、fair(第三方)
按后端服务器的响应时间来分配请求,响应时间短的优先分配。
upstream resinserver{
server server1;
server server2;
fair;
}
4、url_hash(第三方)
按访问url的hash结果来分配请求,使每个url定向到同一个后端服务器,后端服务器为缓存时比较有效。在upstream中加入hash语句,server语句中不能写入weight等其他的参数,hash_method是使用的hash算法
upstream resinserver{
server squid1:3128;
server squid2:3128;
hash $request_uri;
hash_method crc32;
}
tips:
upstream resinserver{#定义负载均衡设备的Ip及设备状态
ip_hash;
server 127.0.0.1:8000 down;
server 127.0.0.1:8080 weight=2;
server 127.0.0.1:6801;
server 127.0.0.1:6802 backup;
}
在需要使用负载均衡的server中增加
proxy_passhttp://resinserver/;
每个设备的状态设置为:
1.down 表示单前的server暂时不参与负载
2.weight 默认为1.weight越大,负载的权重就越大。
3.max_fails :允许请求失败的次数默认为1.当超过最大次数时,返回proxy_next_upstream 模块定义的错误
4.fail_timeout:max_fails次失败后,暂停的时间。
5.backup: 其它所有的非backup机器down或者忙的时候,请求backup机器。所以这台机器压力会最轻。

© 著作权归作者所有

五大三粗
粉丝 163
博文 2290
码字总数 4763735
作品 0
广州
程序员
私信 提问
Nginx 配置实践

nginx 一般用作请求转发,用作服务器集群的负载均衡 典型的高并发集群是 nginx+tomcat(多个) nginx可以高效处理对静态文件的请求,tomcat 负责动态请求 配置范例: #user nobody;worker_pr...

HZCoder
2016/03/29
49
0
负载均衡器技术Nginx和F5的优缺点对比

对于数据流量过大的网络中,往往单一设备无法承担,需要多台设备进行数据分流,而负载均衡器就是用来将数据分流到多台设备的一个转发器。   目前有许多不同的负载均衡技术用以满足不同的应...

Zero零_度
2015/04/17
0
2
Nginx反向代理实现负载均衡配置图解

Nginx反向代理实现负载均衡配置图解 [导读] 负载均衡配置是超大型机器需要考虑的一些问题,同时也是数据安全的一种做法,下面我来介绍在nginx中反向代理 负载均衡配置图解,大家可参考本文章...

thinkyoung
2015/01/07
0
0
Nginx学习之负载均衡fair模块

Nginx学习之负载均衡fair模块 2017-04-10 20:27 写在开始 前面对Nginx的三种负载均衡实现做了一个简单的介绍,这里分享一个第三方的负载均衡模块nginx-upstream-fair。 模块介绍 The Nginx ...

linjin200
2018/07/19
0
0
Nginx 负载均衡(简单配置)

网上看到的简单部署方案以及自己的测试,笔记一下。 一、Nginx作为负载均衡的优点 1工作在网络的7层之上,可以针对http应用做一些分流的策略,比如针对域名、目录结构,它的正则规则比HAPro...

槑槑的嫑嫑
2018/01/11
0
0

没有更多内容

加载失败,请刷新页面

加载更多

动态代理知识详解

动态代理实现的两种方式 给动态代理举个栗子:例如我们平时买笔记本电脑,很多时候都是不从厂家拿货,而是通过经销商买电脑。代理模式出现解决了生产厂家的一些问题,那么这个这个思想在我们...

我叫小糖主
34分钟前
7
0
Calendar TimeZone SimpleDateFormat

关于Calendar类的使用可参考:Java Calendar类的使用总结 获取日历(Calendar):java.util.Calendar#getInstance() 获取时区TimeZone: TimeZone.getTimeZone("GMT+00:00"); 或:TimeZone.ge......

Hzhodor
34分钟前
0
0
这 17 个 JVM 参数,高级 Java 必须掌握

前言 大家都知道,jvm在启动的时候,会执行默认的一些参数。一般情况下,这些设置的默认参数应对一些平常的项目也够用了。但是如果项目特别大了,需要增加一下堆内存的大小、或者是系统老是莫...

编程SHA
40分钟前
0
0
jenkins配置自动发送邮件

1.开通QQ的SMTP服务,需要发一条短信,qq会给你一个密码(不是你的QQ邮箱密码哦) 2.安装 Email Extension Plugin 插件 3.进入系统管理--系统设置 3.1按照如下图设置 首先找到 Extended E-m...

shzwork
44分钟前
0
0
网络请求异常拦截优化

目录介绍 01.网络请求异常分类 02.开发中注意问题 03.原始的处理方式 04.如何减少代码耦合性 05.异常统一处理步骤 06.完成版代码展示 好消息 博客笔记大汇总【16年3月到至今】,包括Java基础...

潇湘剑雨
49分钟前
0
0

没有更多内容

加载失败,请刷新页面

加载更多

返回顶部
顶部