Linux 文件目录管理的指令

Posted 无风便起浪的谢浪

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了Linux 文件目录管理的指令相关的知识,希望对你有一定的参考价值。

 

 

1.知识点:绝对路径:写法从/(根目录开始) /usr/share/doc

相对路径:不从/开始  如cd ../man

如果清楚文件夹内部情况,建议使用相对路径在文件夹之间跳转,而不用绝对路径,每次都是一长串地址

. 代表当前层目录

..代表上层目录

~代表自己的根目录

~user(user是代指用户哇!)代表到user这个人的根目录

2.cd 与 pwd

cd ..回到上一层目录

cd ../home相对路径的写法

cd /var/www/html 绝对路径的写法

cd   回到用户的根目录

cd ~   回到用户(个人)的根目录

cd ~xwc  回到xwc用户的根目录

pwd  显示当前目录(print working directory)

3.mkdir 与 rmdir

mkdir 目录名称  这个必须一层一层建目录

rmdir 目录名称 这个必须一层一层的删除

否则就会提示不为空

要是需要(不假思索地)都删除,可以使用指令 rm-rf h

 

 全没了(所以不大安全)

4.PATH环境变量

什么是PATH呢

当我们执行一个指令时,系统会依照PATH的设定到PATH定义的每个路径下搜寻文件,先搜寻到的指令文件先被执行。

怎么看呢?

指令 echo $PATH

 

如何将/root加到PATH中呢?(知道就好)

PATH=“$PATH”:/root(感觉跟赋值语句一样)

5.文件与目录管理指令ls cp rm mv

ls显示文件名称属性

-a列出所有文件(包括隐藏)

-l详细列出,连同文件大小,属性数据

-S以文件大小排序

--color=never/always/auto(不显示颜色,均显示颜色,由系统自行判断)

ls -l的简写 ll(两个小写的L)这个命令可以说是超级方便了。

cp 复制

-d 我复制个快捷方式到指定位置

-r 目录的复制

原本是空文件夹的3里面多了个1

 

 -s 做成链接文件

-u 如果源文件较新,或者没有目标文件,才会进行复制动作。可用于备份操作。

rm 删除

-i默认参数  询问是否删除

-rf  疯狂删除

mv 移动,变更文件名

mv x x.old    重命名

mv x1 x2 x3... /root   即把x1 x2 x3文件一并移动到root下 

6.查看文件内容

cat与tac

cat -n查看信息时把行号也给我列出来

(Concatenate 连续的缩写,不过较不常见,配合more和less比较好)

tac  反向显示(最后一行在最上面)

more 与less

more ~/.txt一页一页的显示文件内容

ls -al|more 把ll一页一页的显示出来

相较于more,  less更灵活,

可以按PgUp PgDn翻页

less  还能查找,优秀

head与tail

查看文档文档开头,文档结尾

tail -n 5 1.txt(只显示1.txt的后五行)

nl 与cat -n相似

od 读取非ASCII数据文件,此时使用vi more lesss指令看不出来内容。输出来的数据都是内存中的数据。

7.链接文件的介绍

what is inode?

介绍inode之前 我们先看硬盘结构的大体介绍

圆形 每个硬盘盘头都有一个可以读写的磁头

磁头固定,绕硬盘盘片转一圈,轨迹就是磁道Track,

所有盘片相同磁道号的集合成为磁柱,每一磁道被划分了很多区域,每个区域叫一个扇区。扇区是硬盘的最小存储物理量,约512字节。

硬盘分割后,格式化。格式化要考虑两个方面,Block和inode,Block是磁盘可以记录的最小单位,由数个扇区组成。

Block是记录文件内容数据的区域,inode是记录该文件属性及放置在哪个Block的信息,所以每个文件都会占用一个inode,所以我们就知道,一个分区被格式化为一个文件系统后,基本上他都一定会有inode table 与数据区两大块。

ln(唉,终于要说这个指令了)

相当于windows的快捷方式,不过链接功能要好用得多。连接分硬链接和符号链接。

硬链接:当系统要读取一个文件时,他会先读取inode table,再建一个inode到文件Block,没有错,这两个inode都可以到我们需要的Block那里去。但是“目录”本身是消耗inode的,这样,缺点之一:硬链接就不能链接目录,第二,不能跨文件系统。

符号链接:建个文件,相当于路牌,指向所需文件。

测试案例:

(cp 最后那个 "." 别忘了)

准备工作,建文件夹

0原始信息:

1硬链接信息:

 

注意看,上面那个数字变成2了(好神奇啊!!),这就表示占用了inodes。

2符号链接信息

注意passwd-soft会指向另一个文件,而且,最前面属性为1,此外,他是一个独立文件。先删除passwd,我们看一下内容。

3使用more

(好神奇)

如果使用-s参数,符号链接虽然跟windows的快捷方式相像,但不同,在windows中,你怎么修改快捷方式那个图标,甚至内部信息,都不会对原文件有一丝一毫的影响(撑死对不上号打不开了),但是Linux不同,你修改链接文件,被指向的文件也会修改的。

