本节索引


  • Ipvsadm工具介绍

  • Web服务的负载均衡

  • 实现http与https的同时调度

1 ipvsadm工具


我们知道LVS项目已提供了一个实现可伸缩网络服务的Linux Virtual Server框架。在LVS框架中,提供了含有三种"IP负载均衡技术"的IP虚拟服务器软件"IPVS"、"基于内容请求分发的内核Layer-7交 换机KTCPVS"和"集群管理软件"。这里主要说说”IP负载均衡技术”他的管理工具就是ipvsadm。

1)ipvsadm语法

ipvsadm -A|E -t|u|f service-address [-s scheduler] [-p [timeout]] [-M netmask] [-b sched-flags]ipvsadm -D -t|u|f service-addressipvsadm -Cipvsadm -Ripvsadm -S [-n]ipvsadm -a|e -t|u|f service-address -r server-address [-g|i|m] [-w weight] [-x upper] [-y lower]ipvsadm -d -t|u|f service-address -r server-addressipvsadm -L|l [options]ipvsadm -Z [-t|u|f service-address]ipvsadm --set tcp tcpfin udpipvsadm --start-daemon state [--mcast-interface interface] [--syncid syncid]ipvsadm --stop-daemon stateipvsadm -h

2)Ipvsadm选项介绍

选项 说明
-A (--add-service) 在内核的虚拟服务器列表中添加一条新的虚拟IP记录。也就是增加一台新的虚拟服务器。虚拟IP也就是虚拟服务器的IP地址。
-E (--edit-service) 编辑内核虚拟服务器列表中的一条虚拟服务器记录
-D (--delete-service) 删除内核虚拟服务器列表中的一条虚拟服务器记录
-C (--clear) 清除内核虚拟服务器列表中的所有规则
-R (--restore) 恢复虚拟服务器规则
-S (--save) 保存虚拟服务器规则,输出为-R 选项可读的格式
-a (--add-server) 在内核虚拟服务器列表的一条记录里添加一条新的Real Server记录。也就是在一个虚拟服务器中增加一台新的Real Server
-e (--edit-server) 编辑一条虚拟服务器记录中的某条Real Server记录
-d (--delete-server) 删除一条虚拟服务器记录中的某条Real Server记录
-L|-l –list 显示内核中虚拟服务器列
-t 说明虚拟服务器提供的是tcp服务,此选项后面跟如下格式:[virtual-service-address:port] or [real-server-ip:port]
-u 说明虚拟服务器提供的是udp服务,此选项后面跟如下格式:[virtual-service-address:port] or [real-server-ip:port]
-f fwmar 说明是经过iptables标记过的服务类型
-s 此选项后面跟LVS使用的调度算法;有这样几个选项:rr|wrr|lc|wlc|lblc|lblcr|dh|sh。默认的调度算法是: wlc
-p  [timeout] 在某个Real Server上持续的服务时间。也就是说来自同一个用户的多次请求,将被同一个Real Server处理。此参数一般用于有动态请求的操作中,timeout的默认值为360s(帮助文档写的是300s)。例如:-p 100,表示持续服务时间为00s。
-r 指定Real Server的IP地址,此选项后面跟如下格式:[real-server-ip:port]
-g (--gatewaying) 指定LVS 的工作模式为直接路由模式(此模式是LVS 默认工作模式)
-i (-ipip) 指定LVS 的工作模式为隧道模式
-m (--masquerading) 指定LVS 的工作模式为NAT模式
-w (--weight) weight 指定Real Server的权值
-c (--connection) 显示LVS目前的连接信息 例如:ipvsadm -L -c
-L --timeout 显示“tcp tcpfin udp”的timeout值,如:ipvsadm -L --timeout
-L --daemon 显示同步守护进程状态,例如:ipvsadm -L –daemon
-L  --stats 显示统计信息,例如:ipvsadm -L –stats
-L  --rate 显示速率信息,例如:ipvsadm -L  --rate

3)说明: 保存添加的虚拟ip记录和ipvsadm的规则可以使用service ipvsadm save,还可以用-S或--save。清除所有记录和规则除了使用-C,还以使用--clear。

