Nginx负载均衡-day

1 Nginx负载均衡实战

  Nginx的负载均衡可以用自带的upstream模块完成,本身还自带健康检查,非常简单。不但可以负载web,还可以负载fastcgi、memcached,功能非常强大

  1.1 环境准备

#需要准备四台服务器、LB01、LB02、RS01、RS02
LB01:
    ip:
        eth0:172.16.50.1
        eth1:10.0.0.1
LB02:
    ip:
        eth0:172.16.50.2
        eth1:10.0.0.2
RS01:
    ip:
        eth0:10.0.0.80
RS01:
    ip:
        eth0:10.0.0.80

2 配置RS节点

  要为集群配置后端真实服务器,也就是节点服务器

  2.1 RS01

1、安装Nginx
http://www.cnblogs.com/wazy/p/8108824.htm #两台都要装

2、配置
[[email protected] ~]# echo "1" >/usr/local/nginx/html/index.html

3、启动
[[email protected] html]# /usr/local/nginx/sbin/nginx
#测试是否能正常访问

  2.2 RS02

1、安装Nginx
http://www.cnblogs.com/wazy/p/8108824.html #两台都要装

2、配置
[[email protected] ~]# echo "2" >/usr/local/nginx/html/index.html

3、启动
[[email protected] html]# /usr/local/nginx/sbin/nginx
#测试是否能正常访问

  2.3 策略

#后端服务器只允许调度器访问80端口

#这里负载均衡开启80端口
#web后端只对负载开启80端口
-A INPUT -s 192.168.1.1/32 -m tcp -p tcp --dport 8080:8083 -j ACCEPT
-A INPUT -s 192.168.1.2/32 -m tcp -p tcp --dport 8080:8083 -j ACCEPT
#centos6

firewall-cmd --permanent --add-rich-rule ‘rule family=ipv4 source address=192.168.1.1 port port=8080 protocol=tcp accept‘
firewall-cmd --permanent --add-rich-rule ‘rule family=ipv4 source address=192.168.1.1 port port=8081 protocol=tcp accept‘
firewall-cmd --permanent --add-rich-rule ‘rule family=ipv4 source address=192.168.1.1 port port=8082 protocol=tcp accept‘
firewall-cmd --permanent --add-rich-rule ‘rule family=ipv4 source address=192.168.1.1 port port=8083 protocol=tcp accept‘
#centos7
修改相应IP,然后测试就行了

3 配置LB

  为集群配置调度器,也叫Nginx的反向代理,类似LVS的LB调度器

  3.1 LB01

1、安装Nginx
http://www.cnblogs.com/wazy/p/8108824.html
2、配置nginx
[[email protected] ~]# cat /usr/local/nginx/conf/nginx.conf
user  nginx;
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"‘;
    sendfile        on;
    keepalive_timeout  65;
    include extra/www.conf;
}

[[email protected] ~]# cat /usr/local/nginx/conf/extra/www.conf
upstream www_real_server {
    server 10.0.0.80:80;
    server 10.0.0.81:80;
}

server {
    listen 80;
    server_name www.daniel.com;
    location / {
                root html; #定义服务器的默认网站根目录位置
                index index.html index.htm;  #定义首页索引文件的名称
                proxy_pass http://www_real_server;  #请求转向server1 定义的服务器列表
                proxy_set_header X-Real-IP $remote_addr; #后端的Web服务器可以通过X-Forwarded-For获取用户真实IP
                client_max_body_size 100m; #允许客户端请求的最大单文件字节数
        }
}

4 Nginx负载均衡upstream模块介绍与LVS对比

    Nginx负载均衡功能依赖于ngx_http_upstream_module模块,所支持的代理方式有proxy_pass,fastcgi_pass,memcached_pass

#常用参数选项
1、upstream 模块应放于nginx.conf配置的http{}标签内
2、upstream 模块默认算法是wrr(权重轮询 weighted round-robin)
server 10.0.0.80:80 负载均衡后面的RS配置,可以使IP或域名,端口不写,默认是80端口。高并发场景IP要换成域名,通过DNS做负载均衡
weight 是权重,默认是1
max_fails=2 最大尝试失败的次数,默认是1,0表示禁止失败尝试。企业场景:京东1此,蓝汛10次,根据业务需求去配置
backup 热备配置(RS节点的高可用),当前面激活的RS都失败后会自动启用热备RS
fail_timeout=20s 失败超时时间,默认是10s。京东3秒,蓝汛3秒,根据业务需求配置。常规业务2-3秒合理
down 这标志着服务器永远不可以用,这个参数一直配合ip_hash 使用

  

  

  

原文地址:https://www.cnblogs.com/wazy/p/8522790.html

时间: 2024-10-12 22:15:47

Nginx负载均衡-day的相关文章

nginx负载均衡+keepalive心跳检测

环境标准: 一一一一一一一一一一一一一一一一一一一一一一一一一一一一一一一一一一一一一一一一一一一一一一一一一一一一一一一一一一一一一一一一 内核:2.6.32-642.el6.x86_64 系统:CentOS release 6.8 (Final) ip: web01:10.0.0.8 nginx 解析手机端 均做了nginx的负载均衡但是只均衡一台机器可以后续往里填 web02:10.0.0.200 nginx 解析电脑端 均做了nginx的负载均衡但是只均衡一台机器可以后续往里填 lb01

