云计算笔记

1.描述以及工作原理

  1. 什么是LVS

  2. LVS调度算法

  3. 静态调度算法 Fixed Scheduling Method

  4. 轮询

  5. 加权轮询

  6. 目标地址hash

linux virtural server的简称,也就是linxu虚拟机服务器,这是一个

由章文嵩博士发起的开源项目,官网是

http://www.linuxvirtualserver.org,现在lvs已经是linux内核标

准的一部分,使用lvs可以达到的技术目标是:通过linux达到负载均衡技术

和linux操作系统实现一个高性能高可用的linux服务器集群,他具有良好

的可靠性,可延展性和可操作性,从而以低廉的成本实现最优的性能,Lvs是

一个实现负载均衡集群开源软件项目,lvs从逻辑上可以分为调度层,

server集群层,和共享存储

免费,开源,四层负载均衡

RR 轮询**

调度器通过"轮叫"调度算法将外部请求按顺序轮流分配到集群中的真

实服务器上,它均等地对待每一台服务器,而不管服务器上实际的连

接数和系统负载。

WRR 加权轮询**

调度器通过"加权轮叫"调度算法根据真实服务器的不同处理能力来调

度访问请求。 这样可以保证处理能力强的服务器处理更多的访问流

量。调度器 可以自动问询真实服务器的负载情况,并动态地调整其

权值DH 目标地址hash**

算法也是针对目标IP地址的负载均衡,但它是一种静态映射算法,通

过一个散列(Hash)函数将一个目标IP地址映射到一台服务器。

目标地址散列调度算法先根据请求的目标IP地址,作为散列键

(Hash Key)从静态分配的散列表找出对应的服务器,若该服务器

是可用的且未超载,将请求发送到该服务器,否则返回空。

  1. 源地址hash

SH 源地址hash**

算法正好与目标地址散列调度算法相反,它根据请求的源IP地址,作

为散列键(Hash Key)从静态分配的散列表找出对应的服务器,若

该服务器是 可用的且未超载,将请求发送到该服务器,否则返回

空。

它采用的散列函数与目标地址散列调度算法的相同。除了将请求的目

标IP地址换成请求的源IP地址外,它的算法流程与目标地址散列调

度算法的基本相似。在实际应用中,源地址散列调度和目标地址散列

调度可以结合使用在防火墙集群中,它们可以保证整个系统的唯一出

入口。

  1. 动态调度算法 Dynamic Scheduling Method 动态调度方法

  2. Lc最少链接

调度器通过"最少连接"调度算法动态地将网络请求调度到已建立的链

接数最少的服务器上。 如果集群系统的真实服务器具有相近的系统

性能,采用"最小连接"调度算法可以较好地均衡负载。

  1. wlc加权最少链接、

在集群系统中的服务器性能差异较大的情况下,调度器采用"加权最

少链接"调度算法优化负载均衡性能,具有较高权值的服务器将承受

较大比例的活动连接负载。调度器可以自动问询真实服务器的负载情

况,并动态地调整其权值。3. sed最少期望延迟

基于wlc算法,举例说明:ABC三台机器分别权重123,连接数也分

别是123,name如果使用WLC算法的话一个新请求 进入时他可能会

分给ABC中任意一个,使用SED算法后会进行这样一个运算

A:(1+1)/2

B:(1+2)/2

C:(1+3)/3

根据运算结果,把连接交给C

  1. nq从不排队调度算法

无需列队,如果有台realserver的连接数=0 就直接分配过去,不

需要进行sed运算

  1. lblc基于本地最少链接

"基于局部性的最少链接" 调度算法是针对目标IP地址的负载均衡,

目前主要用于Cache集群系统。

该算法根据请求的目标IP地址找出该 目标IP地址最近使用的服务

器,若该服务器 是可用的且没有超载,将请求发送到该服务器;

若服务器不存在,或者该服务器超载且有服务器处于一半的工作负

载,则用"最少链接"的原则选出一个可用的服务器,将请求发送到该

服务器。

  1. lblcr带复制的基于本地的最少链接"带复制的基于局部性最少链接"调度算法也是针对目标IP地址的负

载均衡,目前主要用于Cache集群系统。

它与LBLC算法的不同 之处是它要维护从一个 目标IP地址到一组服