2 web服务的负载均衡


1)实验准备:准备4台虚拟机

@@一台作为VS服务器

@@一台作为客户端

@@两台主机作为web服务器,当然了,不只是web服务器。这里只是为了实验方便,web服务最常见,

2)网络拓扑及地址规划

3)环境配置

为了实验能顺利实现,关闭防火墙和selinux;注意这只是实验环境中。

[root@vin ~]# iptables -F         # 清空防火墙规则
[root@vin ~]# setenforce 0        # 临时禁用selinux
[root@vin ~]#

4)web服务器配置

为了让我们看清楚LVS是如何调度的,我们特意将两台web服务器的index.html页面设置的不一样。

@@安装服务:

[root@vin ~]# yum install httpd -y
[root@vin ~]# echo "Linux web1" > /var/www/html/index.html   # 修改主页,web2的主页内容修改为Linux web2

@@设置路由:只留一个网卡并且将网关指向Director

[root@vin ~]# route -n
Kernel IP routing table
Destination     Gateway         Genmask         Flags Metric Ref    Use Iface
192.168.14.0    0.0.0.0         255.255.255.0   U     0      0        0 ens33
0.0.0.0         192.168.14.77   0.0.0.0         UG    0      0        0 ens33

5)VS调度器设置

@@ 安装ipvsadm工具

[root@vin ~]# yum install ipvsadm -y        # yum安装,不过我已经安装了
Loaded plugins: fastestmirror
Loading mirror speeds from cached hostfile
Package ipvsadm-1.27-7.el7.x86_64 already installed and latest version
Nothing to do
[root@vin ~]# mount /dev/sr0 /mnt             # 挂载光盘
mount: /dev/sr0 is write-protected, mounting read-only
[root@vin ~]# rpm -ivh /mnt/Packages/ipvsadm-1.27-7.el7.x86_64.rpm       # rpm安装
[root@vin ~]#

@@ 开启核心转发功能

[root@vin ~]# echo 1 > /proc/sys/net/ipv4/ip_forword

@@ 定义集群服务

[root@vin ~]# ipvsadm -A -t 172.18.14.100:80 -s wrr
[root@vin ~]# ipvsadm -a -t 172.18.14.100:80 -r 192.168.14.55 -m -w 3     # 定义web1的权重为3
[root@vin ~]# ipvsadm -a -t 172.18.14.100:80 -r 192.168.14.66 -m -w 1     # 定义web2的权重为1(默认也是1;可省略)
[root@vin ~]# ipvsadm -Ln                         # 查看几区服务
IP Virtual Server version 1.2.1 (size=4096)
Prot LocalAddress:Port Scheduler Flags-> RemoteAddress:Port           Forward Weight ActiveConn InActConn
TCP  172.18.14.100:80 wrr-> 192.168.14.55:80             Masq    3      0          0 -> 192.168.21.66:80             Masq    1      0          0

6)测试

在客户端使用for循环向VIP发起http访问请求

[root@vint ~]# for i in {1..10};do curl Linux web1
Linux web1
Linux web2
Linux web2
Linux web2
Linux web1
Linux web2
Linux web2
Linux web2
Linux web1
Linux web2

7)结果分析

观察访问结果,我们发现,LVS根据我们的算法WRR(加权轮询)及对应的权重(3,1)进行了调度。

3 实现http与https同时调度


方案一:同过添加两个集群服务,分别针对http和https的访问

1)原理剖析:

要实现http(上面我们已经实现了)与https的调度,我们第一步要做的就是:为两台服务提供CA证书,而且这两个服务器上的CA证书必须完全相同(可以采取先给一个授权,在复制到另外一台服务器上),这里我们可以使用Director作为根CA的颁发机构来颁发证书,也可以使用web服务器的自签名证书。然后我们在VS服务器上在添加一个用于https进行调度的集群服务,从而实现调度。

2)在web服务器上实现https服务

@@生成证书:这里就不在说怎么实现CA了,请参考博客:http://vinsent.blog.51cto.com/13116656/1964034