12.17 Nginx负载均衡;12.18 ssl原理;12.19 生产ssl密钥对;12.20 Nginx配置ssl

扩展: 针对请求的uri来代理 http://ask.apelearn.com/question/1049 根据访问的目录来区分后端web http://ask.apelearn.com/question/920 12.17 Nginx负载均衡 1. 安装dig命令: [[email protected] ~]# yum install -y bind-utils 2. 用dig获取qq.com的ip地址: [[email protected] ~]# dig qq.com 3. 创建ld.co

Linux CentOS搭建JDK+Mysql+Tomcat+Nginx负载均衡环境      

本文使用了Tomcat+Nginx环境,主要起到负载均衡的作用,使用Tomcat处理jsp后台程序,使用Nginx处理静态页面. 准备工作(下载软件版本,请自行百度下载) 安装包放至:/usr/local/src 安装地址:/usr/local/软件名 1.apache-tomcat-6.0.48 2.mysql-5.5.54 3.nginx-1.6.3 4.cmake-2.8.8 5.pcre-8.40 6.jdk-8u11-linux-x64 7.openssl-1.1.0d(https使用

nginx负载均衡

nginx负载均衡 Nginx负载均衡的理解 Nginx是一个轻量级的.高性能的WebServer,他主要可以干下面两件事: 作为http服务器(和apache的效果一样) 作为反向代理服务器实现负载均衡 现在Nginx到处都可以见到,经常会看到宕机后的网页会显示nginx的字样,这也说明Nginx由于高性能.使用配置简.开源单这些特点被越来越多的用户所接受,所使用. 其中第一种作为http服务器,结合php-fpm进程,对发来的请求进行处理,nginx本身并不会解析php,他只是作为一个服务器

lvs、haproxy、nginx 负载均衡的比较分析

lvs.haproxy.nginx 负载均衡的比较分析 对软件实现负载均衡的几个软件,小D详细看了一下,从性能和稳定上还是LVS最牛,基本达到了F5硬件设备的60%性能,其他几个10%都有点困难. 不过就因为LVS忒牛了,配置也最麻烦了,而且健康检测需要另外配置Ldirector,其他HAPROXY和NGINX自己就用,而且配置超级简单. 所以小D建议,如果网站访问量不是门户级别的用HAPROXY或者NGINX就OK了,到了门户级别在用LVS+Idirector吧 哈哈 lvs和nginx都可以

Nginx 负载均衡

原文地址:http://nginx.com/resources/admin-guide/load-balancer/ Nginx Load Balancing nginx 负载均衡 This section describes how to use NGINX and NGINX Plus as a load balancer. 本章将讨论如何使用Nginx和Nginx加做负载均衡器. In This Section 本章包括 Load balancing overview 负载均衡概览 Pro

day10 nfs服务,nginx负载均衡,定时任务

=====================nginx 负载均衡======================= 实现nginx负载均衡的效果,并运用nfs服务共享目录,使所有nginx服务拥有共同的http目录 nginx安装:http://www.cnblogs.com/alwaysInMe/p/6924859.html nfs安装:NFS 是Network File System的缩写,即网络文件系统.一种使用于分散式文件系统的协定. ===>  环境配置及软件安装 注:本次安装用的是cent

nginx 负载均衡策略

nginx 负载均衡策略 1. 轮询 轮询方式是nginx负载均衡的默认策略,根据每个server的权重值来轮流发送请求,例如: upstream backend {server backend1.example.com;server backend2.example.com;} 这种情况是每个server都使用相同的权重,默认值为1 可以手动设定权重,例如 upstream backend {server backend1.example.com weight=5;server backend

搭建Nginx负载均衡服务文档一

搭建负载均衡服务的实际需求: 1.把单台服务器无法承受的大规模并发访问或数据流量分担到多台节点设备上,分别进行处理,减少用户等待响应的时间,提升用户体验. 2.单个重负载的运算分担到多台节点设备上做并行处理,每个节点处理结束后,将结果汇总,返回给用户. 3.7*24小时的服务保证,任意一个或多个有限后面节点设备宕机,不能影响业务. 实现Nginx负载均衡需要两个组件: l  Ngx_http_proxy_module,用于把请求后抛给服务器节点或upstream服务器池: l  Ngx_http

nginx负载均衡和tomcat热部署简单了解

简单说下几个名词 nginx 它是一个反向代理,实际上就是一台负责转发的代理服务器,貌似充当了真正服务器的功能,但实际上并不是,代理服务器只是充当了转发的作用,并且从真正的服务器那里取得返回的数据,这个就是nginx的工作内容 tomcat 开源的web服务器 oracle 数据库 redis 缓存系统 nginx负载均衡简介 如图1展示,客户端发起请求,通过nginx代理后,根据权重将请求平均转发到服务器 热部署简介 一般我们只有1个tomcat的时候,如果需要代码包,就需要把tomcat关闭