p { margin-bottom: 0.25cm; line-height: 120% }
首先介绍目录相关的路径的表示法:
1 . 代表此目录
2 .. 代表上一层目录
3 – 代表前一个工作目录
4 ~ 代表当前用户身份的主文件夹
5 ~account 代表account这个用户的主文件夹
然后介绍下路径的2个概念:1
相对路径 2绝对路径
绝对路径:
例如/home/zhf/zhf这个路径,路径由根目录开始写起,包含了所有经过的路径
相对路径:路径不是由/写起。相对路径指相对于当前工作目录的路径。相对路径可以写成
cd
../test这种方式,举个例子:在zhf文件夹中有test和test1的文件夹。如果我首先进入test文件夹,此时想要转换到test1文件夹。一般的写法是cd
.. 然后cd
./test1。先回退到上一级目录,然后进入test1文件夹。
p { margin-bottom: 0.25cm; line-height: 120% }
但是test和test1都属于zhf文件夹下面,所以从test转换到test1可以用cd ../test1的方式
目录处理常见
的几个命令如下:
1
cd: change directory. cd后面可以跟相对路径和绝对路径。比如cd
/home/zhf/zhf就是到zhf这个文件夹。
cd
~回到根目录。cd
~zhf 回到zhf的/home
目录
p { margin-bottom: 0.25cm; line-height: 120% }
2 pwd: print working directoy. 顾名思义就是打印当前的工作路径
3 mkdir: 创建文件夹。这里有2个配置参数 -m和-p。
-m:配置文件的权限。当我们创建文件或者文件夹的时候,创建的文件和文件夹是默认权限的。 默认权限可以用umask 来查看。在这里我们的umask是0022。大多数的系统也都是这个值
p { margin-bottom: 0.25cm; line-height: 120% }
第一位的数字忽略,也就是默认权限是022. 这代表什么意思呢。前一章讲到用户和用户权限的时候,提到文件的权限分为读写执行,rwx。分别用数字代表就是 4 2 1。文件权限有本用户,同属一个用户组的用户权限,其他用户的权限。 三者结合起来,如果所有用户都用户读写执行权限,那么文件的权限就是rwx-rwx-rwx。写成数字也就是777. 那么倒过来再看下umask就比较清楚了。umask就代表777需要减去的权限。umask是022,那么默认的权限就是777-022=755。也就代表当前用户有读写执行权限,同用户组用户和其他用户有读,执行权限。也就是rwx-r—xr—x. 我们实际建立一个文件夹来看下是否是这样的。新建立的test文件夹 权限正好是rwx-r—xr--x
p { margin-bottom: 0.25cm; line-height: 120% }
如果觉得umask的0022太过于抽象. 可以用umask -S来更直观的看文件的默认权限
root@zhf-linux:/home/zhf/zhf# umask -S
u=rwx,g=rx,o=rx
所以这里用-m可以制定我们想用的权限。而不是用默认的权限。如下:
root@zhf-linux:/home/zhf/zhf#
mkdir -m 766 test
root@zhf-linux:/home/zhf/zhf#
ls -al
total
7648
drwxrwxr-x
7 zhf zhf 4096 Aug 28 21:30 .
drwxr-xr-x
28 zhf zhf 4096 Aug 28 20:53 ..
-rw-r--r--
1 root zhf 37 May 24 2016 crontest.cron
-rw-r--r--
1 zhf zhf 7733727 Nov 7 2016 Django-1.10.3.tar.gz
drwxr-xr-x
3 root root 4096 Jul 29 10:33 python_prj
drwxrwxr-x
13 root zhf 4096 Aug 21 09:53 python_source
-rw-r--r--
1 zhf zhf 5645 Sep 26 2016 python.vim
-rw-rw-r--
1 zhf zhf 3646 Aug 6 14:24 result1.html
-rw-r--r--
1 root root 0 Aug 6 1root@zhf-linux:/home/zhf/zhf# mkdir
test/test2
mkdir:
cannot create directory ‘test/test2’: No such file or
directory4:24 result.html
drwxrwxr-x
2 zhf zhf 4096 May 14 14:49 shell_test
drwxrw-rw-
2 root root 4096 Aug 28 21:30 test
-rw-rw-r--
1 zhf zhf 38844 Aug 6 15:28 test.png
-rw-rw-r--
1 zhf zhf 145 Aug 6 13:56 test.txt
drwxrwxr-x
2 zhf zhf 4096 Jul 28 10:31 tool_source
-rw-r--r--
1 root root 161 Apr 1 06:30 tst1.tar.bz2
-p:
将所需要的目录递归的建立起来。比如我想建立多个路径的文件夹。mkdir
test/test2. 执行失败。提示没有
test这个文件夹。
root@zhf-linux:/home/zhf/zhf#
mkdir test/test2
mkdir:
cannot create directory ‘test/test2’: No such file or directory
而采用mkdir
test/test2。 则可以一次性的建立test/test2文件夹。
4
rmdir: 删除文件夹。
-p和建立的意思一样,代表连同上层的空目录一起删掉
文件的隐藏属性:
前面介绍了文件的读写执行权限,其实文件还有一些隐藏属性。可以用lsattr和chattr来查看和更改。
chattr有几个参数如下:
a:
只能增加数据,既不能删除也不能修改数据,只有root用户有这个权限
c:
读取的时候会自动亚索
d:
当dump程序被执行的时候,可确保该文件不被dump备份
i:
文件既不能被删除,改名,也无法写入或者添加数据。root用户有此权限
s:
当某件被删除的时候,完全从这个硬盘删除
u:与s相反,如果文件被删除了,数据内容还存在与硬盘中,还可以找回
那么如何设置权限呢,很简单,+代表增加某个权限,-代表去掉某个权限。
我们以i这个参数来看下
root@zhf-linux:/home/zhf/zhf#
chattr +i test.txt
root@zhf-linux:/home/zhf/zhf#
rm test.txt
rm:
cannot remove 'test.txt': Operation not permitted
root@zhf-linux:/home/zhf/zhf#
chattr -i test.txt
root@zhf-linux:/home/zhf/zhf#
rm test.txt
在设置了+i后,文件不能被删除。在-i后,文件才能被删除。在设置了权限后,通过lsattr来查看对应的权限。
root@zhf-linux:/home/zhf/zhf#
chattr +i test.txt
root@zhf-linux:/home/zhf/zhf#
lsattr test.txt
----i--------e--
test.txt
文件查找:
在一个系统中,要去查找文件是一件很头疼的事情,在windows中有各种各样的文件查找软件。比如everything。
但在Linux下,有许多命令也可以快速查找文件。
查找命令有whereis,locate,find。通常使用的是whereis和locate。因为相比find查找硬盘,whereis和locate是查找数据库。速度更快一些。但是find的参数配置更灵活。也就是能更精准的找到我们想要的文件。我们重点介绍下find命令。
命令格式:find
[PATH] [option] [action]
PATH代表查找的路径,如果没有特指的路径,也可以用/根目录开始查找
option有很多种:
-mtime:
根据修改时间
-uid:根据用户的uid
-gid:根据用户的gid
-user
name:根据用户名
-group
name:根据群组名字
-name:根据文件名
-size:根据文件大小
-type:根据文件类型
-perm
+-mode: 根据文件权限 必须要全部包含或者任一mode的文件
action:
在查找完文件后,我们想进行后处理,比如将结果保存在一个文件里面。就要用到action。命令格式位
-exec
ls -l {} \; -exec {}
\;都是关键字命令,其中我们要执行的动作写在-exec和{}之间。find的结果就放在{}里面。
来看一个例子,我们要找到在/home/zhf下的test.py文件。用如下的命令
root@zhf-linux:/home/zhf/zhf/python_prj#
find /home/zhf -name test.py
/home/zhf/py_prj/test.py
/home/zhf/zhf/python_prj/test.py
/home/zhf/zhf/python_source/python-nmap-0.6.1/nmap/test.py
/home/zhf/zhf/python_source/python-nmap-0.6.1/build/lib.linux-i686-2.7/nmap/test.py
/home/zhf/zhf/python_source/Django-1.10.3/django/core/management/commands/test.py
/home/zhf/zhf/python_source/Django-1.10.3/build/lib.linux-i686-2.7/django/core/management/commands/test.py
查找到后需要列出所有文件的权限,也就是执行ls
-l命令
root@zhf-linux:/home/zhf/zhf/python_prj#
find /home/zhf -name test.py -exec ls -al {} \;
-rw-r--r--
1 root zhf 427 Oct 24 2016 /home/zhf/py_prj/test.py
-rw-r--rw-
1 root root 66 Jul 28 11:35 /home/zhf/zhf/python_prj/test.py
-rw-r--r--
1 zhf zhf 171 Jul 30 2016
/home/zhf/zhf/python_source/python-nmap-0.6.1/nmap/test.py
-rw-r--r--
1 root root 171 Jul 30 2016
/home/zhf/zhf/python_source/python-nmap-0.6.1/build/lib.linux-i686-2.7/nmap/test.py
-rw-rw-r--
1 zhf zhf 2794 Nov 1 2016
/home/zhf/zhf/python_source/Django-1.10.3/django/core/management/commands/test.py
-rw-r--r--
1 root zhf 2794 Nov 1 2016
/home/zhf/zhf/python_source/Django-1.10.3/build/lib.linux-i686-2.7/django/core/management/commands/test.py