一、zookeeper的基本原理

数据模型,如下:
ZooKeeper数据模型的结构与Unix文件系统很类似,整体上可以看作是一棵树,每个节点称做一个ZNode。每个ZNode都可以通过其路径唯一标识,比如上图中第三层的第一个ZNode,它的路径是/app1/c1。在每个ZNode上可存储少量数据(默认是1M, 可以通过配置修改,通常不建议在ZNode上存储大量的数据),这个特性非常有用。另外,每个ZNode上还存储了其Acl信息,这里需要注意,虽说ZNode的树形结构跟Unix文件系统很类似,但是其Acl与Unix文件系统是完全不同的,每个ZNode的Acl的独立的,子结点不会继承父结点的。
ZooKeeper特性:
1、读、写(更新)模式
在ZooKeeper集群中,读可以从任意一个ZooKeeperServer读,这一点是保证ZooKeeper比较好的读性能的关键;写的请求会先Forwarder到Leader,然后由Leader来通过ZooKeeper中的原子广播协议,将请求广播给所有的Follower,Leader收到一半以上的写成功的Ack后,就认为该写成功了,就会将该写进行持久化,并告诉客户端写成功了。
2、WAL和Snapshot
和大多数分布式系统一样,ZooKeeper也有WAL(Write-Ahead-Log),对于每一个更新操作,ZooKeeper都会先写WAL,然后再对内存中的数据做更新,然后向Client通知更新结果。另外,ZooKeeper还会定期将内存中的目录树进行Snapshot,落地到磁盘上,这个跟HDFS中的FSImage是比较类似的。这么做的主要目的,一当然是数据的持久化,二是加快重启之后的恢复速度,如果全部通过ReplayWAL的形式恢复的话,会比较慢。
3、FIFO
对于每一个ZooKeeper客户端而言,所有的操作都是遵循FIFO顺序的,这一特性是由下面两个基本特性来保证的:一是ZooKeeperClient与Server之间的网络通信是基于TCP,TCP保证了Client/Server之间传输包的顺序;二是ZooKeeperServer执行客户端请求也是严格按照FIFO顺序的。
4、Linearizability
在ZooKeeper中,所有的更新操作都有严格的偏序关系,更新操作都是串行执行的,这一点是保证ZooKeeper功能正确性的关键。
二、zookeeper的常用命令
我们可以执行zookeeper-client或者执行/opt/cloudera/parcels/CDH-5.0.0-1.cdh5.0.0.p0.47/lib/zookeeper/bin/zkCli.sh-server localhost,进入zookeeper命令行,如下:
然后,执行ls /可以看到:
然后,我们可以执行create /qyktest‘qyktest'创建一个节点,如下:
然后,我们执行get /qyktest获取节点值,如下:
然后,我们可以执行set /qyktest‘111'修改节点的值,如下:
最后,我们执行delete /qyktest便可删除此节点。
另外,我们还可以在qyktest此节点下继续创建子节点。
好了,几个基本命令就讲到这人啦,其它的命令还有很多,大家可以去查阅下资料。
三、zookeeper的javaapi操作
关于Javaapi操作zookeeper比较简单,笔者直接贴出代码,如下:
packageorg.zookeeper.demo;
importjava.io.IOException;
importjava.util.concurrent.CountDownLatch;
importorg.apache.zookeeper.CreateMode;
importorg.apache.zookeeper.KeeperException;
importorg.apache.zookeeper.WatchedEvent;
importorg.apache.zookeeper.Watcher;
importorg.apache.zookeeper.Watcher.Event.KeeperState;
importorg.apache.zookeeper.ZooDefs.Ids;
importorg.apache.zookeeper.ZooKeeper;
publicclassZookeeperClientimplementsWatcher{
//连接超时时间,10s
privatestaticfinalintSESSION_TIMEOUT= 10000;
//连接的zookeeperserver
privatestaticfinalStringCONNECTION_STRING = "172.31.25.8:2181";
privatestaticfinalStringZK_PATH = "/qyktest";
privateZooKeeperzk = null;
privateCountDownLatchconnectedSemaphore = newCountDownLatch(1);
publicvoidcreateConnection(StringconnectString, intsessionTimeout){
this.releaseConnection();
try{
zk= newZooKeeper(connectString,sessionTimeout, this);
connectedSemaphore.await();
}catch(InterruptedExceptione) {
System.out.println("连接创建失败,发生InterruptedException");
e.printStackTrace();
}catch(IOExceptione) {
System.out.println("连接创建失败,发生IOException");
e.printStackTrace();
}
}
publicvoidreleaseConnection(){
if(this.zk!= null){
try{
this.zk.close();
}catch(InterruptedExceptione) {
e.printStackTrace();
}
}
}
publicbooleancreatePath(Stringpath, String data) {
try{
Stringresult = this.zk.create(path,data.getBytes(), Ids.OPEN_ACL_UNSAFE,CreateMode.PERSISTENT);
System.out.println("节点创建成功,Path: "+result + ", content: "+data);
}catch(KeeperExceptione) {
System.out.println("节点创建失败,发生KeeperException");
e.printStackTrace();
}catch(InterruptedExceptione) {
System.out.println("节点创建失败,发生InterruptedException");
e.printStackTrace();
}
returntrue;
}
publicStringreadData(Stringpath) {
try{
System.out.println("获取数据成功,path:"+path);
returnnewString(this.zk.getData(path,false,null));
}catch(KeeperExceptione) {
System.out.println("读取数据失败,发生KeeperException,path:"+path);
e.printStackTrace();
return"";
}catch(InterruptedExceptione) {
System.out.println("读取数据失败,发生InterruptedException,path: "+path);
e.printStackTrace();
return"";
}
}
publicbooleanwriteData(Stringpath, String data) {
try{
System.out.println("更新数据成功,path:"+path + ", stat: "+this.zk.setData(path,data.getBytes(), -1));
}catch(KeeperExceptione) {
System.out.println("更新数据失败,发生KeeperException,path:"+path);
e.printStackTrace();
}catch(InterruptedExceptione) {
System.out.println("更新数据失败,发生InterruptedException,path: "+path);
e.printStackTrace();
}
returnfalse;
}
publicvoiddeleteNode(Stringpath) {
try{
this.zk.delete(path,-1);
System.out.println("删除节点成功,path:"+path);
}catch(KeeperExceptione) {
System.out.println("删除节点失败,发生KeeperException,path:"+path);
e.printStackTrace();
}catch(InterruptedExceptione) {
System.out.println("删除节点失败,发生InterruptedException,path: "+path);
e.printStackTrace();
}
}
publicstaticvoidmain(String[]args) {
ZookeeperClientsample = newZookeeperClient();
//获取连接
sample.createConnection(CONNECTION_STRING,SESSION_TIMEOUT);
//读数据
Stringqyk = sample.readData("/qyktest");
System.out.println("qyk:"+qyk);
Stringurl = sample.readData("/qyk/db/url");
System.out.println("url"+url);
Stringdriver = sample.readData("/qyk/db/driver");
System.out.println("driver"+driver);
StringuserName = sample.readData("/qyk/db/userName");
System.out.println("userName"+userName);
Stringpassword = sample.readData("/qyk/db/password");
System.out.println("password"+password);
//创建节点
sample.createPath(ZK_PATH,"我是节点初始内容");
System.out.println("数据内容:"+sample.readData(ZK_PATH) + "\n");
//更新节点
sample.writeData(ZK_PATH,"更新后的数据");
System.out.println("数据内容:"+sample.readData(ZK_PATH) + "\n");
//删除节点
sample.deleteNode(ZK_PATH);
//释放连接
sample.releaseConnection();
}
@Override
publicvoidprocess(WatchedEventevent) {
System.out.println("收到事件通知:"+event.getState() + "\n");
if(KeeperState.SyncConnected== event.getState()) {
connectedSemaphore.countDown();
}
}
}
然后,执行可以看到,控制台输出如下:
所以,像一些公用的配置,我们可以存到zookeeper里面,之后其它的服务就可以使用了
总结
以上所述是小编给大家介绍的java 中 zookeeper简单使用,希望对大家有所帮助,如果大家有任何疑问请给我留言,小编会及时回复大家的。在此也非常感谢大家对网站的支持!
# zookeeper简单使用
# java使用zookeeper实现的分布式锁示例
# Java zookeeper图形化工具ZooInspector用法详解
# java连接zookeeper的3种方式小结
# 解决java连接zookeeper很慢的问题
# 在Java中操作Zookeeper的示例代码详解
# Java调用Zookeeper的实现步骤
# 如何使用Java操作Zookeeper
# Java中的ZooKeeper使用
# 我们可以
# 都是
# 文件系统
# 客户端
# 可以通过
# 可以看到
# 小编
# 我是
# 几个
# 这一
# 就会
# 都有
# 也有
# 好了
# 还可以
# 第一个
# 在此
# 一是
# 是由
# 还会
相关文章:
家庭建站与云服务器建站,如何选择更优?
网站制作话术技巧,网站推广做的好怎么话术?
打鱼网站制作软件,波克捕鱼官方号怎么注册?
如何用虚拟主机快速搭建网站?详细步骤解析
深圳网站制作培训,深圳哪些招聘网站比较好?
如何配置支付宝与微信支付功能?
制作网站哪家好,cc、.co、.cm哪个域名更适合做网站?
如何用好域名打造高点击率的自主建站?
商务网站制作工程师,从哪几个方面把握电子商务网站主页和页面的特色设计?
建站之星24小时客服电话如何获取?
图片制作网站免费软件,有没有免费的网站或软件可以将图片批量转为A4大小的pdf?
c++如何打印函数堆栈信息_c++ backtrace函数与符号名解析【方法】
学校为何禁止电信移动建设网站?
中山网站推广排名,中山信息港登录入口?
建站为何优先选择香港服务器?
高端云建站费用究竟需要多少预算?
寿县云建站:智能SEO优化与多行业模板快速上线指南
广州网站制作公司哪家好一点,广州欧莱雅百库网络科技有限公司官网?
公司网站建设制作费用,想建设一个属于自己的企业网站,该如何去做?
如何制作新型网站程序文件,新型止水鱼鳞网要拆除吗?
免费视频制作网站,更新又快又好的免费电影网站?
如何在建站宝盒中设置产品搜索功能?
SAX解析器是什么,它与DOM在处理大型XML文件时有何不同?
如何快速生成橙子建站落地页链接?
如何基于云服务器快速搭建网站及云盘系统?
制作网站的公司有哪些,做一个公司网站要多少钱?
建站之家VIP精选网站模板与SEO优化教程整合指南
建站中国必看指南:CMS建站系统+手机网站搭建核心技巧解析
百度网页制作网站有哪些,谁能告诉我百度网站是怎么联系?
如何在Tomcat中配置并部署网站项目?
家具网站制作软件,家具厂怎么跑业务?
如何在搬瓦工VPS快速搭建网站?
平台云上自助建站如何快速打造专业网站?
建站之星导航菜单设置与功能模块配置全攻略
制作宣传网站的软件,小红书可以宣传网站吗?
如何在Golang中实现微服务服务拆分_Golang微服务拆分与接口管理方法
如何选择长沙网站建站模板?H5响应式与品牌定制哪个更优?
如何在阿里云虚拟机上搭建网站?步骤解析与避坑指南
小自动建站系统:AI智能生成+拖拽模板,多端适配一键搭建
宝华建站服务条款解析:五站合一功能与SEO优化设置指南
如何在Windows环境下新建FTP站点并设置权限?
建站主机选购指南:核心配置与性价比推荐解析
c++怎么实现高并发下的无锁队列_c++ std::atomic原子变量与CAS操作【详解】
宝塔建站助手安装配置与建站模板使用全流程解析
大连网站制作费用,大连新青年网站,五年四班里的视频怎样下载啊?
盘锦网站制作公司,盘锦大洼有多少5G网站?
Dapper的Execute方法的返回值是什么意思 Dapper Execute返回值详解
建站之星代理如何优化在线客服效率?
如何构建满足综合性能需求的优质建站方案?
网站制作大概要多少钱一个,做一个平台网站大概多少钱?
*请认真填写需求信息,我们会在24小时内与您取得联系。