如果你:ln -s /bin /root/bin     /root/bin中的东西其实都是/bin的。

8.文件与目录权限的指令

chown chgrp chmod 

-R 可以一下改变一个目录内所有文件的权限噢

umask 可以修改建立文档时的权限噢

用户建文档默认权限是666

建文件夹默认是777

你可以 umask 111

之后再建个文件夹  就会是 666了

chattr lsattr

chattr +i 1.txt 如此就无法修改这个txt文档了

chattr -i 1.txt 解除该属性

可是我们如何看这个文件有哪些属性呢?

没错  lsattr就是来看的

-a 将隐藏文件的属性也显示

-R将子目录的数据也一并显示出来

这两个指令要谨慎使用。+i后就没法变了。

9.搜寻文件或目录

which查看可执行文件的位置

whereis查看文件的位置

locate 配合数据库查看文件位置

find 实际搜寻硬盘查询文件名称

which 别忘了是查看可执行文件的位置(eg: passwd)

whereis

(指令有的翻译了,有的没翻译。)

从上到下依次是只找二进制,只找说明文件manual路径下的文件,只找source源文件,-u是没有说明文档的文件。

whereis -m passwd

仅搜寻man page 所在的目录。

whereis 相对于find快很多,这是为什么呢

因为Linux系统将系统内的所有文件都记录在一个数据库文件中,所以就快了(??)。

locate 

和whereis 一样都是从数据库文件中来找东西,但是呢,Linux的数据库默认是一周更新一次,所以你刚刚删掉的,你会再找到,你刚刚添加的,你会在下一周才能找到。如何解决这个问题呢?

updatedb闪亮登场

来让我们看看吧

首先 touch 建个文档123456

用locate去数据库文件中找,(没更新呢,怎么会找到呢)

updatedb更新一下,

再找,找到了,然后我们删除一下

删除了,可是还能在数据库文件找到,更新一下,就找不到了。嗯就是这样。

那么到底要建立哪些数据库呢,是否全部都要建立,似乎不需要,可以选择需要建立数据数据库的目录。在/etc/updatedb.conf内设定。

find(这个不简单,我之前还天真的以为只是查找)

(好想跳过,而且书上说了,由于find在寻找数据时,相当耗硬盘(那可是递归呀。。),所以没事不要用find,用更棒的locate和whereis代替,不过还是看看吧)

1.时间

-atime n 将n*24小时内被存取过的文件列出来

-ctime n 将n*24小时内被改变、新增的文件或目录列出来

-mtime n 将n*24小时内被修改过的文件列出来

-newer file 把比file还要新的文件列出来

2.使用名称

-gid n 寻找群组ID为n的文件

-group n 寻找群组名称为n的文件

-uid n 寻找拥有者ID为n的文件

-user n 寻找拥有者名称为n的文件

-name file 找file(之前只知道这一条)

-type type 按类型找(后面那个type可以是b,c,d,p,l,s)

10.SetUID,SetGID,Sticky bit 与file指令

UID用户代号

GID群组代号

可以用 more /etc/passwd 查看系统中所有账号

如果新建一个用户,UID、GID都是0,那就是root身份。

SUID、SGID又是什么?

Set UID(SUID)的主要功能就是在某个文件执行期间具有文件拥有者的权限。

就是下图中那个rw “s”,这里是SUID,如果是-rwxr-sr-x这里就是SGID。

 

当一个文件具有SUID时,同时others群组拥有x,那么当others群组执行该程序时,others群组将拥有该文件的owner权限。

(owner:?????就因为一个SUID,别人就能和我一样高贵了?)

(可不是嘛,所以涉及到变更一个文件使之具有SUID,SGID,要万分谨慎)

Sticky bit

为什么 othrs的x没有用s代替的情况呢?

没必要。

所有人都可执行,他们自然有权限。

这里有个新的属性(Sticky bit) t,最大的用处:具有t属性的目录,其下的文件或目录只有文件拥有者及root 才有权删除。

在我们的系统中预设有一个这样的目录,辣就是/tmp

最后一行的tmp  “t“引人注目

这说明了什么,在这个目录里,普通用户可以新建修改任何文件,但是仅能删除自己建立的文件,除非你是root。

来让我们试试吧

 root登陆

到/tmp里建个文件夹shanbudiao

修改权限777 

用普通账户登陆

尝试删除

失败了。

最后一个指令 file

file 【文件名】

可以查看文件类型,还可以看是否被加入SUID等信息。

 

(文件部分的指令就到此结束了,o(* ̄▽ ̄*)ブ)

以上是关于Linux 文件目录管理的指令的主要内容,如果未能解决你的问题,请参考以下文章

[Linux] 文件与目录管理

linux常用指令介绍

Linux文件与目录管理

linux目录和文件管理

LINUX常用命令目录和文件管理

Linux指令入门目录结构和文件管理指令