3)VS上添加集群服务

[root@vin ~]# ipvsadm -A -t 172.18.14.100:443 -s wrr
[root@vin ~]# ipvsadm -a -t 172.18.14.100:443 -r 192.168.14.55 -m -w 3     # 定义web1的权重为3
[root@vin ~]# ipvsadm -a -t 172.18.14.100:443 -r 192.168.14.66 -m -w 1     # 定义web2的权重为1(默认也是1;可省略)
[root@vin ~]# ipvsadm -Ln                         # 查看几个集群服务
IP Virtual Server version 1.2.1 (size=4096)
Prot LocalAddress:Port Scheduler Flags-> RemoteAddress:Port           Forward Weight ActiveConn InActConn
TCP  172.18.14.100:80 wrr-> 192.168.14.55:80             Masq    3      0          0 -> 192.168.21.66:80             Masq    1      0          0
TCP  172.18.14.100:443 wrr-> 192.168.14.55:443             Masq    3      0          0 -> 192.168.21.66:443             Masq    1      0          0

4)测试

[root@vint ~]# for i in {1..10};do curl http://172.18.14.100;curl


方案二:使用防火墙标记,实现http与https的统一调度。

1)明晰思路

上面实现了http与https通过LVS的调度分别按相应算法调度,但是他们的调度依然各是各的,我们怎么能让VS服务将http与https能够看成一个服务进行调度呢,此时我们想到了Netfilter中的MANGLE表,我们可以在防火墙上做策略,让访问我的https和http服务的请求给他们打上标记MARK,这样,在调度的时候,我们只需要根据MARK实现调度即可,至于他是究竟是http还是https我们便不在关心。

2)在VS上配置iptables规则

[root@vint ~]# iptables -F
[root@vint ~]# iptables -F -t nat    # 保证防墙上没有其他规则干扰;注意:这只是实验环境
[root@vint ~]# iptables -A -t mangle PREROUTING -p tcp -m multiport --dport 80,443 \
>-d 172.18.14.100 -j MARK --set-mark 10

3)设置LVS集群服务

由于我们将二者集合起来调度,在Director看来,http访问与https访问都是同一个服务,所以我们想清空原有的集群服务,在重新添加集群服务。

[root@vint ~]# ipvsadm -C
[root@vint ~]# ipvsadm -Ln         # 确保规则清除
IP Virtual Server version 1.2.1 (size=4096)
Prot LocalAddress:Port Scheduler Flags-> RemoteAddress:Port           Forward Weight ActiveConn InActConn
[root@vint ~]# ipvsadm -Z         # 清空计数器
[root@vin ~]# ipvsadm -A -t -f 10 -s wrr
[root@vin ~]# ipvsadm -a -t -f -r 192.168.14.55 -m -w 3     # 定义web1的权重为3
[root@vin ~]# ipvsadm -a -t -f -r 192.168.14.66 -m -w 1     # 定义web2的权重为1(默认也是1;可省略)

4)测试

[root@vint ~]# for i in {1..10};do curl http://172.18.14.100;curl https://172.18.14.100;done

笔者便签


感谢您能读到最后,如果这篇文章能让你有所收获,那将是我的荣幸,如果没能帮到你,那就在送你一句话,与君共勉:If a thing is worth doing it is worth worth doing well ---- 事情值得做,就值得好好做。

转载于:https://blog.51cto.com/vinsent/1975378

