1.集群的特点

(1)高性能

(2)价格有效性

(3)可伸缩性

(4)高可用性

(5)透明性

2.负载均衡概述

负载均衡,英文名称为Load Balance,其含义就是指将负载(工作任务)进行平衡、分摊到多个操作单元上进行运行,例如FTP服务器、Web服务器、企业核心应用服务器和其它主要任务服务器等,从而协同完成工作任务。

负载均衡构建在原有网络结构之上,它提供了一种透明且廉价有效的方法扩展服务器和网络设备的带宽、加强网络数据处理能力、增加吞吐量、提高网络的可用性和灵活性。

3.构建集群环境

三台web服务器配置一模一样

3.1web01
  1. vim /etc/nginx/conf.d/proxy.conf

  2. server{
  3. listen 80;
  4. server_name www.shuai.com;
  5.  
  6. location / {

  7. root /www/;
  8. index index.html;
  9. }
  10. }
3.2web02
  1. vim /etc/nginx/conf.d/proxy.conf

  2. server{
  3. listen 80;
  4. server_name www.shuai.com;
  5.  
  6. location / {

  7. root /www/;
  8. index index.html;
  9. }
  10. }
3.3web03
  1. vim /etc/nginx/conf.d/proxy.conf

  2. server{
  3. listen 80;
  4. server_name www.shuai.com;
  5.  
  6. location / {

  7. root /www/;
  8. index index.html;
  9. }
  10. }
3.4测试

4.负载均衡环境搭建

  1. vim /etc/nginx/conf.d/proxy.conf

  2. upstream shuai {
  3. server 10.0.0.7:80;
  4. server 10.0.0.8:80;
  5. server 10.0.0.9:80;
  6. }

  7. server {

  8. listen 80;
  9. server_name www.shuai.com;

  10. location / {

  11. proxy_pass http://shuai;
  12. proxy_set_header HOST $host;


  13. }

  14. }

4.1负载均衡模块详细说明
ngx_http_upstream_module

http://nginx.org/en/docs/http/ngx_http_upstream_module.html#upstream

4.1.1轮训分配请求(平均)

默认配置

4.1.2weight=number权重分配请求
  1. upstream oldboy {
  2. server 10.0.0.7:80 weight=3;
  3. server 10.0.0.8:80 weight=2;
  4. server 10.0.0.9:80 weight=1;
  5. }