务器的映射,而LBLC算法维护从一个目标IP地址到一台服务器的映

射。

该算法根据请求的目标IP地址找出该目标IP地址对应的服务器组,

按"最小连接"原则从服务器组中选出一台服务器,

若服务器没有超载,将请求发送到该服务器;若服务器超载,则

按"最小连接"原则从这个集群中选出一 台服务器 ,将该服务器加

入到服务器组中,将请求发送到该服务器。同时,当该服务器组有一

段时间没有被修改, 将最忙的服务器从服务器组中删除,以降低复

制的程度。

  1. LVS的工作原理

  2. 当用户向负载均衡调度器(director server)发起请求,调度器将

请求发往内核空间

  1. prerouting链首先会接受到用户请求,判断目标ip确定是本机ip,将

数据包发往input链

  1. IPVS是工作在input链上的,当用户请求到达input时,ipvs会将用户

请求和自己定义好的集群服务器进行比对,如果用户请求就是定义

的集群服务,那么此时ipvs会强行修改数据包里的目标ip地址以及端

口,并将新的数据包发往POSTROUTING链,

  1. POSTROUTING链接收到数据包后,发现目标ip地址刚好是自己的

后端服务器,那么通过选路,将数据包最终发送给后端服务器4.

2.组成以及相关术语

1.组成

  1. ipvs

  2. ipvsadm

  3. lvs组成=ipvsipv(内核,负载均衡调度代码)+sadm(ipvs管理器,负责

均衡提供集群后端服务等信息)

2.术语

  1. DS DIrector Server 前端负责均衡节点(负载均衡服务器)

  2. RS real server 后端真实工作服务器(web服务器)

ip virtual server,一段代码工作在内核空间,ipvs,是真正生效实现

调度的代码(累死nginx中的proxy_pass),

另一段是工作在用户空间,ipvsadm,负责为ipvs内核框架编写规则,定义

谁是集群服务,谁是后端真正的服务器(real server)类似nginx中的

upstrean3. vip向外部直接面向用户请求,作为用户请求的目标ip地址(负载均衡的

ip地址,提供给用户)

  1. DIP Director Server Ip 和内部主机通讯的ip地址(负责与Real Server交

互的内部Ip)

  1. RIP Real Server Ip 后端服务器ip地址

  2. CIP client IP 访问客户端ip地址

3.三种工作模式

  1. *LVS-NAT模式

  2. *LVS-DR模式

  3. Lvs-Tun模式(隧道模式)

4.NAT模式的工作原理1. 用户请求ds,此时请求的报文会先到内核空间prerouting链,此时报文

ip为cip,目标ip为vip

  1. prerouting检测发现数据包目标ip是本机,将数据包送到input链

  2. ipvs对比数据包请求的服务是否为集群服务,如果是,修改数据包的目

标ip地址为后端服务器的IP地址,然后将数据包发送给POSTROUTING

链,此时报文ip为cip,目标ip为rip

  1. POSTROUTING通过选路,将数据发送给Real Server

  2. RealServer对比发现目标ip为自己的ip,开始构建响应报文发回给

Director Server此时报文的源ip为RIP,目标ip为CIP

  1. Derector Server在响应客户端前,会将源ip地址修改为自己的VIP,然

后响应给客户端,目标ip为cip,此时报文源IP为VIP,目标ip为cip

NAT模型的特性

  1. Rs应该是私有地址,Rs网关必须指向DIP

  2. DIP和RIP必须在同一个网段内

  3. 请求和响应报文都应该经过Director Server,高负载场景中Director

Server容易成为性能瓶颈

  1. 支持端口映射

  2. Rs可是使用任意操作系统

  3. 缺陷,对Ds压力会比较大,请求和响应都需要经过ds,

5.NAT模式实战-环境准备

角色

作用

ip

NAT

负载均衡调度

器 DS

内网:(DIP192.168.71.171),外

网:(VIP192.168.71.170)

web01

真实web服务

器Rs

x.x.x.200

环境规划角色

作用

ip

web02

真实web服务

器Rs

x.x.x.201

DNS

用来解析各主

机的域名和ip

地址

client

测试

  1. 给NAT主机增加一张网卡,命名为ens37,自动或者手工获取ip均可,

