NFS : NFS 4 ACL Tool |
It's possible to set ACL on NFS(v4) filesystem to install NFS 4 ACL tool. | |
| [1] | Install NFS 4 ACL Tool on NFS clients that mounts NFS share with NFSv4. |
| root@node01:~# apt -y install nfs4-acl-tools |
| [2] | On this example, it shows usage examples on the environment like follows. |
| root@node01:~# df -hT /mnt Filesystem Type Size Used Avail Use% Mounted on dlp.srv.world:/home/nfsshare nfs4 27G 937M 25G 4% /mntroot@node01:~# ll /mnt total 8 drwx------ 2 root root 4096 Aug 14 10:36 testdir -rw------- 1 root root 30 Aug 14 10:35 testfile.txt |
| [3] | Show ACL of a file or directory on NFSv4 filesystem. |
| root@node01:~# nfs4_getfacl /mnt/testfile.txt # file: /mnt/testfile.txt A::OWNER@:rwatTcCy A::GROUP@:tcy A::EVERYONE@:tcyroot@node01:~# nfs4_getfacl /mnt/testdir # file: /mnt/testdir A::OWNER@:rwaDxtTcCy A::GROUP@:tcy A::EVERYONE@:tcy # each entry means like follows # ACE = Access Control Entry # (ACE Type):(ACE Flags):(ACE Principal):(ACE Permissions) |
Description
|
| [4] | Add or Delete ACE. |
| root@node01:~# ll /mnt total 8 drwx------ 2 root root 4096 Aug 14 10:36 testdir -rw------- 1 root root 30 Aug 14 10:35 testfile.txtroot@node01:~# nfs4_getfacl /mnt/testfile.txt # file: /mnt/testfile.txt A::OWNER@:rwatTcCy A::GROUP@:tcy A::EVERYONE@:tcy # add generic read/execute for [debian] user to [/mnt/testfile.txt] file root@node01:~# nfs4_setfacl -a A::debian@srv.world:rxtncy /mnt/testfile.txt nfs4_getfacl /mnt/testfile.txt # file: /mnt/testfile.txt D::OWNER@:x A::OWNER@:rwatTcCy A::1000:rxtcy A::GROUP@:tcy A::EVERYONE@:tcy # verify with [debian] user debian@node01:~$ ll /mnt total 8 drwx------ 2 root root 4096 Aug 14 10:36 testdir -rw-r-x---+ 1 root root 30 Aug 14 10:35 testfile.txt debian@node01:~$ cat /mnt/testfile.txt test file # delete generic read/execute for [debian] user from [/mnt/testfile.txt] file root@node01:~# nfs4_setfacl -x A::1000:rxtcy /mnt/testfile.txt nfs4_getfacl /mnt/testfile.txt # file: /mnt/testfile.txt A::OWNER@:rwatTcCy A::GROUP@:tcy A::EVERYONE@:tcy |
| [5] | Edit ACL directly. |
| root@node01:~# nfs4_setfacl -e /mnt/testfile.txt # run an editor on $EDITOR (if null, default is [vi] editor)
## Editing NFSv4 ACL for file: /mnt/testfile.txt
A::OWNER@:rwatTcCy
A::GROUP@:tcy
A::EVERYONE@:tcy
|
| [6] | Add ACE from a file. |
A::debian@srv.world:RX A::trixie@srv.world:RWX # add ACL from the file root@node01:~# nfs4_setfacl -A acl.txt /mnt/testfile.txt nfs4_getfacl /mnt/testfile.txt # file: /mnt/testfile.txt D::OWNER@:x A::OWNER@:rwatTcCy A::1000:rxtcy A::1002:rwaxtcy A::GROUP@:tcy A::EVERYONE@:tcy |
| [7] | Replace current ACE to new ACE. |
A::OWNER@:rwaxtTcCy A::GROUP@:tcy A::EVERYONE@:tcy # replace ACL from the file root@node01:~# nfs4_setfacl -S acl.txt /mnt/testfile.txt nfs4_getfacl /mnt/testfile.txt # file: /mnt/testfile.txt A::OWNER@:rwaxtTcCy A::GROUP@:tcy A::EVERYONE@:tcy |
| [8] | Replace specific ACE to new ACE. |
| root@node01:~# nfs4_getfacl /mnt/testfile.txt # file: /mnt/testfile.txt A::OWNER@:rwaxtTcCy A::GROUP@:tcy A::EVERYONE@:tcy # replace EVERYONE's ACE to read/execute root@node01:~# nfs4_setfacl -m A::EVERYONE@:tcy A::EVERYONE@:RX /mnt/testfile.txt nfs4_getfacl /mnt/testfile.txt # file: /mnt/testfile.txt A::OWNER@:rwaxtTcCy A::GROUP@:rxtcy A::EVERYONE@:rxtcy |
No comments:
Post a Comment