大数据,机器学习,人工智能

[ZooKeeper]初步认识

2018-06-13  本文已影响1人  瑾兰

前言

在学习任何技术知识的时候,一定要思考他的本质!
3w原则想必都听过:why、what、how。大why,小what,和一带而过的how。对于这些实践性很强的知识,我们还要熟练应用。
清晰准确地表达明白原因,其实也是在测试自己是否真的理解了。

一、为什么出现Zookeeper

在这里以电商架构为例子,在很早之前我们采用的是单一的应用架构,即前台client请求service。随着互联网的发展和体系的扩大,后端建构通过垂直伸缩(升级到更强大的服务器:多CPU 昂贵大中型机 )的方式很难达到我们期望的性能要求,同时投入产出比也非常大,同时普通PC性能也越来越高,所以通过水平伸缩(增加更便宜的机器)的方式来提升性能成为了主流。

在分布式架构下,当服务越来越多时,规模越来越大时,对应的机器数量也越来越来越多,单靠人工来管理和维护及地址的配置、地址信息也越来越困难,单点故障问题也开始凸显出来,一旦服务器路由或者负载均衡服务器宕机,依赖他的所有服务均将失效。

​ 此时,需要一个能够动态注册获取服务信息的地方,来统一管理服务名称和其对应的服务器列表信息(称为:服务配置中心)。当服务提供者在启东时,将其提供的服务名称、服务器地址注册到服务配置中心;服务消费者通过服务配置中心来获得需要调用的服务机器列表。通过相应的负载均衡算法,选取其中一台服务器进行调用。当服务器宕机或者下线时,相应的机器需要能够动态地从服务配置中心里面移除,并通知相应的服务消费者,否则服务消费者就有可能因为调用已经失效的服务而发生错误。

在这个过程中,服务消费者只有在第一次调用服务时,需要查询服务配置中心,然后将查询到的信息缓存到本地,后面的调用直接使用本地缓存的服务地址列表信息而不需要重复发起请求到服务配置中心,去获取相应的服务地址列表,直到服务地址列表有变化(机器上线,或者下线)。这种无中心化的结构,解决了之前负载均衡设备所导致的单点故障问题,并且大大减轻了服务配置中心的压力。

二、什么是zookeeper

zookeeper是一个分布式协调服务。其本质就是:协调协调、协调。协调的是服务。

也可以这样理解:zookeeper就是一个服务注册和获取服务地址、名称信息的中间件。

其目的就是将那些复杂且容易出错的分布式一致性服务封装起来,方便提供给用户使用。

三、如何安装部署ZooKeeper

zookeeper有两种运行模式:集群模式和单击模式。

安装:下载zookeeper的安装包,解压安装即可:tar -zxvf

常用命令:

命令 含义
bin/zkServer.sh start 启动ZK服务
bin/zkServer.sh status 查看ZK服务状态
bin/zkServer.sh stop 停止ZK服务
bin/zkServer.sh restart 重启ZK服务
zkCli.sh 启动ZK客户端
zkCli.sh -timeout 0 -r -server ip:port 链接服务器
1 、单击模式安装:

解压便可使用。将conf目录写的zoo_sample.cfg文件copy一份重命名zoo.cfg。修改dataDir目录(日志文件存放路径)。

2 、集群环境安装:

Zookeeper集群安装(基于JDK之上)。
在 zookeeper 集群中,各个节点总共有三种角色,分别是: leader,follower,observer 。

在zookeeper集群中,我们采用模拟3台机器来搭建zookeeper集群(或者用一台机器安装kvm虚拟出三台)。分别复制安装包到三台机器上并解压,同时copy一份zoo.cfg.

注意:

四、重点注意的配置文件

上一篇 下一篇

猜你喜欢

热点阅读