理论上nat对应ds服务器应该有两张网卡(vip,dip)vip对外服务,需

要使用公网ip,dip内网局域网,使用虚拟机使用仅主机模式,也可以用

桥接模式和nat模式都可以

  1. 步骤

  2. 配置两个网卡和两个ip地址,正常来说应该配置两个不同的网段的

ip,一个对外的vip,一个对内的dip,现在主要使用nat的网络模

式,可以配置桥接模式对外,Nat对内,教师机不方便配置桥接模

式,所以都是配置的nat模式,但是一定要分清楚哪个ip是vip,哪个

ip是dip,在物理主机上都要能够ping通。

  1. 克隆主机,生成net模式的机器

  2. 设置主机名称nat.yuanyu.zhangmin

  3. 更改ip地址

[root@nat ~]# hostname

nat.yuanyu.zhangmin

vim /etc/sysconfig/network-scripts/ifcfg-ens33

DEFROUTE="yes"

IPV4_FAILURE_FATAL="no"IPV6INIT="yes"

IPV6_AUTOCONF="yes"

IPV6_DEFROUTE="yes"

IPV6_FAILURE_FATAL="no"

IPV6_ADDR_GEN_MODE="stable-privacy"

NAME="ens33"

UUID="7a2bb575-3b9c-4206-9dd7-e87372b68952"

DEVICE="ens33"

ONBOOT="yes"

IPADDR=10.1.1.100

NETMASK=255.255.255.0

GATEWAY=10.1.1.2

DNS1=8.8.8.8

DNS2=114.114.114.1145. 额外添加一张网卡,选择对外提供服务的桥接模式或者nat模式,选

择桥接模式(ip不同)

  1. 查看所有网卡[root@nat ~]# ip a

1: lo: <LOOPBACK,UP,LOWER_UP> mtu 65536 qdisc

noqueue state UNKNOWN group default qlen 1000

link/loopback 00:00:00:00:00:00 brd

00:00:00:00:00:00

inet 127.0.0.1/8 scope host lo

valid_lft forever preferred_lft forever

inet6 ::1/128 scope host

valid_lft forever preferred_lft forever

2: ens33: <BROADCAST,MULTICAST,UP,LOWER_UP> mtu 1500

qdisc pfifo_fast state UP group default qlen 1000

link/ether 00:0c:29:6f:6e:0a brd

ff:ff:ff:ff:ff:ff

inet 10.1.1.100/24 brd 10.1.1.255 scope global

ens33

valid_lft forever preferred_lft forever

inet6 fe80::20c:29ff:fe6f:6e0a/64 scope link

valid_lft forever preferred_lft forever

3: ens36: <BROADCAST,MULTICAST,UP,LOWER_UP> mtu 1500

qdisc pfifo_fast state UP group default qlen 1000

link/ether 00:0c:29:6f:6e:14 brd

ff:ff:ff:ff:ff:ff

inet 192.168.0.100/24 brd 192.168.0.255 scope

global ens36

valid_lft forever preferred_lft forever

inet6 240e:878:8fa:6069:20c:29ff:fe6f:6e14/64

scope global mngtmpaddr dynamic

valid_lft forever preferred_lft forever

inet6 fe80::20c:29ff:fe6f:6e14/64 scope link

valid_lft forever preferred_lft forever

  1. 修改网卡配置文件[root@nat ~]# vim /etc/sysconfig/network

scripts/ifcfg-ens36

TYPE="Ethernet"

BOOTPROTO="none"

NAME="ens36"

UUID="606c3bb5-ae86-42fa-95e1-d9766c3d4ab9"

DEVICE="ens36"

ONBOOT="yes"

IPADDR=192.168.0.100

NETMASK=255.255.255.0

  1. 时间同步

[root@nat ~]# yum -y install ntpdate

[root@nat ~]# yum -y install ntp

[root@nat ~]# ntpdate cn.ntp.org.cn

[root@nat ~]# systemctl start ntpd

[root@nat ~]# systemctl enable ntpd

  1. 停用其他服务

停用selinux

setenforce 0

sed -i '/SELINUX=enforcing/cSELINUX=disabled'

/etc/selinux/config

#停用防火墙

systemctl stop firewalld

systemctl disable firewalld &>/dev/null

停用NetworkManage

systemctl stop NetworkManager

