返回顶部
首页 > 资讯 > 精选 >acl权限如何在zookeeper中进行配置
  • 840
分享到

acl权限如何在zookeeper中进行配置

zookeeperacl权限zookeepe 2023-05-31 02:05:53 840人浏览 安东尼
摘要

acl权限如何在ZooKeeper中进行配置?相信很多没有经验的人对此束手无策,为此本文总结了问题出现的原因和解决方法,通过这篇文章希望你能解决这个问题。Zookeeper使用ACL来控制访问Znode,ACL的实现和UNIX的实现非常相似

acl权限如何在ZooKeeper中进行配置?相信很多没有经验的人对此束手无策,为此本文总结了问题出现的原因和解决方法,通过这篇文章希望你能解决这个问题。

Zookeeper使用ACL来控制访问Znode,ACL的实现和UNIX的实现非常相似:它采用权限位来控制那些操作被允许,那些操作被禁止。但是和标准的UNIX权限不同的是,Znode没有限制用户(user,即文件的所有者),组(group)和其他(world)。Zookeepr是没有所有者的概念的。

每个ZNode的ACL是独立的,且子节点不会继承父节点的ACL。例如:Znode /app对于ip为172.16.16.1只有只读权限,而/app/status是world可读,那么任何人都可以获取/app/status;所以在Zookeeper中权限是没有继承和传递关系的,每个Znode的权限都是独立存在的。

Zookeeper支持可插拔的权限认证方案,分为三个维度:scheme,user,permission。通常表示为scheme:id,permissions,其中Scheme表示使用何种方式来进行访问控制,Id代表用户,Permission表示有什么权限。下面分别说说这三个维度:

ZooKeeper支持如下权限(permissions):

  · CREATE:可以创建子节点

  · READ:可以获取该节点的数据,也可以读取该节点所有的子节点。

  · WRITE:可以写数据到该节点。

  · DELETE:可以删除子节点。

   ·ADMIN:可以在该节点中设置权限。

简单来说,zookeeper的这5种操作权限,CREATE、READ、WRITE、DELETE、ADMIN 也就是 增、删、改、查、管理权限,这5种权限简写为crwda(即:每个单词的首字符缩写)

注:这5种权限中,delete是指对子节点的删除权限,其它4种权限指对自身节点的操作权限

内置的ACL Schemes:

world: 只有一个id:anyone,world:anyone表示任何人都有访问权限,Zookeeper把任何人都有权限的节点都归属于world:anyone

auth:不需要任何id, 只要是通过auth的user都有权限

digest: 使用用户名/密码的方式验证,采用username:BASE64(SHA1(passWord))的字符串作为ACL的ID

ip: 使用客户端的IP地址作为ACL的ID,设置的时候可以设置一个ip段,比如ip:192.168.1.0/16, 表示匹配前16个bit的IP段

sasl:sasl的对应的id,是一个通过sasl authentication用户的id,zookeeper-3.4.4中的sasl authentication是通过kerberos来实现的,也就是说用户只有通过了kerberos认证,才能访问它有权限的node.

如果需要实现自己定义的Scheme,可以实现org.apache.zookeeper.server.auth.AuthenticationProvider接口。

