一、LVS运行原理
LVS:Linux Virtual Server
,负载调度器,内核集成,章文嵩,阿里的四层
SLB(Server LoadBalance)
是基于LVS+keepalived
实现
LVS
官网
:
http://www.linuxvirtualserver.org/
LVS 相关术语
- VS: Virtual Server,负责调度
- RS:RealServer,负责真正提供服务
lvs集群体系结构:
lvs概念:
- VS:Virtual Server
- RS:Real Server
- CIP:Client IP
- VIP: Virtual serve IP VS外网的IP
- DIP: Director IP VS内网的IP
- RIP: Real server IP
- 访问流程:CIP <--> VIP == DIP <--> RIP
lvs
集群的类型
lvs-nat:
- 本质是多目标IP的DNAT,通过将请求报文中的目标地址和目标端口修改为某挑出的RS的RIP和
- PORT实现转发
- RIP和DIP应在同一个IP网络,且应使用私网地址;RS的网关要指向DIP
- 请求报文和响应报文都必须经由Director转发,Director易于成为系统瓶颈
- 支持端口映射,可修改请求报文的目标PORT
- VS必须是Linux系统,RS可以是任意OS系统
nat
模式数据逻辑
data:image/s3,"s3://crabby-images/b7c6a/b7c6a83759dd4ff4d266735b8c52b325ce56514e" alt=""
案例:
data:image/s3,"s3://crabby-images/6cf95/6cf95f85e9247a2ce747f6e6298045c8e0721357" alt=""
实施:
准备环境:
准备4台虚拟机(rhel9 )
网络编辑器:
lvs服务器
- 配置两块网卡(nat/仅主机)
- 虚拟机(rhel9)
- IP:nat-172.25.254.100/24 ,172.25.254.2 仅主机-192.168.0.100/24
data:image/s3,"s3://crabby-images/bcd90/bcd90303e958301996a0cd7b4f1e37433b3cb26b" alt=""
data:image/s3,"s3://crabby-images/fce53/fce532a363bddef21f12e5c3d2f7ad553e61837a" alt=""
lvs打开内核路由功能
data:image/s3,"s3://crabby-images/e6ab8/e6ab83d71fb539e85cd22855bd224f383c8bcf1a" alt=""
data:image/s3,"s3://crabby-images/5c51e/5c51e9b617c30d48292dfa728ad14448be37a853" alt=""
生效:
data:image/s3,"s3://crabby-images/f2340/f234089a87e78ed862858de8799de73b38d5fd6b" alt=""
为了看到效果,在两台不同的服务端里面我们设置的html里的内容访问不一样
webserver1服务器
- rhel9
- 仅主机
- IP:192.168.0.10/24 ,192.168.0.100
安装httpd并开机启动:并编写
data:image/s3,"s3://crabby-images/a24f8/a24f8e43b782e23abad499793fd17c034771a30a" alt=""
data:image/s3,"s3://crabby-images/a0ea0/a0ea0fc39d702a475ad44d1e6b1d468d3ba4aa61" alt=""
data:image/s3,"s3://crabby-images/89e22/89e227255fe9c14a5401c521c723550f3fffe7fe" alt=""
webserver2服务器
- rhel9
- 仅主机
- IP:192.168.0.20/24 ,192.168.0.100
data:image/s3,"s3://crabby-images/cbfc2/cbfc20a2c47d4041757c5d4a75ea7e1afb0fc846" alt=""
安装httpd并开机启动:并编写
data:image/s3,"s3://crabby-images/a24f8/a24f8e43b782e23abad499793fd17c034771a30a" alt=""
data:image/s3,"s3://crabby-images/a0ea0/a0ea0fc39d702a475ad44d1e6b1d468d3ba4aa61" alt=""
测试环节
在lvs虚拟机上ping并且访问他的内容
data:image/s3,"s3://crabby-images/af0ac/af0aca4a2927889360f7d92e87b80317baa527ce" alt=""
在客户机(新机子/但是同一个网段里面)测试
data:image/s3,"s3://crabby-images/5c88f/5c88f4982a6d6305d521a3d4d4cf460b6ff61d85" alt=""
访问流量:
客户把这个流量给了端口网关,然后通过算法到lvs的IP 在去访问这个分布式的ip的内容