systemctl disable NetworkManager &>/dev/null

  1. 添加web服务器(web01 10.1.1.200,web02 10.1.1.201)11. 配置dns服务器

  2. yuanyu.zhangmin

web01.yuanyu.zhangmin x.x.x.200

Web02.yuanyu.zhangmin x.x.x.201

nat.yuanyu.zhangmin

x.x.x.100

Ds.yuanyu.zhangmin

x.x.x.110

  1. 配置client客户测试机

设置主机名称

关闭防火墙

固定ip地址

关闭SELinux

关闭NetworkManager

安装nginx

修改index.html文件

时间同步

启动服务

修改主机名称

固定ip

关闭防火墙

关闭SELinux

关闭NetManager

安装bind的

yum -y install bind

配置主配置文件

vim /etc/named.conf

配置zones文件

vim /etc/named.rfc...zones

配置zone文件

vim /var/named/...zone

同步时间

启动服务13.

主机名

ip地址

功能

web01.yuanyu.zhangmin

192.168.71.132

rs

realserver

Web02.yuanyu.zhangjin

192.168.71.133

rs.

Realserver

Nat.yuanyu.zhangmin

Vip

192.168.71.171.

dip

192.168.71.170

ds. Director

serrver,ntp

dns.yuanyu.zhangmin

192.168.71.149

Dns

清单

6.NAT模式搭建实战

  1. nat服务器配置

  2. Itvs. Ip vartual server 已经是内核应用,无法修改

  3. ipvsadm这个工具管理服务

临时指定dns服务器

永久指定dns服务器

安装ipvsadm

[root@nat ~]# yum -y install ipvsadm2. web服务器网关配置

7.NAT模式修改操作

1.修改

清空以往的规则

[root@nat ~]# ipvsadm -C

查看规则

[root@nat ~]# ipvsadm -L -n

新增规则

[root@nat ~]# ipvsadm -A -t 192.168.0.100:80 -s rr

添加主机

[root@nat ~]# ipvsadm -a -t 192.168.0.100:80 -r

10.1.1.200:80 -m

[root@nat ~]# ipvsadm -a -t 192.168.0.100:80 -r

10.1.1.201:80 -m

设置ip转发

[root@nat ~]# vim /etc/sysctl.conf

============================================

net.ipv4.ip_forward=1

============================================

设置生效

[root@nat ~]# sysctl -p

net.ipv4.ip_forward = 1

[root@web01 ~]# route del default

[root@web01 ~]# route add default gw 10.1.1.100

[root@web02 ~]# route del default

[root@web02 ~]# route add default gw 10.1.1.1008.DR模式工作原理

9.DR模式的搭建实战

配置vip网卡

  1. 在编辑虚拟网络中创建桥接模式的网卡,并且桥接到有网的适配器上

  2. 在vmware的虚拟主机资源管理器找到虚拟主机,右键菜单,设置

  3. 添加新的网卡,自定义为刚才创建的桥接模式网卡

  4. 此时在虚拟主机中使用ifconfig无法找到新的网卡

  5. ip a能够查看到新的ens36网卡,没有路由

  6. 编辑网卡配置

  7. 重启network服务

添加规则

TYPE="Ethernet"

BOOTPROTO="none"

NAME="ens36"

UUID="fdbcb12c-33b6-4d7d-93bb-3b5380c4fb30"

DEVICE="ens36"

ONBOOT="yes"

IPADDR=192.168.10.100

[root@ds01 ~]# systemctl restart network

[root@ds01 ~]# # 配置ipvs规则

[root@ds01 ~]# ipvsadm -A -t 192.168.10.100:80 -s rr

[root@ds01 ~]# ipvsadm -Ln

IP Virtual Server version 1.2.1 (size=4096)

Prot LocalAddress:Port Scheduler Flags

-> RemoteAddress:Port Forward Weight

ActiveConn InActConnip转发

TCP 192.168.10.100:80 rr

[root@ds01 ~]# # 添加rs web01 web02 添加规则

[root@ds01 ~]# ipvsadm -a -t 192.168.10.100:80 -r

10.1.1.200:80 -m

[root@ds01 ~]# ipvsadm -a -t 192.168.10.100:80 -r

10.1.1.201:80 -m

