1. Zookeeper 综述
1.1.zk总体介绍
整个 ZK 体系会从入门开始,到基础,进阶以及实战,最后把相关的理论给介绍一下。
1.1.1. 为什么学习 ZK
应该重点掌握分布式环境的演进过程,从一个单节点开始,慢慢过渡到分布式,为什么单节点不行,传统一个 tomcat 打天下有什么优点,缺点又是什么,当一个 tomcat 搞不定的时候,分布式的架构图又是什么样的。
传统的单节点架构自然有问题,到了分布式的架构中,问题肯定也有不少,这些问题就是我们学习 ZK 要解决的,但学习这些解决方案之前,还是需要有点理论基础。接下来就要了解下什么是 zk,为什么学习 zk, zk 在分布式架构中扮演了什么样的角色。
1.1.2. zookeeper 基础
了解 zk 是什么玩意后,接下来就把 zk 安装好,先来讲解的是 zk 单机部署,这个非常容易,而且后面绝大部的时间都是使用单节点来使用的,至于集群的配置放到后面来讲,如果正在在工作中,集群的维护应该是运维来做,哪怕没有运维,在后面通过详细的学习通过也能在20 分钟内完全搭建起来。
Zk 的特性:这块是重点之中的重点,后面学习的一切操作,包括实战,都是建立在这基础之上的。其中数据模型和 watch 机制又是最最重要的。
1.1.3. zk 进阶
安装好了 zk,对 zk 基础有一定的了解后,接下来就学习怎么操作 zk,首先了解基础 zk 客户端的使用。
客户端的简单使用能解决一些问题,方便查看信息,简单省事,但真正对于我们 java 架构师来说最重要的是 java 客户端,包括原生的,zkclient 以及 curotor,最少要熟练使用其中的一种,另外的在工作中也要很快的百度得出来。
1.1.4. zk 的实战
一般来说 zk 实战是放到最后来讲得,但这一块确是面试得时候经常会碰到的,所以先提前,这一块是整个课程的重点,会讲到配置中心,负载均衡,分布式锁,集群选举,尤其是负载均衡。
1.1.5. zk 高级知识
这一块不需要完全听懂,掌握 40%-50%就够了,工作中很少用到,但确实面试的时候的加分项,包括 2pc,3pc 提交协议,集群的安装等等。
1.1.6. 总结:不管怎么样,其中的 zk 基础,zk 进阶客户端的使用,以及 zk 项目实战请务必重视起来。
1.2.分布式系统基础知识
一个 tomcat 打天下的时代,不能说完全淘汰了,在一个管理系统,小型项目中还经常使用,这并不过分,出于成本的考虑,这反而值得提倡。
1.2.1. 分布式系统是什么
分布式系统:一个硬件或软件组件分布在不同的网络计算机上,彼此之间仅仅通过消息传递进行通信和协调的系统。
这是分布式系统,在不同的硬件,不同的软件,不同的网络,不同的计算机上,仅仅通过消息来进行通讯与协调。
这是他的特点,更细致的看这些特点又可以有:分布性、对等性、并发性、缺乏全局时钟、故障随时会发生。
1.2.1.1. 分布性
既然是分布式系统,最显著的特点肯定就是分布性,从简单来看,如果我们做的是个电商项目,整个项目会分成不同的功能,专业点就不同的微服务,比如用户微服务,产品微服务,订单微服务,这些服务部署在不同的 tomcat 中,不同的服务器中,甚至不同的集群中,整个架构都是分布在不同的地方的,在空间上是随意的,而且随时会增加,删除服务器节点,这是第一个特性。
1.2.1.2. 对等性
对等性是分布式设计的一个目标,还是以电商网站为例,来说明下什么是对等性,要完成一个分布式的系统架构,肯定不是简单的把一个大的单一系统拆分成一个个微服务,然后部署在不同的服务器集群就够了,其中拆分完成的每一个微服务都有可能发现问题,而导致整个电商网站出现功能的丢失。
比如订单服务,为了防止订单服务出现问题,一般情况需要有一个备份,在订单服务出现问题的时候能顶替原来的订单服务。这就要求这两个(或者 2 个以上)订单服务完全是对等的,功能完全是一致的,其实这就是一种服务副本的冗余。
还一种是数据副本的冗余,比如数据库,缓存等,都和上面说的订单服务一样,为了安全考虑需要有完全一样的备份存在,这就是对等性的意思。
1.2.1.3. 并发性
并发性其实对我们来说并不陌生,在学习多线程的时候已经或多或少学习过,多线程是并发的基础。
但现在我们要接触的不是多线程的角度,而是更高一层,从多进程,多 JVM 的角度,例如在一个分布式系统中的多个节点,可能会并发地操作一些共享资源,如何准确并高效的协调分布式并发操作。后面实战部分的分布式锁其实就是解决这问题的。
1.2.1.4. 缺乏全局时钟
在分布式系统中,节点是可能反正任意位置的,而每个位置,每个节点都有自己的时间系统,因此在分布式系统中,很难定义两个事务纠结谁先谁后,原因就是因为缺乏一个全局的时钟序列进行控制,当然,现在这已经不是什么大问题了,已经有大把的时间服务器给系统调用。
1.2.1.5. 故障随时会发生
任何一个节点都可能出现停电,死机等现象,服务器集群越多,出现故障的可能性就越大,随着集群数目的增加,出现故障甚至都会成为一种常态,怎么样保证在系统出现故障,而系统还是正常的访问者是作为系统架构师应该考虑的。
1.2.2.大型网站架构图回顾
知道什么是分布式系统,接下来具体来看下大型网站架构图,这个图在前面分布式架构演进应该已经讲过,首先整个架构分成很多个层,应用层,服务层,基础设施层与数据服务层,每一层都由若干节点组成,这是典型的分布式架构,后面一大把的时间就是系统的学习里面的每一个部分。
那么 zookeeper 在其中又是扮演什么角色呢,如果可以把 zk 扮演成交警的角色,而各个节点就是马路上的各种汽车(汽车,公交车),为了保证整个交通(系统)的可用性,zookeeper必须知道每一节点的健康状态(公交车是否出了问题,要派新的公交【服务注册与发现】),公路在上下班高峰是否拥堵,在某一条很窄的路上只允许单独一个方向的汽车通过【分布式锁】。
如果交通警察是交通系统的指挥官,而 zookeeper 就是各个节点组成分布式系统的指挥官。
1.2.2.1. 分布式系统协调“方法论”
1.2.2.1.1. 分布式系统带来的问题
如果把分布式系统和平时的交通系统进行对比,哪怕再稳健的交通系统也会有交通事故,分布式系统也有很多需要攻克的问题,比如:通讯异常,网络分区,三态,节点故障等。
1.2.2.1.1.1.通信异常
通讯异常其实就是网络异常,网络系统本身是不可靠的,由于分布式系统需要通过网络进行数据传输,网络光纤,路由器等硬件难免出现问题。只要网络出现问题,也就会影响消息的发送与接受过程,因此数据消息的丢失或者延长就会变得非常普遍。
1.2.2.1.1.2.网络分区
网络分区,其实就是脑裂现象,本来有一个交通警察,来管理整个片区的交通情况,一切井然有序,突然出现了停电,或者出现地震等自然灾难,某些道路接受不到交通警察的指令,可能在这种情况下,会出现一个零时工,片警零时来指挥交通。但注意,原来的交通警察其实还在,只是通讯系统中断了,这时候就会出现问题了,在同一个片区的道路上有不同人在指挥,这样必然引擎交通的阻塞混乱。
这种由于种种问题导致同一个区域(分布式集群)有两个相互冲突的负责人的时候就会出现,这种精神分裂的情况,在这里称为脑裂,也叫网络分区。
1.2.2.1.1.3.三态
三态是什么?三态其实就是成功,与失败以外的第三种状态,当然,肯定不叫变态,而叫超时态。
在一个 jvm 中,应用程序调用一个方法函数后会得到一个明确的相应,要么成功,要么失败,而在分布式系统中,虽然绝大多数情况下能够接受到成功或者失败的相应,但一旦网络出现异常,就非常有可能出现超时,当出现这样的超时现象,网络通讯的发起方,是无法确定请求是否成功处理的。
1.2.2.1.1.4.节点故障
这个其实前面已经说过了,节点故障在分布式系统下是比较常见的问题,指的是组成服务器集群的节点会出现的宕机或“僵死”的现象,这种现象经常会发生。
1.2.2.1.2. CAP 理论
前面花费了很大的篇幅来了解分布式的特点以及会碰到很多会让人头疼的问题,这些问题肯定会有一定的理论思想来解决问题的。
接下来花点时间来谈谈这些理论,其中 CAP 和 BASE 理论是基础,也是面试的时候经常会问到的;
首先看下 CAP,CAP 其实就是一致性,可用性,分区容错性这三个词的缩写。
1.2.2.1.2.1.一致性
一致性是事务 ACID 的一个特性【原子性(Atomicity)、一致性(Consistency)、隔离性(Isolation)、持久性(Durability)】。
这里讲的一致性其实大同小异,只是现在考虑的是分布式环境中,还是不单一的数据库。
在分布式系统中,一致性是数据在多个副本之间是否能够保证一致的特性,这里说的一致性和前面说的对等性其实差不多。如果能够在分布式系统中针对某一个数据项的变更成功执行后,所有用户都可以马上读取到最新的值,那么这样的系统就被认为具有【强一致性】。
1.2.2.1.2.2.可用性
可用性指系统提供服务必须一直处于可用状态,对于用户的操作请求总是能够在有限的时间内访问结果。
这里的重点是【有限的时间】和【返回结果】;
为了做到有限的时间需要用到缓存,需要用到负载,这个时候服务器增加的节点是为性能考虑;
为了返回结果,需要考虑服务器主备,当主节点出现问题的时候需要备份的节点能最快的顶替上来,千万不能出现 OutOfMemory 或者其他 500,404 错误,否则这样的系统我们会认为是不可用的。
1.2.2.1.2.3.分区容错性
分布式系统在遇到任何网络分区故障的时候,仍然需要能够对外提供满足一致性和可用性的服务,除非是整个网络环境都发生了故障,不能出现脑裂的情况。
1.2.2.1.2.4.具体描述
来看下 CAP 理论具体描述:一个分布式系统不可能同时满足一致性、可用性和分区容错性这三个基本需求,最多只能同时满足其中的两项:
TIPS:不可能把所有应用全部放到一个节点上,因此架构师的精力往往就花在怎么样根据业务场景在 A 和 C 直接寻求平衡。
1.2.2.1.3. BASE 理论
根据前面的 CAP 理论,架构师应该从一致性和可用性之间找平衡,系统短时间完全不可用肯定是不允许的,那么根据 CAP 理论,在分布式环境下必然也无法做到强一致性。
BASE 理论:即使无法做到强一致性,但分布式系统可以根据自己的业务特点,采用适当的方式来使系统达到最终的一致性。
1.2.2.1.3.1. Basically Avaliable 基本可用
当分布式系统出现不可预见的故障时,允许损失部分可用性,保障系统的“基本可用”;体现在“时间上的损失”和“功能上的损失”;e.g:部分用户双十一高峰期淘宝页面卡顿或降级处理。
1.2.2.1.3.2. Soft state 软状态
其实就是前面讲到的三态,既允许系统中的数据存在中间状态,既系统的不同节点的数据副本之间的数据同步过程存在延时,并认为这种延时不会影响系统可用性;e.g:12306 网站卖火车票,请求会进入排队队列。
1.2.2.1.3.3. Eventually consistent 最终一致性
所有的数据在经过一段时间的数据同步后,最终能够达到一个一致的状态;e.g:理财产品首页充值总金额短时不一致;
1.3.Zookeeper 简介
1.3.1. Zookeeper 简介(what)
ZooKeeper 致力于提供一个高性能、高可用,且具备严格的顺序访问控制能力的分布式协调服务,是雅虎公司创建,是 Google 的 Chubby 一个开源的实现,也是 Hadoop 和 Hbase 的重要组件。
1.3.1.1. 设计目标
简单的数据结构:共享的树形结构,类似文件系统,存储于内存;
可以构建集群:避免单点故障,3-5 台机器就可以组成集群,超过半数正常工作就能对外提供服务;
顺序访问:对于每个读请求,zk 会分配一个全局唯一的递增编号,利用这个特性可以实现高级协调服务;
高性能:基于内存操作,服务于非事务请求,适用于读操作为主的业务场景。3 台 zk集群能达到 13w QPS;
1.3.2. 哪些常见需要用到 ZK(why)
数据发布订阅
负载均衡
命名服务
Master 选举
集群管理
配置管理
分布式队列
分布式锁
1.3.3. 为什么要学习 zookeeper?(why)
1.互联网架构师必备技能
2.高端岗位必考察的知识点
3.zk 面试问题全解析
Zookeeper 是什么框架
应用场景
Paxos 算法& Zookeeper 使用协议
选举算法和流程
Zookeeper 有哪几种节点类型
Zookeeper 对节点的 watch 监听通知是永久的吗?
部署方式?集群中的机器角色都有哪些?集群最少要几台机器
集群如果有 3 台机器,挂掉一台集群还能工作吗?挂掉两台呢?
集群支持动态添加机器吗?
网友评论