======================================
ZooKeeper 背景
======================================
ZooKeeper 是一个非常优秀的开源项目, 可以为软件系统提供非常重要的基础特性:
1. 分布式锁. 使用场景有: 比如我们有一套系统, 为了保证HA, 在多台需要在多台服务器上部署, 该服务程序有一些定时任务需要执行, 我们需要确保同一个定时任务不会在多台机器上被同时执行. 分布式锁可以使用 redis/RDBMS实现, 但都不如 ZooKeeper 更适合.
2. 比如要开发一套Master-Slave集群系统, Leader选举是必需的.
3. 服务发现. 在服务发现场景中, 我更推荐 consul.

ZooKeeper 数据结构
zk 提供类似于文件系统命名空间(name space), 我们可以采用路径的方式创建节点, 在节点上可以保存业务数据(2MB字节), 节点除了保存业务数据外, ZooKeeper还保存着版本号/时间戳等信息.

节点分为:
永久节点: 创建后一直保存着, 除非被删除
临时节点: 创建节点的会话存在, 节点就存在, 会话一旦结束, 节点就被删除.
顺序节点: 创建节点的时候, 自动为节点增加一个序列号, 多个客户端创建同一个节点, 序列号自增.

另外, zk 提供了监听机制, 组合这些不同类型的节点, zk就能提供分布式锁/Leader选举/分布式存储等功能.

======================================
Windows 单机安装
======================================
1. 复制 conf/zoo_sample.cfg 为 conf/zoo.cfg
zoo.cfg 默认的端口为 clientPort=2181
2. 运行 zkServer.cmd 启动 server
3. 运行 zkCli.cmd 客户端登陆
zkCli.cmd #登陆本机 localhost:2181, 可以不带任何参数
zkCli.cmd -server localhost:2181 #指定server和端口

======================================
基本命令
======================================

zk 提供很好用的命令行工具, 能自动补全节点名, 命令也不多.

help 命令, 显示zkCli命令行所支持的所有命令, 以及它们的使用语法.

ls some_path 命令, 显示指定路径下的节点

create some_path some_data 命令:
创建一个指定的节点, 并设定节点值.

get some_path 命令
显示指定节点的详细数据

create -s some_parent/some_path some_data 命令
创建一个 some_parent/some_path 序列节点, 该创建命令可以指定多次, 第一次创建的真实节点名为 some_parent/some_path0000000000, 第二次创建的节点名为 some_parent/some_path0000000001, 以此类推.

create -s -e some_parent/some_path some_data 命令
创建一个 some_parent/some_path 临时序列节点, 该创建命令可以指定多次, 第一次创建的真实节点名为 some_parent/some_path0000000000, 第二次创建的节点名为 some_parent/some_path0000000001, 以此类推. 但和普通的序列节点不同的是, 普通序列节点将一直存在, 直到被删除为止,临时序列节点只在会话期存在, 会话断开后就自动被删除.

第一个客户端创建一次:

第二个客户端再创建一次:

\

检查节点情况:

第一个客户端退出后, 再检查节点的情况, 只剩一个节点了

delete some_path 命令
删除节点

set some_path data 命令
重新设置节点数值

监听器
ls some_path watch
get some_path watch
ls 和 get 命令都可以加上 watch 关键词, 用来监听节点是否有变化, 一旦节点有变化, 会通知客户端.

======================
参考
======================
书籍: 李家智著 Spring Boot 2 精髓.
可能是把 ZooKeeper 概念讲的最清楚的一篇文章 https://github.com/Snailclimb/JavaGuide/blob/master/%E4%B8%BB%E6%B5%81%E6%A1%86%E6%9E%B6/ZooKeeper.md