[root@ds01 ~]# ipvsadm -Ln

IP Virtual Server version 1.2.1 (size=4096)

Prot LocalAddress:Port Scheduler Flags

-> RemoteAddress:Port Forward Weight

ActiveConn InActConn

TCP 192.168.10.100:80 rr

-> 10.1.1.200:80 Masq 1 0

0

-> 10.1.1.201:80 Masq 1 0

0

[root@ds01 ~]# vim /etc/sysctl.conf

##########################################

net.ipv4.ip_forward=1

#############################################

[root@ds01 ~]# sysctl -p

net.ipv4.ip_forward = 1临时修改web01和web02的网

关,网关必须指向dip(调度服务

器的对内的ip)

lvs-nat模式的优点配置简单,缺点是请求和响应都必须经过ds,容易称为

性能瓶颈

希望有这样的模式,请求的时候使用input链进行负载均衡,响应的时候就

不要经过ds,直接由rs响应给客户端

在nat模式的时候,请求vip,接收vip的响应

构想 请求vip,接受rip响应,这是不允许 lvs-dr模式

vip 请求 rip响应

NAT脚本

[root@web01 ~]# route del default

[root@web01 ~]# route add default gw 10.1.1.100

[root@web01 ~]# # 临时修改网关

这也要求了rs ip和 dip要在同一个网段,因为dip是要作为网关存在的

ds脚本

#!/bin/bash

#配置网卡

echo TYPE="Ethernet" >> /etc/sysconfig/network

scripts/ifcfg-ens36

echo BOOTPROTO="none" >> /etc/sysconfig/network

scripts/ifcfg-ens36

read -p "router name:" router_name

echo NAME='"$rount_name"' >> /etc/sysconfig/network

scripts/ifcfg-ens36

uuidkey=( uuidgen )echo UUID='"uuidkey"' >> /etc/sysconfig/network

scripts/ifcfg-ens36 >> /etc/sysconfig/network

scripts/ifcfg-ens36

echo DEVICE='"$rount_name"' >> /etc/sysconfig/network

scripts/ifcfg-ens36

echo ONBOOT="yes" >> /etc/sysconfig/network-scripts/ifcfg

ens36

echo IPADDR=192.168.10.100 >> /etc/sysconfig/network

scripts/ifcfg-ens36

systemctl restart network

#安装ipvsadm

yum list installed|grep ipvsadm

if[ $? -ne 0 ];then

yum -y install ipvsadm

fi

#配置规则

read -p "vip:" vip

read -p "port:" port

read -p "rule:" s

ipvsadm -A -t vip:port -s $s

ip forward

echo "net.ipv4.ip_forward=1" >/etc/sysctl.conf

sysctl -p

rs脚本

#!/bin/bash

read -p "dip:" dip

设置网关

route del default

route add defualt gw $dip

DR模式

1.性能更优,回路不再经过ds

2.ds和rs为了保证用户响应,都要求配置统一的vip3.由于rs是直接响应client,网关一定不能设置为ds 的dip

4.对rs的vip进行抑制,让ds的vip接收请求,rs的vip不接受请求

5.rs的vip绑定点lo回路网卡上

1.在ds的ens33上挂一个vip 10.1.1.102

[root@dr03 ~]# ifconfig

ens33: flags=4163<UP,BROADCAST,RUNNING,MULTICAST> mtu

1500

inet 10.1.1.101 netmask 255.255.255.0 broadcast

10.1.1.255

inet6 fe80::20c:29ff:fe38:97fb prefixlen 64

scopeid 0x20<link>

ether 00:0c:29:38:97:fb txqueuelen 1000

(Ethernet)

RX packets 153 bytes 16165 (15.7 KiB)

RX errors 0 dropped 0 overruns 0 frame 0

TX packets 144 bytes 15826 (15.4 KiB)

TX errors 0 dropped 0 overruns 0 carrier 0

collisions 0

lo: flags=73<UP,LOOPBACK,RUNNING> mtu 65536

inet 127.0.0.1 netmask 255.0.0.0

inet6 ::1 prefixlen 128 scopeid 0x10<host>

loop txqueuelen 1000 (Local Loopback)

RX packets 64 bytes 5568 (5.4 KiB)

RX errors 0 dropped 0 overruns 0 frame 0

