群集的含义
由多台主机构成,但对外表现为一个整体,只提供一个访问入口,相当于一台大型的计算机。
横向发展:放更多的服务器,有调度分配的问题。
垂直发展:升级单机的硬件设备,提高单个服务器自身功能。
集群类型:
data:image/s3,"s3://crabby-images/b1d89/b1d896357fb92fe04dee19b0748f02d1c2c8d556" alt=""
分布式系统
把任务分布下去,比如一个程序,分布在不同的电脑上组成,一台服务器不够,多台服务器处理同一任务。
data:image/s3,"s3://crabby-images/bacde/bacdeef824a66ea7620bbe333609b6913e8b4519" alt=""
集群与分布式区别
data:image/s3,"s3://crabby-images/1029e/1029e77dbd9e3582b1363aedfb9e90fa34e21723" alt=""
集群:同一个业务系统,部署在多台服务器上。集群中,每一台服务器实现的功能没有差别,数据和代码都是一样的。
分布式:一个业务被拆成多个子业务,或者本身就是不同的业务,部署在多台服务器上。分布式中,每一台服务器实现的功能是有差别的,数据和代码也是不一样的,分布式每台服务器功能加起来,才是完整的业务。
集群设计原则
可扩展性---集群的横向扩展能力
可用性---无故障时间 (SLA service level agreement)
性能---访问响应时间
容量---单位时间内的最大并发吞吐量(C10K 并发问题)
负载均衡集群
按实现方式划分
data:image/s3,"s3://crabby-images/12f60/12f603d4d7c3b01b4eb478dfce32f3830e3acfa3" alt=""
data:image/s3,"s3://crabby-images/0efad/0efad57a211ff2095c099b2086f897e770c728a1" alt=""
基于工作的协议层次划分
传输层(通用):DNAT 和 DPORT
传输层(通用):DNAT 和 DPORT
LVS:(中型)
nginx:stream(小型)
haproxy:mode tcp(不常用)
应用层(专用):针对特定协议,常称为 proxy server
http:nginx, httpd, haproxy(mode http), ...
fastcgi:nginx, httpd, ...
mysql:mysql-proxy, mycat... mycat:表示mysql读写分离
负载均衡集群架构
data:image/s3,"s3://crabby-images/cad1f/cad1fd6ed0ed8e96aeab8b8a26bd505a9da97b90" alt=""
lvs是内核里面的功能,可以用以下命令,在编译lvs时,可以看见开启或者关闭哪些模块的功能
grep -i -C 10 ipvs /boot/config-3.10.0-693.el7.x86_64
data:image/s3,"s3://crabby-images/65b48/65b48b02a5c06dc5e0057b215850a8c6f9461207" alt=""
并且可以看见调度算法
data:image/s3,"s3://crabby-images/0ab5d/0ab5dc3d112a635fa38a672d9c8beb508d36c63a" alt=""
lvs集群中的术语
VS:代理服务器 Virtual Server,Director Server(DS), Dispatcher(调度器),Load Balancer(lvs服务器)
RS:真实服务器Real Server(lvs), upstream server(nginx), backend server(haproxy)(真实服务器)
CIP:客户机Client IP(客户机IP)
VIP:代理服务器外网ip Virtual serve IP VS外网的IP
DIP:代理服务器内网ipDirector IP VS内网的IP
RIP:真实服务器的ip Real server IP (真实IP)
data:image/s3,"s3://crabby-images/92d81/92d8180d88fe72352a6514ff3e057fe8048471ee" alt=""
data:image/s3,"s3://crabby-images/52d2b/52d2b72b8e1985e5a6efe2b64833a93d873a7318" alt=""
lvs工作模式
data:image/s3,"s3://crabby-images/27fad/27fad281c20ad8011e8db84c66ff637fa33d0b85" alt=""
lvs-nat:
文字版流程讲解:
data:image/s3,"s3://crabby-images/d87ee/d87ee79742f9eebb1457aa7e470331b64fb797fe" alt=""
lvs-nat:本质是多目标IP的DNAT,通过将请求报文中的目标地址和目标端口修改为某处的RS的RIP和PORT实现转发
(1)RIP和DIP应在同一个IP网络,且应使用私网地址;RS的网关要指向DIP
(2)请求报文和响应报文都必须经由lvs服务器转发,lvs服务器易于成为系统瓶颈
(3)支持端口映射,可修改请求报文的目标PORT
(4)VS必须是Linux系统,RS可以是任意OS系统
LVS调度算法
分为静态算法和动态算法
静态算法:不管后端服务器状态
1、RR:roundrobin,轮询,较常用
2、WRR:Weighted RR,加权轮询,较常用
3、SH:Source Hashing,实现session sticky,源IP地址hash;将来自于同一个IP地址的请求始终发往第一次挑中的RS,从而实现会话绑定
4、DH:Destination Hashing;目标地址哈希,第一次轮询调度至RS,后续将发往同一个目标地址的请求始终转发至第一次挑中的RS,典型使用场景是正向代理缓存场景中的负载均衡,如: Web缓存
动态算法:根据一个参考值overhead ,来看服务器是否忙
ipvsadm 工具
data:image/s3,"s3://crabby-images/54f7d/54f7d9e6b9584968b2a08ed5df3b1d1e7f649bff" alt=""
NAT模式,LVS负载均衡部署
data:image/s3,"s3://crabby-images/ca10a/ca10acbc41b5813d57b67c59e04ef864afedbb73" alt=""
data:image/s3,"s3://crabby-images/347bd/347bde43047a1f454f517154ba9655701370ab30" alt=""
第一步 四台服务器全部关闭防火墙+防护
data:image/s3,"s3://crabby-images/0a747/0a74714bb75a4ecf4da9b8d63eccf3f12e90d41c" alt=""
data:image/s3,"s3://crabby-images/1506f/1506f4ba2124772ef0f121ed2f812ed7c0002969" alt=""
NFS服务器上配置:
先下载nfs
data:image/s3,"s3://crabby-images/46583/46583b42a4a6cb4aaf19c2405b90bbfe09b0c99c" alt=""
然后去新建两个共享目录
data:image/s3,"s3://crabby-images/9a3d2/9a3d21863edf49cbe96806d6cc72e18897371c41" alt=""
主配置文件里面的内容:
data:image/s3,"s3://crabby-images/fc5d1/fc5d19fb04d7b5cbbd2e5e2041fc71a6e252ef1e" alt=""
随后,分别切换到bennt accp文件里面 去写一下文件内容
然后进到两台真实服务器里面centos2 centos3
真实服务器nginx httpd都可以
centos2 centos3相同 步骤:
data:image/s3,"s3://crabby-images/694e4/694e49cb226247d458fd9622d806e79edcab3bef" alt=""
data:image/s3,"s3://crabby-images/2d038/2d0386bb57aa69391fddf566b58303a927fa58a7" alt=""
centos2 挂载acpp到主页面里面
data:image/s3,"s3://crabby-images/b7081/b708151ff946f7ec3b7d6aacc2447ec1e73a51fb" alt=""
centos 3 将bennt挂载到主页面
data:image/s3,"s3://crabby-images/cc43c/cc43ccd38e7ce5980859104c93930a04363033e5" alt=""
可以通过showmout -e 查看共享的目录
data:image/s3,"s3://crabby-images/aa84e/aa84e3d26a99f4f1717afb03d7e81ddfa422abbb" alt=""
代理服务器配置
先下载ipvasdm 服务
data:image/s3,"s3://crabby-images/99428/994281d180551dcd6ffa731196e9aa43e6145966" alt=""
随后,因为代理服务器有内网跟外网,所以有两块网卡,在虚拟机里面添加一张网卡
data:image/s3,"s3://crabby-images/7f31c/7f31cb853e15589c82592d7b16d30fdba30c9948" alt=""
cpens33 到ens36 ens36就是代理服务器的外网(12.0.0.1)
data:image/s3,"s3://crabby-images/d9da1/d9da12f27cc221b705eb8804dac1dd0763a1be64" alt=""
然后修改一下ens33 跟ens36的配置文件,此时代理服务器为网关,ip地址要跟网关一样(因为自己就是网关)
ens33里面的配置:
data:image/s3,"s3://crabby-images/806fa/806fa34d20353d010cefea1d7b59b9b54336124b" alt=""
ens36配置
然后开启路由转发功能,如果不知道,可以用命令去查找
data:image/s3,"s3://crabby-images/dadc9/dadc9b0781b7220ccefe465a18988a6f3d86bedd" alt=""
复制此行,然后进入到systcl.conf的 主配置文件里面
data:image/s3,"s3://crabby-images/66467/66467e19c76710501e53073d0ebfab96372e428e" alt=""
然后查看一下 是否开启
data:image/s3,"s3://crabby-images/c53d6/c53d6e5c2d12b7e6f1b1993917720ccd8b2aa9fd" alt=""
如何开启ipvsadm服务。发现有错误
data:image/s3,"s3://crabby-images/90991/90991be5af76aba21ae3f70414c5132219a0b4e4" alt=""
如何查看 journalctl -xe
data:image/s3,"s3://crabby-images/88e58/88e582e2c37d06a23443b7ff1c9242ac3bdf86a4" alt=""
data:image/s3,"s3://crabby-images/9b9ad/9b9ad65d27c1354398ab8628c8cbbcc6350f5b64" alt=""
将文件导到这个目录下面 随后开启
data:image/s3,"s3://crabby-images/c6d5f/c6d5f8988fe06fb98bc493251851f1efef663fbf" alt=""
data:image/s3,"s3://crabby-images/56c29/56c29439e8c57ae29de2eb9578f0efe8d17b352b" alt=""
ipvsadm -A -t 12.0.0.1 (表示新建一个代理服务器 -t表示代理服务器外网的IP地址是12.0.0.1)
data:image/s3,"s3://crabby-images/825c5/825c52ba4b5ab3ba9102c5dbd4e58fec5d1bf321" alt=""
这边代理服务器的内网网关是192.168.68.3 后面真实的服务器要通的话,必须要将两台网关改成代理服务器的ip地址 centos2 centos3 都要修改网关
data:image/s3,"s3://crabby-images/73c53/73c530fd97b65dab382d54b011bc29180dbc4a88" alt=""
随后两台都要重启
data:image/s3,"s3://crabby-images/659bf/659bf76cee14950f894350c0029d8fa3afa1efd1" alt=""
然后在代理服务器上curl一下 代理服务器的外网 成功
data:image/s3,"s3://crabby-images/f5633/f5633c1c23196762be3df586cbc2434bfc78908b" alt=""