ZooKeeper基础的更多相关文章

  1. zookeeper_02:zookeeper基础

    ZooKeeper基础概述 ZooKeeper维护一个小型的数据节点,这些节点被称为znode,采用类似于文件系统的层级树状结构进行管理. 针对一个znode,没有数据常常表达了重要的信息.比如,在主 ...

  2. Hadoop系列-zookeeper基础

    目前是刚刚初学完zookeeper,这篇文章主要是简单的对一些基本的概念进行梳理强化. zookeeper基础概念的理解 有时候计算机领域很多名词都是从一长串英文提取首字母缩写而来,但很不幸zooke ...

  3. Zookeeper 基础、工作流、ZAP协议

    ZooKeeper 基础 在深入了解ZooKeeper的运作之前,让我们来看看ZooKeeper的基本概念.[1] 我们将在本章中讨论以下主题:1.Architecture(架构)2.Hierarch ...

  4. Zookeeper系列一:Zookeeper基础命令操作

    有些事不是努力就可以改变的,五十块的人民币设计的再好看,也没有一百块的招人喜欢. 前言 由于公司年底要更换办公地点,所以最近投了一下简历,发现面试官现在很喜欢问dubbo.zookeeper和高并发等 ...

  5. Zookeeper基础教程(六):.net core使用Zookeeper

    Demo代码已提交到gitee,感兴趣的更有可以直接克隆使用,地址:https://gitee.com/shanfeng1000/dotnetcore-demo/tree/master/Zookeep ...

  6. Zookeeper基础教程(五):C#实现Zookeeper分布式锁

    分布式锁 互联网初期,我们系统一般都是单点部署,也就是在一台服务器完成系统的部署,后期随着用户量的增加,服务器的压力也越来越大,响应速度越来越慢,甚至出现服务器崩溃的情况. 为解决服务器压力太大,响应 ...

  7. 第一章 zookeeper基础概念

    1.ZooKeeper是什么 ZooKeeper为分布式应用提供了高效且可靠的分布式协调服务,提供了统一命名服务. 配置管理和分布式锁等分布式的基础服务.在解决分布式数据一致性方面, ZooKeepe ...

  8. Zookeeper(一) zookeeper基础使用

    一.Zookeeper是什么 (安装的是3.4.7) ZooKeeper 是一个分布式的,开放源码的分布式应用程序协调服务,是 Google 的 Chubby 一个开源的实现.它提供了简单原始的功能, ...

  9. Zookeeper基础命令操作

    转载链接:https://blog.csdn.net/dandandeshangni/article/details/80558383 安装参考链接https://blog.csdn.net/qiun ...

随机推荐

  1. 洛谷P3222 [HNOI2012]射箭(计算几何,半平面交,双端队列)

    洛谷题目传送门 设抛物线方程为\(y=ax^2+bx(a<0,b>0)\),我们想要求出一组\(a,b\)使得它尽可能满足更多的要求.这个显然可以二分答案. 如何check当前的\(mid ...

  2. 【BZOJ1022】小约翰的游戏(博弈论)

    [BZOJ1022]小约翰的游戏(博弈论) 题面 BZOJ 题解 \(Anti-SG\)游戏的模板题目. #include<iostream> #include<cstdio> ...

  3. bzoj3796(后缀数组)(SA四连)

    bzoj3796Mushroom追妹纸 题目描述 Mushroom最近看上了一个漂亮妹纸.他选择一种非常经典的手段来表达自己的心意——写情书.考虑到自己的表达能力,Mushroom决定不手写情书.他从 ...

  4. NOIP2008双栈排序(贪心)

    题目描述 Tom最近在研究一个有趣的排序问题.如图所示,通过2个栈S1和S2,Tom希望借助以下4种操作实现将输入序列升序排序. 操作a 如果输入序列不为空,将第一个元素压入栈S1 操作b 如果栈S1 ...

  5. 【算法】php实现斐波那契数列

    斐波那契数列指的是这样一个数列 1, 1, 2, 3, 5, 8, 13, 21.这个数列从第3项开始,每一项都等于前两项之和. 根据这个定义,斐波那契数列的递推公式是:f(n)=f(n-1)+f(n ...

  6. Mysql 从入门到遗忘

    高级数据过滤: WHERE AND OR NOT 总是与其他操作符一起使用,用在要过滤的前面. 通配符过滤: LIKE: %相当于正则中的.*?,_相当于正则中的.. $ select id from ...

  7. 单片机的基本构成、工作原理 LET′S TRY“嵌入式编程”: 1 of 6

    单片机的基本构成.工作原理 LET′S TRY“嵌入式编程”: 1 of 6 本连载讲解作为嵌入式系统开发技术人员所必需具备的基础知识.这些基础知识是硬件和软件技术人员都应该掌握的共通技术知识.有了电 ...

  8. 解决忘记mysql中的root用户密码问题

    如果忘了数据库中的root密码,无法登陆mysql. 解决步骤: 1. 使用“--skip-grant-tables”启动数据库 ~]#systemctl stop mysql ~]#mysqld_s ...

  9. hdu 1024 Max Sum Plus Plus(m段最大和)

    Problem Description Now I think you have got an AC in Ignatius.L's "Max Sum" problem. To b ...

  10. C语言中的类型转换——将字符串s转换为整数型(int)类型

    在讲类型转换之前,我们先要理解下C语言中单引号和双引号的区别. 先讲双引号,双引号就是字符串,我们要证实我们的想法,我选择写一段代码看看开: #include <stdio.h> int ...