目录与路径
绝对路径与相对路径
绝对路径:路径的写法『一定由根目录 / 写起』,例如: /usr/share/doc 这个目录。
相对路径:路径的写法『不是由 / 写起』,例如由 /usr/share/doc 要到 /usr/share/man 底下时,可以写成: cd ../man这就是相对路径的写法,相对路径意指『相对于目前工作目录的路径
- Cd表示要转换到的目录
- . 代表此层目录
- .. 代表上一层目录
- - 代表前一个工作目录
- ~ 代表『目前用户身份』所在的家目录
- ~account 代表 account 这个用户的家目录
- pwd (显示目前所在的目录) 例如在上个表格最后的目录是/var/mail这个目录,但是提示字符仅显示mail, 如果你想要知道目前所在的目录,可以输入pwd即可
- mkdir (创建新目录),假如你要创建一个目录为 /home/bird/testing/test1,那么首先必须要有 /home 然后 /home/bird ,再来 /home/bird/testing 都必须要存在,才可以创建 /home/bird/testing/test1 这个目录
- rmdir (删除『空』的目录)
- pwd,mkdir,rm
- 关于运行档路径的变量: $PATH 例如/bin/ls(这是绝对路径), 那你会不会觉得很奇怪:『为什么我可以在任何地方运行/bin/ls这个指令呢? 』 为什么我在任何目录下输入 ls 就一定可以显示出一些消息而不会说找不到该 /bin/ls 指令呢?这是因为环境变量 PATH 的帮助所致,echo有『显示、印出』的意思,而 PATH 前面加的 $ 表示后面接的是变量,所以会显示出目前的 PATH,通过上面的图可以看出这个ls确实存在于/root底下,并不是被删除了!
- 所以,为了安全起见,不建议将『.』加入PATH的搜索目录中。
- PATH
- ls,
- 文件与目录的查看: ls
- -a :全部的文件,连同隐藏档( 开头为 . 的文件) 一起列出来
- -d :仅列出目录本身,而不是列出目录内的文件数据
- -l :长数据串列出,包含文件的属性与权限等等数据
- cp (复制文件或目录)
- -a :相当于 -dr --preserve=all 的意思
- -i :若目标档(destination)已经存在时,在覆盖时会先询问动作的进行
- -p :连同文件的属性(权限、用户、时间)一起复制过去,而非使用缺省属性
- -r :递归持续复制,用于目录的复制行为
- -l :进行硬式链接(hard link)的链接档创建,而非复制文件本身;
- Cp使用时需要注意权限
- rm (移除文件或目录)
- -f :就是 force 的意思,忽略不存在的文件,不会出现警告消息;
- -i :交互模式,在删除前会询问用户是否动作
- -r :递归删除,最常用在目录的删除了
- mv (移动文件与目录,或更名)
- 选项与参数:
- -f :force 强制的意思,如果目标文件已经存在,不会询问而直接覆盖;
- -i :若目标文件 (destination) 已经存在时,就会询问是否覆盖!
- -u :若目标文件已经存在,且 source 比较新,才会更新 (update)
- 例如:复制一文件,创建一目录,将文件移动到目录中
- cd /tmp
- cp ~/.bashrc bashrc
- mkdir mvtest
- mv bashrc mvtest
文件内容查阅
直接查看文件内容: cat, tac, nl
- cat 由第一行开始显示文件内容
- tac 从最后一行开始显示,可以看出 tac 是 cat 的倒着写!
- nl 显示的时候,顺道输出行号!
- more 一页一页的显示文件内容
- less 与 more 类似,但是比 more 更好的是,他可以往前翻页!
- head 只看头几行
- tail 只看尾巴几行
- od 以二进位的方式读取文件内容!
- cat (concatenate)
- -n :打印出行号,连同空白行也会有行号,与 -b 的选项不同;
- tac (反向列示)
- tac 刚好是将 cat 反写过来,所以他的功能就跟 cat 相反
- cat 是由『第一行到最后一行连续显示在屏幕上』,而 tac 则是『 由最后一行到第一行反向在屏幕上显示出来 』
- nl (添加行号打印)
- nl 可以将输出的-b :指定行号指定的方式,主要有两种:
- -b a :表示不论是否为空行,也同样列出行号(类似 cat -n);
- -b t :如果有空行,空的那一行不要列出行号(默认值);
- -n :列出行号表示的方法,主要有三种:
- -n ln :行号在屏幕的最左方显示;
- -n rn :行号在自己字段的最右方显示,且不加 0 ;
- -n rz :行号在自己字段的最右方显示,且加 0 ;
- -w :行号字段的占用的字符数。文件内容自动的加上行号
more (一页一页翻动)
- 空白键 (space):代表向下翻一页;
- Enter :代表向下翻『一行』;
- /字符串 :代表在这个显示的内容当中,向下搜索『字符串』这个关键字;
- :f :立刻显示出文件名以及目前显示的行数;
- q :代表立刻离开 more ,不再显示该文件内容。
- b 或 [ctrl]-b :代表往回翻页,不过这动作只对文件有用,对管线无用。
head (取出前面几行)
- 若要显示前 20 行,就得要这样:
- head -n 20 /etc/man_db.conf
- 范例:如果后面100行的数据都不打印,只打印/etc/man_db.conf的前面几行
- head -n -100 /etc/man_db.conf
tail (取出后面几行)
- 若要显示最后的 20 行,就得要这样:
- tail -n 20 /etc/man_db.conf
- 例一:如果不知道/etc/man_db.conf有几行,却只想列出100行以后的数据时?
- tail -n +100 /etc/man_db.conf
修改文件时间或建置新档: touch
- 每个文件在linux底下都会记录许多的时间参数, 其实是有三个主要的变动时间
- Mtime
- 当该文件的『内容数据』变更时,就会更新这个时间!内容数据指的是文件的内容,而不是文件的属性或权限
- Ctime
- 当该文件的『状态 (status)』改变时,就会更新这个时间,举例来说,像是权限与属性被更改了,都会更新这个时间
- Atime
- 当『该文件的内容被取用』时,就会更新这个读取时间 (access)。举例来说,我们使用 cat 去读取 /etc/man_db.conf , 就会更新该文件的 atime 了
- Mtime
- 以下是实例
- [root@study ~]# touch [-acdmt] 文件
- 选项与参数:
-a :仅修订 access time;
-c :仅修改文件的时间,若该文件不存在则不创建新文件;
-d :后面可以接欲修订的日期而不用目前的日期,也可以使用 --date="日期或时间"
-m :仅修改 mtime ;
-t :后面可以接欲修订的时间而不用目前的时间,格式为[YYYYMMDDhhmm]
- 至于运行的结果当中,我们可以发现数据的内容与属性是被复制过来的,因此文件内容时间(mtime)与原本文件相同。
- 透过 touch 这个指令,我们可以轻易的修订文件的日期与时间。并且也可以创建一个空的文件喔! 不过,要注意的是,即使我们复制一个文件时,复制所有的属性,但也没有办法复制 ctime 这个属性的。 ctime 可以记录这个文件最近的状态 (status) 被改变的时间。无论如何,还是要告知大家, 我们平时看的文件属性中,比较重要的还是属于那个 mtime 。我们关心的常常是这个文件的『内容』 是什么时候被更动的
文件与目录的缺省权限与隐藏权限
文件缺省权限:umask
- umask
- 0022
- umask -S
- u=rwx,g=rx,o=rx
- 简单的来说umask可以设置用户访问的默认权限
- umask 的分数指的是『该默认值需要减掉的权限!』因为 r、w、x 分别是 4、2、1 分,所以啰!也就是说,当要拿掉能写的权限,就是输入 2 分,而如果要拿掉能读的权限,也就是 4 分,那么要拿掉读与写的权限,也就是 6 分,而要拿掉运行与写入的权限,也就是 3 分,这样了解吗?请问你, 5 分是什么?呵呵! 就是读与运行的权限啦
- umask 为 003 ,所以拿掉的权限为 --------wx,因此:
- 文件: (-rw-rw-rw-) - (--------wx) = -rw-rw-r--
- 目录: (drwxrwxrwx) - (d-------wx) = drwxrwxr-
文件特殊权限: SUID, SGID, SBIT
- Set UID
- SUID的权限有这样的限制与功能:
- SUID 权限仅对二进位程序(binary program)有效;
- 运行者对于该程序需要具有 x 的可运行权限;
- 本权限仅在运行该程序的过程中有效 (run-time);
- 运行者将具有该程序拥有者 (owner) 的权限。
- 如果 dmtsai 使用 cat 去读取 /etc/shadow 时,他能够读取吗?因为 cat 不具有 SUID 的权限,所以 dmtsai 运行 『cat /etc/shadow』 时,是不能读取 /etc/shadow 的
观察文件类型:file
- 如果你想要知道某个文件的基本数据,例如是属于 ASCII 或者是 data 文件,就可以利用 file 这个指令来检阅
- file ~/.bashrc
- /root/.bashrc: ASCII text
指令与文件的搜索
which (寻找『运行档』)
- -a :将所有由 PATH 目录中可以找到的指令均列出,而不止第一个被找到的指令名称
- 这个指令是根据『PATH』这个环境变量所规范的路径
- 如下例子
- 搜索 ifconfig 这个指令的完整文件名
- [root@study ~]# which ifconfig
- /sbin/ifconfig
Find
-
- 这个可以根据时间来查找有变动过内容的文件
- find / -mtime 0
- # 那个 0 是重点0 代表目前的时间,所以,从现在开始到 24 小时前,