LVS实现web服务的负载均衡相关推荐

  1. LVS+Keepalived实现高可用负载均衡

    本文来说下如何使用LVS+Keepalived 实现高可用负载均衡 文章目录 概述 LVS与Keepalived 相关术语 本文小结 概述 在业务量达到一定量的时候,往往单机的服务是会出现瓶颈的.此时 ...

  2. LVS+Keepalived 实现高可用负载均衡

    一.Keepalived介绍 keepalived是在Linux系统下的一个轻量级的高可用解决方案,是使用C语言编写的,在 Keepalived 中实现了一组检查器,可以根据服务集群中服务器的健康状态 ...

  3. 运维——Web 性能优化 —— 负载均衡

    Web 性能优化 -- 负载均衡 一.软件负载均衡技术 Linux 集群的分类: 高可用性集群:运行于两个或多个节点上,目的在于某节点系统出现故障时在其他节点的支持下仍然可继续对外提供相应的服务.这类 ...

  4. Linux下部署lvs+keepalived实现高可用负载均衡

    lvs+keepalived是什么? keepalived工作原理 keepalived是集群管理中保证集群高可用的一个服务软件,其功能类似于heartbeat,用来防止单点故障. keepalive ...

  5. FastDFS蛋疼的集群和负载均衡(十五)之lvs四层+Nginx七层负载均衡

    ###Interesting things lvs+nginx的拓扑图 准备环境,基于上一篇[Diary Report 2018-1-3]关于FastDFS蛋疼的集群和负载均衡(十三)之LVS-DR环 ...

  6. L8.1 lvs+heartbeat-ldirectord实现高可用负载均衡

    lvs+heartbeat-ldirectord实现高可用负载均衡 拓扑: IPVS规则与heartbeat ipvs规则不再使用ipvsadm配置,而是依靠heartbeat的包工具ldirecto ...

  7. .net core grpc consul 实现服务注册 服务发现 负载均衡(二)

    在上一篇 .net core grpc 实现通信(一) 中,我们实现的grpc通信在.net core中的可行性,但要在微服务中真正使用,还缺少 服务注册,服务发现及负载均衡等,本篇我们将在 .net ...

  8. azure git怎么使用_Azure(一)Azure Traffic Manager为我们的Web项目提供负载均衡

    一,引言 上一篇讲到我们将自己的Net Core Web 项目部署到 Azure 的 Web App 的一项 pass 服务,假如随着项目的日益增长的访问量,之前部署到单节点的应用可能无法保证其稳定性 ...

  9. NGINX配置基于Node.js服务的负载均衡服务器

    NGINX配置基于Node.js服务的负载均衡服务器 本部署指南说明了如何使用NGINX开源和NGINX Plus在Node.js应用程序服务器池之间平衡HTTP和HTTPS通信.本指南中的详细说明适 ...

最新文章

  1. 问题排查:vue项目刷新页面加载了500多个请求?
  2. Android Telephony分析(四) ---- TelephonyManager详解
  3. js调用浏览器的下载框
  4. Chart Share
  5. ppt转html5 带动画_我复刻了IPhone12这页发布会PPT
  6. MAUI中构建跨平台原生控件实现
  7. 【贪心】雷达装置(ybtoj 贪心-1-2)
  8. go语言mysql删除记录_MySQL数据库删除操作-Go语言中文社区
  9. Linux下超简单的Mysql自动备份+定期删除之前备份文件脚本
  10. tomcat启动时出现Error starting static Resources 错误
  11. 流畅的python读书笔记-第十章-序列的修改、散列和切片
  12. vue前端页面通用模板梳理
  13. linux耳机的检测原理,耳机检测原理介绍
  14. 接呀呀云实时语音SDK总结
  15. 银行间市场评论员文章词云绘制效果
  16. html 限制每行字数,毕业论文每行字数的设置
  17. Invalid config, exiting abnormally
  18. Java 独占锁ReentrantLock、读(悲观读)写锁ReentrantReadWriteLock、读(乐观读/悲观读)写锁StampedLock
  19. BS架构说明以及网页组成
  20. Android Makefile 及Android.mk 整理

热门文章

  1. UEStudio使用技巧三则
  2. 初步了解BIM模型和超图相关操作
  3. 如何编程实现一个基本的微分器
  4. 超图三维GIS开发概念学习
  5. Matlab 2012安装图解
  6. ivew 封装删除 对话框
  7. Appium进行iOS自动化测试时遇到的问题及解决办法
  8. pandas.read_csv() 报错 OSError: Initializing from file failed,报错原因分析和解决方法
  9. [转]阿拉伯数字转一二三和壹贰叁
  10. poj 3304 Segments (几何 : 线段 直线相交)