博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
《鸟哥的Linux私房菜》7章 Linux文件与目录管理 习题答案
阅读量:5741 次
发布时间:2019-06-18

本文共 3231 字,大约阅读时间需要 10 分钟。

自己整理了一下,分享给大家,这些习题确实是非常经典的!

1.什么是绝对路径与相对路径?

绝对路径是相对于/目录的路径的,比如/home/user;

相对路径是相对于当前工作目录的,比如你的系统上有个/home/user/test目录,此时你在/home/user目录下,那么./test就是相对路径。


2.如何更改一个目录的名称?例如/home/test变为/home/test2。

mv /home/test /home/test2

3.PATH这个环境变量的意义是什么?

这里先看一下PATH:

[root@xpleaf ~]# echo $PATH/usr/local/sbin:/usr/local/bin:/sbin:/bin:/usr/sbin:/usr/bin:/root/bin

当你输入一个命令时,系统就会按PATH设置的路径一个一个地去查找这个命令,直到找到为止;如果多个路径都有此命令,则以PATH设置路径中找到的第一个为准。


4.umask有什么用处与优点?

用处:可以用来设置创建文件或目录时,该文件或目录的默认权限;

优点:在一些特殊的生产环境中,如果对创建文件或目录的默认权限有需求时,就可以改变umask来达到我们的需求,从而可以更合理地控制文件与目录。


5.当一个用户的umask分别为033与044,他所建立的文件与目录的权限是什么?

关于umask的设置以及文件与目录默认权限的计算方法,可以参考我的另一篇博文:

《浅谈linux中umask值及其对应的文件权限》

这里直接给出答案:

033 044
文件权限 -|rw-|r--|r-- -|rw-|-w-|-w-
目录权限 -|rwx|r--|r-- -|rwx|-wx|-wx

6.什么是SUID?

SUID是特殊的文件权限,当文件拥有SUID权限时,其他用户(非该文件属主)如果对此文件有x权限(前提该文件还可以被执行,所以SUID一般是针对二进制命令文件),当执行该文件时,会暂时获得该文件所有者的权限,再去执行该文件。


7.当我要查询/usr/bin/passwd这个文件的传统权限、文件类型与文件的隐藏属性,可以使用什么命令来查询?

查询传统权限:

[root@xpleaf ~]# ls -l /usr/bin/passwd -rwsr-xr-x. 1 root root 30768 2月  22 2012 /usr/bin/passwd

查询文件类型:

[root@xpleaf ~]# file /usr/bin/passwd /usr/bin/passwd: setuid ELF 64-bit LSB shared object, x86-64, version 1 (SYSV), dynamically linked (uses shared libs), for GNU/Linux 2.6.18, stripped

查询隐藏属性:

[root@xpleaf ~]# lsattr /usr/bin/passwd -------------e- /usr/bin/passwd

8.尝试用find找出目前Linux系统中所有具备SUID的文件有哪些。

[root@xpleaf ~]# find / -perm +4000输出省略

注意下面三个符号的区别:

4755 查找的文件权限必须为:-|rws|r-x|r-x
-4755 查找的文件权限需要满足:文件的权限至少要与4755即-|rws|r-x|r-x相同,或权限比其更多
+4755 查找的文件权限需要满足:文件的权限最多只能与4755即-|rws|r-x|r-x相同,或权限比其更少

9.找出/etc下面,文件大小介于50KB到60KB之间的文件,并且将权限完整地列出(ls -l)。

这里我就找50KB到100KB的吧。

方法一:

[root@xpleaf ~]# find /etc -size +50k -size -100k -exec ls -l {} \; -rw-r--r--. 1 root root 88371 5月  11 22:24 /etc/termcap-rw-r--r--. 1 root root 65536 1月  13 2010 /etc/pki/nssdb/cert8.db

方法二:

[root@xpleaf ~]# find /etc -size +50k -a -size -100k -exec ls -l {} \;-rw-r--r--. 1 root root 88371 5月  11 22:24 /etc/termcap-rw-r--r--. 1 root root 65536 1月  13 2010 /etc/pki/nssdb/cert8.db

方法三:

[root@xpleaf ~]# find /etc -size +50k -a -size -100k | xargs ls -l-rw-r--r--. 1 root root 65536 1月  13 2010 /etc/pki/nssdb/cert8.db-rw-r--r--. 1 root root 88371 5月  11 22:24 /etc/termcap

其实第一种方法和第二种方法是完全一样的,参数-a是and的意思,即要同时满足前后两个参数所设立的条件,也就是50KB到60KB啦,其实默认就是-a的参数。那么不难理解,如果是-o,表示的是or即或的意思了,即-o前后两个条件,随便一个满足或者同时两个满足都可以。因为题目说的是找文件,所以其实这里加上-type f会更好,不过理解就好了,我这里就不加了,下面的题目也是。


10.找出/etc下面,文件容量大于50KB且文件所有者不是root的文件名,且文件所有者不是root的文件名,且将权限完整地列出(ls -l)。

这里我就找文件所有者不是oldboy用户的。

方法一:

[root@xpleaf ~]# find /etc -size +50k ! -user oldboy -exec ls -l {} \;      -rw-r--r--. 1 root root 88371 5月  11 22:24 /etc/termcap-rw-------. 1 root root 125811 11月 23 2013 /etc/ssh/moduli省略输出

方法二:

[root@xpleaf ~]# find /etc -size +50k -not -user oldboy -exec ls -l {} \; -rw-r--r--. 1 root root 88371 5月  11 22:24 /etc/termcap-rw-------. 1 root root 125811 11月 23 2013 /etc/ssh/moduli省略输出

看题目,“且”就是and的意思啦,所以加不加-a参数都可以。至于“!”,其实就是表示“非”的意思,跟-not是一样的。


11.找出/etc下面,容量大于1500KB以及容量等于0的文件。

这是注意“以及”字眼,按照题目的意思去理解,应该是“或”的意思,否则不可能有既大于1500KB又等于0的文件吧?所以这里用-o参数就可以了。

[root@xpleaf ~]# find /etc -size +1500k -o -size 0k/etc/environment/etc/selinux/targeted/modules/active/netfilter_contexts/etc/selinux/targeted/modules/active/policy.kern省略输出

OK,就这些了,如果有什么问题的话,请跟我说一下,谢谢!

转载地址:http://pjnzx.baihongyu.com/

你可能感兴趣的文章
我的友情链接
查看>>
我的友情链接
查看>>
模板类的友员函数
查看>>
Activiti工作流学习(二)流程实例、执行对象、任务
查看>>
OSPF Multi-zone configuration
查看>>
DNS配置案例
查看>>
GAC
查看>>
关于微信的那点帖。。。。。。(各种实例)
查看>>
This Activity already has an action bar supplied b
查看>>
ajax批量删除自己的微博评论(腾讯微博)
查看>>
Jenkins与Docker的自动化CI/CD实战
查看>>
windows2008下的web配置ssl(4)
查看>>
Python初始基本数据类型
查看>>
比较 SLF4J 与 log4j
查看>>
Redmine Client for windows phone 7.5
查看>>
Mac Finder 自带FTP工具
查看>>
openSUSE 下修改DNS配置
查看>>
C#矩阵加法、取负、数乘、乘法的实现
查看>>
谭浩强《C++程序设计》书后习题 第十章-第十二章
查看>>
我的友情链接
查看>>