0


zookeeper--ACL详解

一、ACL组成简介 (Access Control List)

ACL 权限设置由scheme:expression, perms 三部分组成,分别代表了认证模式(scheme)、授权对象id、对应的权限;

1、认证模式(scheme)

(1)digest模式 ( user:password)

create /zk-node-create-schema mydata digest:user1:+owfoSBn/am19roBPzR1/MfCblE=:crwad
set /zk-node-create-schema  digest:user1:+owfoSBn/am19roBPzR1/MfCblE=:crwad

密码是加密密码,加密步骤如下:
1、首先先对user:password 使用sha1算法得出摘要(digest);
2、然后使用base64算法对该摘要加密;
命令如下:

echo-n user:password | openssl dgst -binary-sha1| openssl base64 

(2)world模式,即world:anynoe cdrwa

world模式是节点的默认模式,当一个节点被创建就会被赋予这种模式,world模式代表所有人对该节点有cdrwa权限。

(3)auth模式

要使用该模式,首先要使用addauth命令添加用户,否则会报错;权限设置命令如下:

create  /test10 hello  auth:user1:明文密码:permissions 
setAcl  /test10   auth:user1:明文密码:permissions 

在auth模式下,对应于上述命令,会自动忽略其中的user1和明文密码字段,而使用通过addauth命令添加的用户和密码,虽然会忽略user1和明文密码字段,但是不能取消,否则会报错;如果添加了多个用户,会对所有已添加的用户设置相同的权限,详情请见下文。

(4)ip模式 ip:具体ip:permissions

该模式对连接服务器的客户端ip进行认证,可以设置多个ip,多个ip通过逗号分隔;

setAcl  /test  ip:IP1:cr,ip:IP2,rw

(5) x509模式

2、权限(permissions)

权限类型ACL简写说明createc可以创建一个子节点readr可以获取节点的数据以及列出子节点writew可以对节点设置数据deleted可以删除一个子节点admina具有设置该节点ACL权限的权限

二、相关命令

1、create

创建节点的时候就指定权限,指定权限的同时需要执行节点值,否则会将权限设置为节点值;

create [-s][-e][-c][-t ttl] path [data][acl]# create a node with the schema[zkshell: 11] create /zk-node-create-schema mydata digest:user1:+owfoSBn/am19roBPzR1/MfCblE=:crwad
    Created /zk-node-create-schema
[zkshell: 12] addauth digest user1:12345
[zkshell: 13] getAcl /zk-node-create-schema
    'digest,'user1:+owfoSBn/am19roBPzR1/MfCblE=: cdrwa

2、addauth scheme auth 与auth模式认证

==scheme一般是digest,并且auth中的密码是明文 ==

[zkshell: 9] getAcl /acl_digest_test
    Insufficient permission : /acl_digest_test
[zkshell: 10] addauth digest user1:12345
[zkshell: 11] getAcl /acl_digest_test
    'digest,'user1:+owfoSBn/am19roBPzR1/MfCblE=: cdrwa

addauth 命令用于在当前seesion中添加用户,当查询或者更改节点信息的时候,服务器会校验当前seesion中是否存在此用户,并校验其密码是否正确,否则会报错

当使用 以下两种方式创建ACL控制权限的时候,需要注意:

create  /test10 hello  auth:user1:明文密码:permissions 
setAcl  /test10   auth:user1:明文密码:permissions 

需要先使用addauth 添加用户,否则会报错,可以添加多个用户,如果添加多个用户,就会对所有用户赋一样的权限,例如:

addauth digest ramboo1:ramboo1
addauth digest ramboo2:ramboo2
addauth digest ramboo3:ramboo3
setAcl /auth auth:ramboo1:ramboo1:cdrwa
getAcl /auth

结果如下

'digest,'ramboo1:JXpHVJcEMUsIf5MM6u7TlOp3pqo=: cdrwa
'digest,'ramboo2:lTTHGKOT6A3iEwj/SV5meGTXbAM=: cdrwa
'digest,'ramboo3:b8+HkvFoPszTILQTMB1YFQ+Yvus=: cdrwa

3、setAcl

setAcl   /test10  scheme:expression, perms 

4、getAcl 获取节点的ACL权限

[zkshell: 4] create /acl_test mydata ip:127.0.0.1:crwda
    Created /acl_test
[zkshell: 5] getAcl /acl_test
    'ip,'127.0.0.1
    : cdrwa
    [zkshell: 6] getAcl /testwatch
    'world,'anyone
    : cdrwa

三、ACL权限特性说明

  • 1、ACL权限控制是基于znode节点的,需要对节点设置权限;
  • 2、ACL权限控制只针对当前节点,并不会对子节点有效,即ACL权限并不会递归;
  • 3、一个节点最原始的权限是world:anynoe cdrwa,即任何人拥有所有权限;
  • 4、每个znode支持设置多种权限控制方案和多个权限;

四、实践

1、digest模式加密

[zhjl@yyzc-zhjlpi02 ~]$ echo-n lichf1:12345| openssl dgst -binary-sha1| openssl base64
PLvXdiB/dq9VM2nkYPecse4HT98=[zhjl@yyzc-zhjlpi02 ~]

2、digest模式创建–需要先通过addauth添加用户才可以进行后续操作

[zk: localhost:2181(CONNECTED)5] create /test7  'hello world ' digest:lichf1:PLvXdiB/dq9VM2nkYPecse4HT98=:crwad
Created /test7
[zk: localhost:2181(CONNECTED)6] get /test7
Insufficient permission : /test7
[zk: localhost:2181(CONNECTED)7] addauth digest lichf1:12345
[zk: localhost:2181(CONNECTED)8] get /test7
hello world
[zk: localhost:2181(CONNECTED)9] getAcl /test7
'digest,'lichf1:PLvXdiB/dq9VM2nkYPecse4HT98=: cdrwa
[zk: localhost:2181(CONNECTED)10]

3、模式错误会报错,并退出连接

[zk: localhost:2181(CONNECTED)8] addauth lichf4
[zk: localhost:2181(CONNECTED)9]
WATCHER:
WatchedEvent state:AuthFailed type:None path:null
2024-03-27 21:48:09,838 [myid:] - INFO  [main-EventThread:ClientCnxn$EventThread@578] - EventThread shut down for session: 0x10b1f1382d70039

4、auth模式

[zk: localhost:2181(CONNECTED)0] addauth digest lichf:12345
[zk: localhost:2181(CONNECTED)2] create /test12 hhh  auth:lichf:12345:crw
Created /test12
[zk: localhost:2181(CONNECTED)3] getAcl /test12
'digest,'lichf:x
: crw
[zk: localhost:2181(CONNECTED)4] get /test12
hhh

5、auth模式–addauth用户添加

添加了两个用户,两个用户分别对应不同的znode节点

[zk: localhost:2181(CONNECTED)0] addauth digest lichf:12345
[zk: localhost:2181(CONNECTED)1] addauth digest lichf1:12345
[zk: localhost:2181(CONNECTED)2] getAcl /test12
'digest,'lichf:x
: crw
[zk: localhost:2181(CONNECTED)3] getAcl /test11
'digest,'lichf1:PLvXdiB/dq9VM2nkYPecse4HT98=: cdrwa
[zk: localhost:2181(CONNECTED)4]
标签: zookeeper linux debian

本文转载自: https://blog.csdn.net/qq_41768644/article/details/137087871
版权归原作者 husterlichf 所有, 如有侵权,请联系我们删除。

“zookeeper--ACL详解”的评论:

还没有评论