什么是zookeeper?
本身就是分布式集群的服务(至少必须有三台zookeeper服务器才能正常运行起来),其中有一个主leader,其他的全为从节点。zookeeper其实内部本身只提供了两个功能(①:管理数据,包括增删改查;②:监听数据),由于有监听数据的功能,只能让一个请求去访问数据,就能保证数据的安全性。所以才衍生出其他更多的功能(分布式锁经典解决办法,分布式定时任务的处理)。
zookeeper的管理方式就像xml节点一样,节点又分为临时节点和持久化节点(还有两种是对应的顺序节点,一般不用),临时节点在zookeeper连接关闭之后就会自动删除,但是永久节点不会在关闭后删除,但是可以通过代码删除。
当发生节点的增删改查时会触发对应的事件,可以通过事件作出相应的处理,看下面的使用场景②
zookeeper的Watcher是核心,process核心运行
zookeeper在没有dubbo情况下的使用场景:
①:分布式定时任务 说明:就是当项目为分布式时,每个项目上面都有一个相同的定时任务,为了避免定时任务重复执行,可以利用zookeeper来防止分布式定时任务重复执行
执行定时任务时去判断当前任务是否已经执行
第一步:每个任务执行之前在zookeeper中创建指定节点
第二步:如果节点创建成功则表明定时任务还没有执行。创建节点时的语句try起来
第三步:创建节点成功则返回true表示任务没有执行。抛出异常则表示节点已经存在了就表示定时任务已经执行了,返回false,其他的定时任务就不会执行。
②:生产环境配置文件更改 说明:将配置信息全部存在zookeeper中,当更改配置信息时会触发zookeeper更改信息方法,可以通过触发方法更改系统配置信息。就可以将信息更改。