4.1.3backup`实现热备功能(将服务器标记为备份服务器。当主服务器不可用时,将传递请求。)

  1. upstream oldboy {
  2. server 10.0.0.7:80;
  3. server 10.0.0.8:80;
  4. server 10.0.0.9:80 backup;
  5. }

4.1.4max_fails=number定义最大失败次数(用于监控检测)

  1. upstream oldboy {
  2. server 10.0.0.7:80 max_fails=5;
  3. server 10.0.0.8:80 max_fails=5;
  4. server 10.0.0.9:80 max_fails=5;
  5. }

4.1.5fail_timeout=time定义失败之后重发的间隔时间(用于监控检测)

  1. upstream oldboy {
  2. server 10.0.0.7:80 fail_timeout=10s;
  3. server 10.0.0.8:80 fail_timeout=10s;
  4. server 10.0.0.9:80 fail_timeout=10s;
  5. }
4.2反向代理模块详细说明

更过模块参考:http://nginx.org/en/docs/http/ngx_http_proxy_module.html#proxy_pass

ngx_http_proxy_module

4.2.1proxy_set_heard负载均衡到后端web服务器无法显示页面

  1. location / {
  2.  
  3. proxy_pass http://shuai;
  4. proxy_set_header HOST $host;
  5.  
  6. }

4.2.2在access日志中显示源IP,而不是负载均衡IP

  1. location / {
  2.  
  3. proxy_pass http://shuai;
  4. proxy_set_header HOST $host;
  5. proxy_set_header X-Forwarded-For $remote_addr;
  6. proxy_next_upstream error timeout http_404 http_502;
  7. }

4.2.3proxy_next_upstream如果后端web出现错误页面,则跳过访问,将正确的页面显示给客户端。

http://nginx.org/en/docs/http/ngx_http_proxy_module.html#proxy_next_upstream

  1. location / {
  2.  
  3. proxy_pass http://shuai;
  4. proxy_set_header HOST $host;
  5. proxy_set_header X-Forwarded-For $remote_addr;
  6. proxy_next_upstream error timeout http_404 http_502;
  7. }

nginx负载均衡与反向代理的更多相关文章

  1. 【架构师之路】Nginx负载均衡与反向代理—《亿级流量网站架构核心技术》

    本篇摘自<亿级流量网站架构核心技术>第二章 Nginx负载均衡与反向代理 部分内容. 当我们的应用单实例不能支撑用户请求时,此时就需要扩容,从一台服务器扩容到两台.几十台.几百台.然而,用 ...

  2. Nginx负载均衡与反向代理—《亿级流量网站架构核心技术》

    当我们的应用单实例不能支撑用户请求时,此时就需要扩容,从一台服务器扩容到两台.几十台.几百台.然而,用户访问时是通过如http://www.XX.com的方式访问,在请求时,浏览器首先会查询DNS服务 ...

  3. Nginx 负载均衡和反向代理实践

    nginx 以哪个配置文件启动 Nginx 负载均衡和反向代理实践 环境介绍 192.168.1.50    在这台主机上配置Nginx 的反向代理,负载均衡,和web1,web1使用的81号端口 1 ...

  4. CentOS中实现Nginx负载均衡和反向代理

    一.安装必要软件 负载均衡服务器:IP设置为192.168.1.10 Web服务器1:安装Apache或者Nginx,IP设置为192.168.1.11: Web服务器2:安装Apache或者Ngin ...

  5. nginx负载均衡和反向代理有什么区别

    近在研究nginx的负载均衡和反向代理,先看下这两个简单的配置吧! 负载均衡 worker_processes 1; events { worker_connections 1024; } http{ ...

  6. Nginx负载均衡和反向代理设置

    Nginx负载均衡: 格式: upstream 别名 {    #别名一般要有意义,能看出是做什么的 server ip:端口;    #要实现负载的服务器的ip.端口号}  例: upstream ...

  7. Nginx负载均衡和反向代理的配置和优化

    负载均衡 负载均衡是由多台服务器以对称的方式组成一个服务器集合,每台服务器都具有等价的地位, 反向代理 是指以代理服务器来接受internet上的请求,然后将请求转给内部的服务器 常见的负载均衡 1. ...

  8. CentOS中nginx负载均衡和反向代理的搭建

    1: 修改centos命令行启动(减少内存占用): vim /etc/inittab :initdefault: --> 修改5为3 若要界面启动使用 startx 2:安装jdk )解压:jd ...

  9. nginx 负载均衡及反向代理

    Nginx简介 Nginx是一款高性能的http 服务器/反向代理服务器及电子邮件(IMAP/POP3)代理服务器.由俄罗斯的程序设计师开发,官方测试nginx能够支支撑5万并发链接,并且cpu.内存 ...

  10. Nginx负载均衡与反向代理的配置实例

    user www www; worker_processes 10; error_log /data1/logs/nginx_error.log crit; pid /usr/local/webser ...

随机推荐

  1. 【转载】深入理解OpenStack-手动制作qcow2镜像

    深入理解OpenStack-手动制作qcow2镜像 2018-01-18 手动制作镜像 1 官方虽提供qcow2系统镜像,但对于有需求的企业来说,还是定制镜像比较靠谱,下面就手动定制一个镜像 给虚拟机 ...

  2. spec cpu2006 官网

    https://www.spec.org/cpu2006/Docs/install-guide-unix.html

  3. http协议工作原理及工作流程

    什么是url ? url = 协议 + 域名 + 资源路径 比如: https://www.baidu.com/index.html http : 超文本传输协议 https: 安全套接字协议 HTT ...

  4. Scala 函数式编程思想

    Spark 选择 Scala 作为开发语言 在 Spark 诞生之初,就有人诟病为什么 AMP 实验室选了一个如此小众的语言 - Scala,很多人还将原因归结为学院派的高冷,但后来事实证明,选择 S ...

  5. 矩阵中的路径 DFS+剪枝

    给定一个 m x n 二维字符网格 board 和一个字符串单词 word .如果 word 存在于网格中,返回 true :否则,返回 false . 单词必须按照字母顺序,通过相邻的单元格内的字母 ...

  6. 链路追踪_SkyWalking的部署及使用

    关于链路追踪,目前比较主流是Cat,Zipkin,SkyWalking等这些工具.这篇文章主要介绍关于SkyWalking工具的. 为什么用SkyWalking,因为它基本没有代码侵入,只这一点就足够 ...

  7. Python3.x 基础练习题100例(91-100)

    练习91: 题目: 时间函数举例1. 程序: if __name__ == '__main__': import time print (time.ctime(time.time())) print ...

  8. Linux(CentOS 7) 安全加固之非业务端口服务关闭 postfix port 25

    目录 关闭TCP 25 端口对应的服务 1. 确认对应端口的进程 2. 查找与关闭对应服务 3. 确认结果,端口已关闭 关闭TCP 25 端口对应的服务 [0 root@Qvps /root] #ca ...

  9. 在windows上 使用celery 报错

    在windows上 使用celery 报错       在windows上 使用celery 报错 ValueError: not enough values to unpack (expected ...

  10. Step By Step(Lua系统库)

    Step By Step(Lua系统库) Lua为了保证高度的可移植性,因此,它的标准库仅仅提供了非常少的功能,特别是和OS相关的库.但是Lua还提供了一些扩展库,比如Posix库等.对于文件操作而言 ...