解决:Ubuntu共享文件夹复制后,cd 命令提示当前目录权限不够

最近因为虚拟机系统崩掉了,重新搭建了新的系统,发现复制共享文件夹后总是提示权限不够的问题,还引发了新的问题,导致/etc/profile 以及.bashrc中设置的环境变量在该目录下每次新开终端都需要source,弄得很心烦。
经过排查是因为将共享文件复制到当前目录时,我给的权限是
chmod -R 666 file

根据在我之前对linux权限的认识,认为工程文件夹只需要读写权限即可,而只有最终生成的可执行文件才需要执行权限,所以只给了文件夹读写权限,所以每次cd的时候都会提示权限不够,应该也是因为这个问题,设置的环境变量每次也需要重启。

事实上,共享文件夹下的文件每次复制都需要额外设置它的权限,会增加额外的工作量,并且有时候会产生很多奇怪的问题。这是因为自动mount的共享文件夹(比如/media/sf_share)所有者为root,所有组为vboxsf,并且只有这两者可以访问。所以可以按照以下命令,将当前用户添加到vboxsf工作组,则可以拥有对其进行操作的权限:

udo usermod -aG vboxsf username
其中,username是你的用户名

另外,经过查资料,linux的权限中文件的读写和文件夹的读是有区别的,常用的操作的权限如下:

r(Read,读取):对文件而言,具有读取文件内容的权限;对目录来说,具有浏览目录的权限。
w(Write,写入):对文件而言,具有新增,修改,删除文件内容的权限;对目录来说,具有新建,删除,修改,移动目录内文件的权限。
x(eXecute,执行):对文件而言,具有执行文件的权限;对目录了来说该用户具有进入目录的权限。

1、目录的只读访问不允许使用cd进入目录,必须要有执行的权限才能进入。
2、只有执行权限只能进入目录,不能看到目录下的内容,要想看到目录下的文件名和目录名,需要可读权限。
3、一个文件能不能被删除,主要看该文件所在的目录对用户是否具有写权限,如果目录对用户没有写权限,则该目录下的所有文件都不能被删除,文件所有者除外
4、目录的w位不设置,即使你拥有目录中某文件的w权限也不能写该文件

你可能感兴趣的:(Linux)