在上一篇文章中,我们向您展示了如何在Linux上创建共享目录。这一次,我们将向您介绍如何在Linux上授予用户对指定目录的读写权限。实现这个目标有两种方式:第一种是使用ACL(AccessControlList),第二种是创建用户组来管理文件权限,下面会一一介绍。为完成本教程,我们将使用以下设置。操作系统:CentOS7测试目录:/shares/project1/reports测试用户:tecmint文件系统类型:ext4请确保所有命令均以root用户执行,或使用sudo命令享有与其相同的权限。让我们开始吧!接下来,使用mkdir命令创建一个名为reports的目录。#mkdir-p/shares/project1/reports使用ACL赋予用户对目录的读写权限重要提示:如果你打算使用这种方法,你需要确认你的Linux文件系统类型(比如ext3和ext4,NTFS,BTRFS)支持ACL。1.首先根据以下命令查看你系统当前的文件系统类型,查看内核是否支持ACL:#df-T|??awk'{print$1,$2,$NF}'|grep"^/dev"#grep-iacl/boot/config*从下面的截图可以看出,文件系统类型是ext4,从CONFIG_EXT4_FS_POSIX_ACL=y选项可以发现内核支持POSIXACL。请参阅ACL对文件系统类型和内核的支持。2、接下来检查文件系统(分区)挂载时是否使用了ACL选项。#tune2fs-l/dev/sda1|grepacl查看分区是否支持ACL从上面的输出可以发现在默认挂载项目中已经支持了ACL。如果您发现结果不符合预期,您可以使用以下命令为指定分区启用ACL支持(本例中使用/dev/sda3)。#mount-oremount,acl/#tune2fs-oacl/dev/sda33,现在是时候将目录报告的读写权限分配给名为tecmint的用户了,只需执行以下命令。#getfacl/shares/project1/reports#CheckthedefaultACLsettingsforthedirectory#setfacl-muser:tecmint:rw/shares/project1/reports#Giverwaccesstousertecmint#getfacl/shares/project1/reports#ChecknewACLsettingsforthedirectory截图中通过ACL对指定目录授予读写权限以上,通过getfacl命令输出结果的第二行,可以发现用户tecmint已经成功获得了/shares/project1/reports目录的读写权限。如果您想获得有关ACL列表的更多信息。查看下面的其他指南。如何使用访问控制列表(ACL)为用户/组设置磁盘配额如何使用访问控制列表(ACL)挂载网络共享现在让我们看看如何使用第二种方法来授予对目录的读写权限。使用用户组来授予用户对指定目录的读写权限。1.如果用户已有默认用户组(通常组名与用户名相同),只需更改文件夹所属的用户组即可。#chgrptecmint/shares/project1/reports此外,我们还可以通过以下方法为多个用户(需要授予对指定目录的读写权限)创建一个新的用户组。这样,一个共享目录也被创建了。#groupaddprojects2。接下来,将用户tecmint添加到项目组:#usermod-aGprojectstecmint#addusertoprojects#groupstecmint#checkusersgroups3。将目录的用户组更改为项目:#chgrpprojects/shares/project1/reports4。现在,设置组成员的读写权限。#chmod-R0760/shares/projects/reports#ls-l/shares/projects/#checknewpermissions就是这样!在本教程中,我们向您展示了如何在Linux中向用户授予对指定目录的读写权限。有问题请在留言区提问。(标题图片:Pixabay,CC0)