TX packets 64 bytes 5568 (5.4 KiB)

TX errors 0 dropped 0 overruns 0 carrier 0

collisions 0

[root@dr03 ~]# ifconfig ens33:0 10.1.1.102 broadcat

10.1.1.102 netmask 255.255.255.255 upbroadcat: 未知的主机

ifconfig: `--help' gives usage information.

[root@dr03 ~]# ifconfig ens33:0 10.1.1.102 broadcast

10.1.1.102 netmask 255.255.255.255 up

[root@dr03 ~]# ifconfig

ens33: flags=4163<UP,BROADCAST,RUNNING,MULTICAST> mtu

1500

inet 10.1.1.101 netmask 255.255.255.0 broadcast

10.1.1.255

inet6 fe80::20c:29ff:fe38:97fb prefixlen 64

scopeid 0x20<link>

ether 00:0c:29:38:97:fb txqueuelen 1000

(Ethernet)

RX packets 399 bytes 38090 (37.1 KiB)

RX errors 0 dropped 0 overruns 0 frame 0

TX packets 300 bytes 32758 (31.9 KiB)

TX errors 0 dropped 0 overruns 0 carrier 0

collisions 0

ens33:0: flags=4163<UP,BROADCAST,RUNNING,MULTICAST> mtu

1500

inet 10.1.1.102 netmask 255.255.255.255

broadcast 10.1.1.102

ether 00:0c:29:38:97:fb txqueuelen 1000

(Ethernet)

lo: flags=73<UP,LOOPBACK,RUNNING> mtu 65536

inet 127.0.0.1 netmask 255.0.0.0

inet6 ::1 prefixlen 128 scopeid 0x10<host>

loop txqueuelen 1000 (Local Loopback)

RX packets 64 bytes 5568 (5.4 KiB)

RX errors 0 dropped 0 overruns 0 frame 0

TX packets 64 bytes 5568 (5.4 KiB)

TX errors 0 dropped 0 overruns 0 carrier 0

collisions 0[root@dr03 ~]# ip a

1: lo: <LOOPBACK,UP,LOWER_UP> mtu 65536 qdisc noqueue

state UNKNOWN group default qlen 1000

link/loopback 00:00:00:00:00:00 brd 00:00:00:00:00:00

inet 127.0.0.1/8 scope host lo

valid_lft forever preferred_lft forever

inet6 ::1/128 scope host

valid_lft forever preferred_lft forever

2: ens33: <BROADCAST,MULTICAST,UP,LOWER_UP> mtu 1500 qdisc

pfifo_fast state UP group default qlen 1000

link/ether 00:0c:29:38:97:fb brd ff:ff:ff:ff:ff:ff

inet 10.1.1.101/24 brd 10.1.1.255 scope global ens33

valid_lft forever preferred_lft forever

inet 10.1.1.102/32 brd 10.1.1.102 scope global ens33:0

valid_lft forever preferred_lft forever

inet6 fe80::20c:29ff:fe38:97fb/64 scope link

valid_lft forever preferred_lft forever

[root@dr03 ~]# route add -host 10.1.1.102 dev ens33:0

10.1.1.101 dip

10.1.1.102 vip 在rs上的vip和这个vip相同

2.设置规范设置rs主机

1.在lo接口上绑定vip

2.设置主机路由

3.抑制rs接收请求

4.生成脚本,对web02使用

安装ipvsadm

yum -y install ipvsadm

$ 设置规则

ipvsadm -A -t 10.1.1.102:80 -s rr

ipvsadm -a -t 10.1.1.102:80 -r 10.1.1.200 -g

ipvsadm -a -t 10.1.1.102:80 -r 10.1.1.201 -g

rs不在需要指定端口,dr不支持端口映射,vip上是80端口,最终就是80端

-m nat -g gateway

[root@web01 ~]# ifconfig lo:0 10.1.1.102 broadcast

10.1.1.102 netmask 255.255.255.255 up

[root@web01 ~]# route add -host 10.1.1.102 dev lo:0

echo 1 > /proc/sys/net/ipv4/conf/lo/arp_ignore

echo 2 > /proc/sys/net/ipv4/conf/lo/arp_announce

echo 1 > /proc/sys/net/ipv4/conf/all/arp_ignore

echo 2 > /proc/sys/net/ipv4/conf/all/arp_announce5.测试使用,查看状态

dr模式的脚本

ds脚本

ifconfig lo:0 10.1.1.102 broadcast 10.1.1.102 netmask

255.255.255.255 up

route add -host 10.1.1.102 dev lo:0

echo 1 > /proc/sys/net/ipv4/conf/lo/arp_ignore

echo 2 > /proc/sys/net/ipv4/conf/lo/arp_announce

echo 1 > /proc/sys/net/ipv4/conf/all/arp_ignore

echo 2 > /proc/sys/net/ipv4/conf/all/arp_announce

[root@dr03 ~]# ipvsadm -Ln --stats

IP Virtual Server version 1.2.1 (size=4096)

Prot LocalAddress:Port Conns InPkts

OutPkts InBytes OutBytes

-> RemoteAddress:Port

TCP 10.1.1.102:80 1 6

0 360 0

-> 10.1.1.200:80 0 0

0 0 0

-> 10.1.1.201:80 1 6

0 360 0

[root@dr03 ~]#

#!/bin/bash

#在ens33上挂载一个ip地址

read -p "vip:" vip

read -p "mac:" mac

read -p "num" num

ifconfig mac:num $vip broadcast $vip netmask

255.255.255.255

主机路由

route add -host $vip dev mac:num#安装ipvsadm

yum list installed|grep ipvsadm

if [ $? -ne 0 ] ; then

yum -y install ipvsadm

fi

#配置规则(不需要设置ip_forword)

ipvsadm -C

read -p "rule:" rule

read -p "port:" port

ipvsadm -A -t vip:port -s $rule

read -p "rip1:" rip1

ipvsadm -a -t vip:port -r $rip1 -g

read -p "rip2:" rip2

ipvsadm -a -t vip:port -r $rip2 -g

rs脚本

#!/bin/bash

#在ens33上挂载一个ip地址

read -p "vip:" vip

read -p "mac:" mac

read -p "num" num

ifconfig mac:num $vip broadcast $vip netmask

255.255.255.255

主机路由

route add -host $vip dev mac:num

echo 1 > /proc/sys/net/ipv4/conf/lo/arp_ignore

echo 2 > /proc/sys/net/ipv4/conf/lo/arp_announce

echo 1 > /proc/sys/net/ipv4/conf/all/arp_ignore

echo 2 > /proc/sys/net/ipv4/conf/all/arp_announce

练习:对mysql的服务进行负载均衡编号

姓名

班级

宿舍

1001

孙颖莎

云计算1班

1002

1002

李雯雯

掰苹果2班

1003

1003

孙杨

老年组4班

504

1.配置mysql主机 x.x.x.21,命名为master_mysql.xxx.xxx,激活并且添加数

据库test

2.在test中添加表student id int 主键,自增,name 字符串类型 非空 ,

grade 字符串 非空,domi varchar 非空

3.添加三行数据

3.配置mysql从服务,备份mysqlx.x.x.22的mysql服务,使用gtids同步事

务。

4.lvs对两台mysql主机进行rr负载均衡

5.使用python写一个脚本通过lvs ds主机读取mysql中的数据

6.自动化程度越高越好

相关推荐
Thanks_ks2 小时前
探索计算机互联网的奇妙世界:从基础到前沿的无尽之旅
物联网·云计算·区块链·tcp/ip协议·计算机互联网·万维网·未来科技
IT技术分享社区2 小时前
C#实战:使用腾讯云识别服务轻松提取火车票信息
开发语言·c#·云计算·腾讯云·共识算法
九河云9 小时前
AWS账号注册费用详解:新用户是否需要付费?
服务器·云计算·aws
神一样的老师9 小时前
利用亚马逊AWS IoT核心和MQTT进行数据采集的综合指南
云计算·aws
昔我往昔15 小时前
阿里云文本内容安全处理
安全·阿里云·云计算
写代码的学渣18 小时前
Linux云计算个人学习总结(一)
linux·运维·云计算
林农19 小时前
C02S11-Linux系统的安全与控制
linux·云计算
danns8881 天前
什么是 AWS PrivateLink
云计算·aws
shiran小坚果1 天前
AWS RDS MySQL内存使用
数据库·mysql·云计算·database·aws