1、查看文件与目录:ls
ls -a:全部的文件,连同隐藏文件(开头为【.】的文件)一起列出来
ls -l:列出长数据串,包含文件的属性与权限等数据
后面还可以加目录,比如要查看主文件夹下面的所有文件(含属性与隐藏文件),可是使用命令
ls -al ~
2、复制文件或目录:cp
cp:复制文件或目录
-a:相当于-pdr
-d:若源文件为连接文件属性,则复制连接文件属性而非文件本身
-i:若目标文件已经存在时,在覆盖之前询问
-p:连同文件的属性一起复制过去,而非使用默认属性
-r:递归持续复制,用于目录的复制行为
-s:复制成为符号链接文件,即快捷方式
-u:如果目标文件比源文件旧才更新目标文件
注意:在默认条件下,cp的源文件与目标文件的权限是不相同的,目标文件的所有者通常是命令操作者,所以一些特殊权限文件,比如密码和配置文件,是不能直接用cp来复制的,必须要加上-a或-p参数保持原来的权限才可以。但是只有在root权限下操作才可以,因为普通用户是不能修改用户和用户组的,所以-a参数也就无效了,如果你在普通用户下加上-a参数复制文件,你会发现文件没有保持原来的用户和用户组,而是变成了执行操作的用户的文件。
3、移除文件或目录:rm
rm -f:忽略不存在的文件,不会出现警告信息
rm -i:互动模式,在删除之前会询问用户是否操作
rm -r:递归删除,最常用的目录删除
4、移动文件或目录,或更名:mv
mv -f:不询问,直接覆盖
mv -i:若目标文件已经存在,则询问是否覆盖
mv -u:若目标文件已经存在,且源文件比较新才会覆盖
5、查看文件内容
cat:从第一行开始显示文件内容 -n:打印行号
tac:反向显示
less:一页一页翻动,可向上向下翻动
head:取出前面几行,默认显示十行,如果要显示前二十行:head -n 20 filename,如果后面100行不打印,只显示前面的:head -n -100 filename
tail:取出后面几行,默认显示十行,如果要显示后二十行:tail -n 20 filename,如果要显示100行以后的数据:tail -n +100 filename
6、文件默认权限:umask
第一个数字是特殊权限,先不用管
后面三个数字分别对应文件所有者,用户组和非用户组的权限,数字的值表示需要减掉的权限,比如第二个数字是0说明文件所有者不需要减掉权限,即拥有可读、可写、可执行的权限,第三个数字是2,表示用户组需要减掉写的权限,即用户组拥有的权限为r-x
也可以使用命令umask -S
比如上面在用户主目录下面的默认权限是022,那么新建的文件同用户组的其他成员是无法编辑的,因为2(可写的权限)已经被拿掉了,那么怎么设置umask呢,直接在umask后面输入002就可以了
umask 002
7、文件隐藏属性chattr , lsattr
chattr:设置文件的隐藏属性
a:当设置a之后,这个文件将只能增加数据,而不能删除也不能修改数据,只有root才能设置这个属性
i:使文件不能被删除、改名、无法写入或添加数据,对于系统安全性有相当大的帮助,只有root能设置此属性
比如给/etc/shadow添加i属性,使用如下命令:
如果要拿掉i属性
8、查看文件类型:file
查看文件类型是属于ASCII或者是data文件或者是binary文件等等,可以使用file命令
9、文件名的查找
通常使用whereis或者是locate来查找,如果找不到,才使用find命令查找,因为whereis和locate是利用数据库来查找数据,所以相当快速,而且没有实际查询硬盘,所以相当快速,而find命令会实际查找硬盘,所以会比较慢