示例:

    @Testpublic void testAclServer() {List<ACL> acls = new ArrayList<ACL>(2);try {Id id1 = new Id("digest", DigestAuthenticationProvider.generateDigest("fish:fishpw"));ACL acl1 = new ACL(ZooDefs.Perms.WRITE, id1);Id id2 = new Id("digest", DigestAuthenticationProvider.generateDigest("qsd:qsdpw"));ACL acl2 = new ACL(ZooDefs.Perms.READ, id2);acls.add(acl1);acls.add(acl2);// 所有用户都有权限// Id world = new Id("world", "anyone");// ACL worldAcl = new ACL(ZooDefs.Perms.READ, world);// acls.add(worldAcl);// 10.0.2.76是本机IP// Id id3 = new Id("ip", "10.0.2.76");// ACL acl3 = new ACL(ZooDefs.Perms.WRITE, id3);// acls.add(acl3);} catch (NoSuchAlGorithmException e1) {e1.printStackTrace();}ZooKeeper zk = null;try {zk = new ZooKeeper("10.0.1.75:2181,10.0.1.76:2181,10.0.1.77:2181", 300000, new Watcher() {// 监控所有被触发的事件public void process(WatchedEvent event) {System.out.println("已经触发了" + event.getType() + "事件!");}});if (zk.exists("/test", true) == null) {System.out.println(zk.create("/test", "ACL测试".getBytes(), acls, CreateMode.PERSISTENT));}} catch (IOException e) {e.printStackTrace();} catch (KeeperException e1) {e1.printStackTrace();} catch (InterruptedException e1) {e1.printStackTrace();}}@Testpublic void testAclClient() {try {ZooKeeper zk = new ZooKeeper("10.0.1.75:2181,10.0.1.76:2181,10.0.1.77:2181", 300000, new Watcher() {// 监控所有被触发的事件public void process(WatchedEvent event) {System.out.println("已经触发了" + event.getType() + "事件!");}});// 只有写权限zk.addAuthInfo("digest", "fish:fishpw".getBytes());// 只有读权限zk.addAuthInfo("digest", "qsd:qsdpw".getBytes());System.out.println(new String(zk.getData("/test", null, null)));zk.setData("/test", "I change!".getBytes(), -1);} catch (KeeperException e) {e.printStackTrace();} catch (InterruptedException e) {e.printStackTrace();} catch (IOException e) {e.printStackTrace();}}

--结束END--

本文标题: acl权限如何在zookeeper中进行配置

本文链接: https://lsjlt.com/news/223127.html(转载时请注明来源链接)

有问题或投稿请发送至: 邮箱/279061341@qq.com    QQ/279061341

猜你喜欢
  • acl权限如何在zookeeper中进行配置
    acl权限如何在zookeeper中进行配置?相信很多没有经验的人对此束手无策,为此本文总结了问题出现的原因和解决方法,通过这篇文章希望你能解决这个问题。Zookeeper使用ACL来控制访问Znode,ACL的实现和UNIX的实现非常相似...
    99+
    2023-05-31
    zookeeper acl权限 zookeepe
  • 如何进行linux sudo权限配置
    本篇文章给大家分享的是有关如何进行linux sudo权限配置,小编觉得挺实用的,因此分享给大家学习,希望大家阅读完这篇文章后可以有所收获,话不多说,跟着小编一起来看看吧。    这里记录一下linux的sudo简单配置...
    99+
    2023-06-06
  • ZooKeeper的权限管理是如何进行的
    ZooKeeper的权限管理是通过ACL(Access Control List,访问控制列表)来实现的。每个ZooKeeper节点...
    99+
    2024-03-08
    ZooKeeper
  • Kafka中的ACL如何配置
    Apache Kafka中的ACL(Access Control List)用于控制用户对主题的访问权限。ACL可以配置在broke...
    99+
    2024-04-02
  • Impala中如何进行权限管理
    在Impala中,权限管理是通过使用Apache Sentry进行的。Apache Sentry是一个独立的开源项目,为Hadoop...
    99+
    2024-03-11
    Impala
  • Kylin中如何进行权限管理
    在Kylin中,权限管理主要涉及到以下几个方面: 用户管理:Kylin支持创建多个用户,可以通过用户名和密码进行认证。可以通过以下...
    99+
    2024-03-11
    Kylin
  • tomcat如何在myeclipse10中进行配置
    这篇文章给大家介绍tomcat如何在myeclipse10中进行配置,内容非常详细,感兴趣的小伙伴们可以参考借鉴,希望对大家能有所帮助。在myeclipse10中添加tomcat:选择属性preferences之后进入配置框:选择serve...
    99+
    2023-05-31
    myeclipse10 omc tomcat
  • SQLServer中如何进行权限管理和安全设置
    在SQL Server中,可以通过以下方式进行权限管理和安全设置: 创建登录账户:使用SQL Server Management...
    99+
    2024-04-09
    SQLServer
  • 如何进行数据库权限分配的探讨
    本篇文章为大家展示了如何进行数据库权限分配的探讨,内容简明扼要并且容易理解,绝对能使你眼前一亮,通过这篇文章的详细介绍希望你能有所收获。首先我们先了解下数据库的权限相关的内容主体“主体” 是可以请求 SQL...
    99+
    2024-04-02
  • 如何在IDEA中对Docker进行配置
    如何在IDEA中对Docker进行配置?相信很多没有经验的人对此束手无策,为此本文总结了问题出现的原因和解决方法,通过这篇文章希望你能解决这个问题。配置docker远程连接端口vi /usr/lib/systemd/system/...
    99+
    2023-06-06
  • 如何在CLion中对openMP进行配置
    本篇文章为大家展示了如何在CLion中对openMP进行配置,内容简明扼要并且容易理解,绝对能使你眼前一亮,通过这篇文章的详细介绍希望你能有所收获。使用MinGW64在Clion中配置openMP的开发 安装MinGW64和CLion配置C...
    99+
    2023-06-06
  • 如何在SpringBoot中对Swagger进行配置
    如何在SpringBoot中对Swagger进行配置?针对这个问题,这篇文章详细介绍了相对应的分析和解答,希望可以帮助更多想解决这个问题的小伙伴找到更简单易行的方法。导入SpringBoot集成Swagger所需要的依赖 <...
    99+
    2023-06-06
  • 怎么在SQLite中进行权限管理
    在SQLite中进行权限管理的方法主要是通过使用SQLite内置的访问控制语句和用户管理功能来实现。以下是一些常用的权限管理方法: ...
    99+
    2024-03-11
    SQLite
  • 分配权限的科学:ACL 在操作系统中的数学原理
    访问控制列表(ACL)在操作系统中扮演着分配权限的关键角色。它是一个数据结构,用于定义哪些用户或组可以访问特定的系统资源。理解其背后的数学原理至关重要,因为它们提供了ACL的有效性和安全性。 离散数学 ACL 的基础是离散数学,特别是集...
    99+
    2024-04-02
  • Linux管理员如何使用ACL设置发送集体权限
    本篇内容介绍了“Linux管理员如何使用ACL设置发送集体权限”的有关知识,在实际案例的操作过程中,不少人都会遇到这样的困境,接下来就让小编带领大家学习一下如何处理这些情况吧!希望大家仔细阅读,能够学有所成!不是每位Linux管理员都知道如...
    99+
    2023-06-16
  • Standalone模式如何在spark中进行配置
    这篇文章给大家介绍Standalone模式如何在spark中进行配置,内容非常详细,感兴趣的小伙伴们可以参考借鉴,希望对大家能有所帮助。spark运行模式Spark 有很多种模式,最简单就是单机本地模式,还有单机伪分布式模式,复杂的则运行在...
    99+
    2023-05-31
    spark standalone spar
  • jdk1.7如何在myEclipse环境中进行配置
    这期内容当中小编将会给大家带来有关jdk1.7如何在myEclipse环境中进行配置,文章内容丰富且以专业的角度为大家分析和叙述,阅读完这篇文章希望大家可以有所收获。第一步:下载jdk1.7第二步:安装jdk1.7     将下载的压缩包进...
    99+
    2023-05-31
    myeclipse jdk
  • git配置文件在哪?如何进行配置?
    Git是目前最流行的版本控制系统之一。在使用Git时,我们需要对其进行一些配置,如设置用户名和邮箱、添加忽略文件等。但是,新手很容易会遇到一个问题:Git配置文件在哪里?本文将为你介绍Git配置文件的位置以及如何进行Git配置。一、Git配...
    99+
    2023-10-22
  • Windows系统中如何进行远程关机权限的设置
    本篇文章给大家分享的是有关Windows系统中如何进行远程关机权限的设置,小编觉得挺实用的,因此分享给大家学习,希望大家阅读完这篇文章后可以有所收获,话不多说,跟着小编一起来看看吧。在内网环境中,有的人可能同时要管理或操作几台工作站,不用谈...
    99+
    2023-06-14
  • 如何在Linux中设置文件权限
    今天就跟大家聊聊有关如何在Linux中设置文件权限,可能很多人都不太了解,为了让大家更加了解,小编给大家总结了以下内容,希望大家根据这篇文章可以有所收获。 Linux中,每一个文件都具有特定的属性。主要包括文件类型和文件权限两个方...
    99+
    2023-06-13
软考高级职称资格查询
编程网,编程工程师的家园,是目前国内优秀的开源技术社区之一,形成了由开源软件库、代码分享、资讯、协作翻译、讨论区和博客等几大频道内容,为IT开发者提供了一个发现、使用、并交流开源技术的平台。
  • 官方手机版

  • 微信公众号

  • 商务合作