系统的伸缩性:系统不想要改变软硬件设计,只需要改变部署的服务器数量,就可以扩大或者缩小网站的服务处理能力。
名言:当一头牛拉不动车时,不要试图找一条更强壮的牛,而是找两头牛来拉车。
集群伸缩性 = 应用服务器集群伸缩性 + 数据服务器集群伸缩性
一、应用集群伸缩性
应用集群伸缩性利器:负载均衡,负载均衡手段:
1、HTTP重定向:第一次HTTP请求返回重定向302(响应码)请求和body包含负载均衡器返回的要重定向访问的IP。两次HTTP请求,性能较差。
2、DNS域名解析负载均衡:DNS中为网站域名配置多个IP,每次域名解析请求会根据负载均衡从中返回一个不同IP。优点:负载均衡交给DNS管理;缺点:DNS多级管理,每一级可能都会缓存A记录地址,当下线某台A的有效部署IP后,要每一级DNS都生效,还需要一定时间。期间的访问,可能会访问到被下线机器;
3、反向代理负载均衡:反向代理不仅可以缓存资源加速系统访问,一般还同时承担负载均衡职责。优点:和反向代理集成在一起部署简单;缺点:所有请求经过反向代理,会导致系统瓶颈。
4、IP负载均衡;
5、数据链路层负载均衡;
负载均衡算法: