标签:linux
一.Linux文件属性及权限
1.文件/目录属性查看
(1)文件属性查看
[root@localhost ~]# ls -l file
- rw-r--r--. 1 root root 0 11月 15 23:55 file
类型 文件权限 连接数 文件所有人 文件所有组 大小 最后一次被修改的时间 名字
(2)查看目录属性
[root@localhost ~]# ls -ld test
d rwxr-xr-x. 2 root root 6 11月 15 23:56 test
类型 权限 连接数 目录所有人 目录所有组 子文件属性大小 目录中内容变化 目录名
注:1.文件名第一个字符为“.”的文件是隐藏文件,用“ls -al”查看
2.文件的容量大小,单位为B。
3.显示完整的时间格式,用“ls -l --full-time”。
(3)文件权限的含义
a.对文件的含义
r:可读权限,可以使用类似cat等命令查看文件内容
w:可以对文件进行编辑和删除
x:可以运行此文件
b.对目录的含义
r:可以对此目录查看目录内的文件内容,如ls
w:可以在此目录创建文件或目录,但必须有x的权限。
x:可以使用cd命令切入到此目录或使用ls -l查看那目录内文件的详细内容。
2.改变文件属性与权限
(1)文件所属用户组
chgrp命令用来改变文件或目录所属的组。
命令结构:
chgrp (-R) 用户组名/gid 文件/目录 ##改变文件/目录所属用户组
chgrp (-R) --reference=文件名 要修改的文件名 ##将要修改的文件的所属组改为和前者文件一致的所属组,前一个文件是被参照的文件,后一个文件为被修改的文件。
注:被改变的组名必须在/etc/group文件内存在,否则显示错误。
[root@localhost ~]# chgrp test file
chgrp: invalid group: ‘test’ ##test用户组不存在
[root@vm1 ~]# ls -l test.txt
-rw-r--r-- 1 root root 0 8月 4 10:36 test.txt
[root@vm1 ~]# chgrp 38 test.txt ##以gid为参数修改,38为ntp的gid。
[root@vm1 ~]# ls -l test.txt
-rw-r--r-- 1 root ntp 0 8月 4 10:36 test.txt
[root@vm1 ~]# ls -l file.sh
-rw-r--r-- 1 root root 0 8月 4 10:37 file.sh
[root@vm1 ~]# chgrp --reference=/root/test.txt file.sh
[root@vm1 ~]# ls -l file.sh
-rw-r--r-- 1 root ntp 0 8月 4 10:37 file.sh
(2)更改文件权限
chmod:不是所有人都可以使用chown更改文件权限,除root外,其余用户只能更改属主为自己的文件或目录。
注:当复制文件/目录给某个用户,复制后文件/目录的属性和权限不会更改,则需要用chown改变文件所有者和所属组。
chmod具有四种更改方式:赋权,授权,八进制更改,参照文件更改。
更改参数:-o(other):更改其他用户的权限
-g(group):更改属组权限
-u(user):更改属主权限
a(all):更改所有用户权限(将以上三种全部更改)
命令结构:
chmod 权限 文件/目录 ##改变文件/目录的权限
a.赋权表示法
用“=”来进行赋权更改,直接更换文件原有的权限,更改为指定的权限。
[root@vm1 ~]# chmod u=rwx file.sh
[root@vm1 ~]# ls -l file.sh
-rwxr--r-- 1 root ntp 0 8月 4 10:37 file.sh
b.授权表示法
用“+”“-”来进行授权更改,其含义为在原有的权限上增加或者减少权限
[root@vm1 ~]# chmod u-w,g-r,o-r file.sh
[root@vm1 ~]# ls -l file.sh
-r-x------ 1 root ntp 0 8月 4 10:37 file.sh
c.八进制表示法
用八进制如:“777”直接对目录或者文件进行权限更改。
[root@vm1 ~]# chmod 644 file.sh
[root@vm1 ~]# ls -l file.sh
-rw-r--r-- 1 root ntp 0 8月 4 10:37 file.sh
d.参照文件表示法
使用选项“--reference=文件”来进行更改,其含义为参照指定文件的权限来对当前指定文件进行权限更改,结果与参照文件的权限一致。
[root@vm1 ~]# ls -l test.txt
-rwxr-xr-x 1 root ntp 0 8月 4 10:36 test.txt
[root@vm1 ~]# ls -l file.sh
-rw-r--r-- 1 root ntp 0 8月 4 10:37 file.sh
[root@vm1 ~]# chmod --reference=/root/test.txt file.sh
[root@vm1 ~]# ls -l file.sh
-rwxr-xr-x 1 root ntp 0 8月 4 10:37 file.sh
注:第一种和第二种只能针对其中一类用户更改,第三中和第四种不能单独更改一类用户。
注:被改变的用户名/组名必须在/etc/passwd和/etc/group文件内存在,否则显示错误。
(3)改变文件属主属组
chown用于修改文件或者目录的属主和属组,root用户可以对所有文件或目录进行属主和属组的更改,普通用户只能更改属主是自己的文件或目录,该命令也可使用参照文件修改法。
命令结构:
chown(-R) 属主名:属组名 文件/目录 ##改变属主属组
chown (-R) --reference=被参照文件 文件
[root@vm1 ~]# chown apache:memcached file.sh
[root@vm1 ~]# ls -l file.sh
-rwxr-xr-x 1 apache memcached 0 8月 4 10:37 file.sh
[root@vm1 ~]# ls -l test.txt
-rwxr-xr-x 1 root ntp 0 8月 4 10:36 test.txt
[root@vm1 ~]# chown --reference=/root/test.txt file.sh
[root@vm1 ~]# ls -l file.sh
-rwxr-xr-x 1 root ntp 0 8月 4 10:37 file.sh
注:对目录更改属主属组时,如果也需要修改目录文件下的文件和目录一样的属主属组,则可使用“-R”参数,代表递归修改目录下的文件。
a.如果只修改文件的属组,则可使用冒号+属组名,表示只修改属组,属主不变。
b.如果只修改属主,则直接写上用户名即可,属组不变。
3.文件/目录权限的意义
(1)文件是用来记录数据的,包括一般文本文件,数据库内容文件,二进制可执行文件等。
#若文件给“w”权限,则应给“r”权限。文件能否执行由是否含有“x”权限决定。
#文件具备“w”权限,可以“写入,编辑,新增,修改”文件的内容,普通用户不能删除文件,文件的删除由目录的“w”权限决定。
(2)目录是存放数据的,主要的内容是记录文件名列表。
#若目录给“r”权限,则应给“x”权限。“w”权限不可随便给。
#目录“w”权限具备“新建,删除,重命名,转移”文件/目录等功能
#目录“x”权限代表用户能否进入目录。
4.文件的默认权限
(1)默认权限的查看
umask(反掩码) ##默认用户在新建文件或目录后的权限默认值。(默认需要减去的权限)。
[root@localhost ~]# umask
0022 ##默认权限为777-022=755.(针对于目录)
注:umask的值默认是四位,分别代表:setUid/setGid/粘着位(sticky)、属主权限、组权限、其他用户的权限。有效值为后三位,bash中,第一位必须为0.
系统超级用户root的umask值是0022,而其余用户的umask值为0002.用户创建“文件”,默认没有执行权限“x”,所以默认值为666,目录默认为777,当目录或文件创建后,需要减去对应的umask值才是目录或者文件的最终权限。所以root创建的目录权限为755,文件权限为644.其余用户创建的目录权限为775,文件权限为664.
系统为什么要经过umask值来创建文件或者目录。
因为系统默认创建文件或目录的权限是666和777,这样不安全,所以引入umask值来控制用户在创建文件或目录时的权限问题。
(-rw-rw-rw)-(-----w--w-)===>-rw-r--r-- ##文件
(drwxrwxrwx)-(d----w--w-)==>drwxr-xr-x ##目录
(2)默认权限的设定
如何设置umask
[root@localhost ~]# umask 002 ##设置默认权限为002
[root@localhost ~]# mkdir yang
[root@localhost ~]# ls -ld yang
drwxrwxr-x. 2 root root 6 Nov 16 05:22 yang
(3)umask配置文件的设定
vim /etc/bashrc ##71行是普通用户的更改,73是超级用户的更改
if [ $UID -gt 199 ] && [ "`id -gn`" = "`id -un`" ]; then ##如果UID不在199之内,并且用户组名和用户名一致
umask 002 ##则该用户是普通用户,umask为0002,
else
umask 022 ##反之为系统用户,umask值为0022
fi
vim /etc/profile ##60行是普通用户的更改,62是超级用户的更改
if [ $UID -gt 199 ] && [ "`id -gn`" = "`id -un`" ]; then
umask 002
else
umask 022
fi
source /etc/bashrc /etc/profile ##让更改立即生效
注:两个文件必须更改一致。
5.特殊权限
stickyid ###强制位
o+t ###只针对目录,当一个目录上有t权限时,这个目录中的文件只能被文件拥有者删除
t=1
chmod o+t 目录
chmod 1777 目录
[root@localhost mnt]# mkdir test yang
[root@localhost mnt]# chmod 777 test
[root@localhost mnt]# chmod 1777 yang
[root@localhost mnt]# ls -ld test yang
drwxrwxrwx. 2 root root 6 Nov 16 08:00 test
drwxrwxrwt. 2 root root 4096 Nov 16 07:59 yang
[root@localhost mnt]# touch test/file{1..2}
[root@localhost mnt]# touch yang/file{1..2}
[root@localhost mnt]# su - student
Last login: Mon Nov 16 07:56:10 EST 2015 on pts/1
[student@localhost ~]$ cd /mnt
[student@localhost mnt]$ rm -fr test/file*
[student@localhost mnt]$ rm -fr yang/file*
rm: cannot remove ‘yang/file1’: Operation not permitted
rm: cannot remove ‘yang/file2’: Operation not permitted
[student@localhost mnt]$ ls test/
[student@localhost mnt]$ ls yang/
file1 file2
sgid ###粘制位
g+s ##针对目录,在目录中创建的文件都自动归属到目录所在组,针对二进制文件,文件内记录的程序在执行时和执行者的组身份没有关系,而是以二进制文件的所有组的身份执行的
chmod g+s file|directory
chmod 2777 file|directory
[root@localhost mnt]# mkdir test
[root@localhost mnt]# chgrp student test
[root@localhost mnt]# chmod 2765 test
[root@localhost mnt]# ls -ld test
drwxrwSr-x. 2 root student 6 Nov 16 07:34 test
[root@localhost mnt]# touch /mnt/test/file
[root@localhost mnt]# ls -l /mnt/test/file
-rw-r--r--. 1 root student 0 Nov 16 07:34 /mnt/test/file
suid ###冒险位
u+s ###针对文件,文件记录动作在执行时是以文件所有人身份执行的,与是谁发起的无关
chmod u+s file
chmod 4777 file
[root@localhost mnt]# cp /bin/touch .
[root@localhost mnt]# chmod 4755 touch
[root@localhost mnt]# ls -l
total 64
-rwsr-xr-x. 1 root root 62432 Nov 16 07:35 touch
[root@localhost mnt]# ls -l
total 64
-rwsr-xr-x. 1 root root 62432 Nov 16 07:35 touch
[student@localhost ~]$ /mnt/touch file
[student@localhost ~]$ touch file1
[student@localhost ~]$ ls -l
-rw-rw-r--. 1 root student 0 Nov 16 07:37 file
-rw-rw-r--. 1 student student 0 Nov 16 07:40 file
########################################################
二.Linux文件类型,扩展名与目录配置
1.文件类型,扩展名
(1)文件类型
普通文件:第一个字符为[-].
纯文本文件(ASCII)
二进制文件(binary)
数据格式文件(data)
目录(directory):第一个属性为[d]。
链接文件(link):第一个属性为[l]。
设备与设备文件(device):通常集中在/dev目录中
块(biock)设备文件:存储数据,提供系统随机访问的接口设备,第一个属性为[b]。一般为主机硬件设备。
字符(character)设备文件:串行接口的设备,第一个属性为[c]。一般为外置设备。
套接字(sockets):数据接口文件,被用在网络上的数据连接。第一个属性是[s]。通常在/var/run目录中可以看到这种文件类型。
管道(FIFO,pipe):
fifo:解决多个程序同时访问一个文件所造成的错误问题。第一个属性是[p]。
(2)文件扩展名
注:一个文件中没有可执行数据,即使拥有“x”权限,也不能执行。
*.sh:脚本或批处理文件。文件是用shell写的,扩展名为*.sh。
*Z,*.tar,*.tar.gz,*.zip,*.tgz:经过打包压缩的文件。
*.html,*.php:网页相关文件,分别带边html语法和php语法的网页文件。.html文件可使用浏览器直接开启,.php文件可以通过客户端的浏览器来服务端浏览。
(3)Linux文件长度限制
默认ext2,ext3,ext4,xfs文件系统
单一文件/目录:最大文件名容许量为255个字符
完整路径名称及目录(/)的完整文件名为4096个字符。
2.目录配置
(1)目录
/ ##根目录。存储与开机系统的文件。/etc./bin./dev./lib./sbin应该和根目录放置在一个分区里,而类似/usr/local可以单独位于另一个分区
/bin ##在单用户维护模式下能够操作的命令。/bin下的一些命令可以被root与一般用户所使用,主要有cat,chmod,chown,date,mv,mkdir,cp,bash等常用命令。
/sbin ##系统管理命令存放位置,一般只能有超级用户执行。大多数命令普通用户一般无权限执行,类似/sbin/ifconfig,普通用户使用绝对路径也能执行,用于查看当前系统的网络配置。
/boot ##启动分区,负责系统启动。存放linux启动时内核以及引导系统程序所需要的核心文件,内核文件(vmlinuz)和grub系统引导管理器(/boot/grub)位于此目录。
/dev ##存放设备与设备接口管理文件,访问该目录下的某个文件相当于访问某个硬件设备,常用的有/dev/null,/dev/zero,/dev/tty,/dev/ip*,/dev/hd*,/dev/sd*。
/etc ##存放大多数系统配置文件,作为一些软件启动时默认配置文件读取的目录,不可放置可执行文件。/etc/fstab:存放系统分区挂载信息,/etc/init.d:所有服务的默认启动脚本。/etc/xinetd.d:super daemon(超级守护进程)管理的各项服务的配置文件目录。/etc/X11:与X Windows有关的配置文件,xorg.conf:XServer的配置文件。
/home ##普通用户的家目录,
/lib ##32位系统库文件存放位置,主要存放开机时用到的函数库,以及在/bin或/sbin下面的命令会调用的函数库。/lib/modules:存放内核相关的模块(驱动程序)
/lib64 ##64位系统库文件存放位置
/media ##系统临时设备挂载点。存放软盘,光盘,DVD等设备。
/mnt ##系统临时设备挂载点
/run ##系统临时设备挂载点
/opt ##第三方软件安装位置。存放第三方软件以及自行安装额外的软件。
/proc ##虚拟文件系统,存放系统运行时的运行信息,如进程信息,内核信息,网络信息等。此目录存放在内存中,实际不占用磁盘空间。如/proc/cpuinfo存放cpu的相关信息。
/root ##超级用户家目录
/srv,/var ##系统数据,日志文件
/sys ##系统管理,主要是关于内核的
/tmp ##系统临时文件存放位置,任何人均可访问。系统软件或者用户运行程序时产生的临时文件存放在这里。此目录数据需要定期清除。
/usr ##系统用户相关信息数据及用户自定义软件存放位置。
(2)系统文件路径
绝对路径
文件在系统的真实位置,文件名字以“/”开头,例如:/usr/share/doc。
相对路径
文件相对与当前所在位置的一个名字的简写,这个名字不会以/开头,而且名字会自动添加pwd显示的值
标签:linux
原文地址:http://jiekeyang.blog.51cto.com/11144634/1834269