转载自:https://blog.csdn.net/fuhanghang/article/details/82807772
最近在开发的时候拥有root权限,但发现服务包都是其他用户权限,这个时候,直接替换上去的class文件是没法使用的,但是又不想重新推服务,发现可以使用chmod更改替换上去的文件权限,就可以使用了。
因此找了下讲解linux 权限的文章,也记录下。
其实开发中使用最多的是chmod 777 +文件名 (给单独文件赋所有权限)
和 chmod -R 777 + 文件夹名(给文件夹下所有文件赋所有权限)
1、举例说明
修改某个目录下的所有文件的权限,包括子目录中的文件,例子如下:
chmod 777 /home/user 注:仅把/home/user目录的权限设置为rwxrwxrwx
chmod -R 777 /home/user 注:表示将整个/home/user目录与其中的文件和子目录的权限都设置为rwxrwxrwx
其中,参数-R表示启动递归处理
2、chmod命令解析
chmod是change the mode of file 的缩写,用于改变对文件的访问模式,即改变访问权限。用3个数字来表达对 用户(文件或目录的所有者),用户组(同组用户),其他用户 的权限:
如:chmod 777 /test
数字7是表达同时具有读,写,执行权限,读取--用数字4表示;写入--用数字2表示;执行--用数字1表示;
按照规则,如你想设置/test目录的权限为:
对用户可读可写:4(读取)+ 2(写入)= 6 ;
对用户组可读可执行:4(读取)+ 1(执行)= 5 ;
对其他用户仅可读:4(读取);
这样就可以用命令:
chmod 654 /test
3、权限解析
针对文件有三种权限,分别是:文件内容(r),写数据到文件(w),作为命令执行文件(x)
针对目录的三种权限,分别是:
读包含在目录中的文件名称(r);
写信息到目录中去(增加和删除索引点的连结,w);
搜索目录(能用该目录名称作为路径名去访问它所包含的文件和子目录);
具体说明:
有只读权限的用户不能用cd进入该目录:还必须有执行权限才能进入;
有执行权限的用户只有在知道文件名,并拥有读权利的情况下才可以访问目录下的文件;
必须有读和执行权限才可以ls列出目录清单,或使用cd命令进入目录;
有目录的写权限,可以创建、删除或修改目录下的任何文件或子目录,即使使该文件或子目录属于其他用户也是如此;
几种常用权限实例:
-rw------- (600) 只有所有者才有读和写的权限
-rw-r--r-- (644) 只有所有者才有读和写的权限,组群和其他人只有读的权限
-rwx------ (700) 只有所有者才有读,写,执行的权限
-rwxr-xr-x (755) 只有所有者才有读,写,执行的权限,组群和其他人只有读和执行的权限
-rwx--x--x (711) 只有所有者才有读,写,执行的权限,组群和其他人只有执行的权限
-rw-rw-rw- (666) 每个人都有读写的权限
-rwxrwxrwx (777) 每个人都有读写和执行的权限