Linux常用文件管理命令及用法

一.Linux上的文件管理命令及其常用的使用方法及相关示例演示:

1.常用命令

(1)ls:列出指定目录下的内容

 格式:ls [OPTION]... [FILE]...

        -a:显示所有文件包括隐藏文件

   -A:显示除.和..之外的所有文件

   -l,--long:显示文件的详细属性信息

   -h:对文件大小进行单位换算,可能影响精度

   -d:查看目录本身而非其内部的文件

   -r:逆序显示文件

   -R:递归显示文件

示例:ls -lah / --详细显示/目录下的所有文件(包括隐藏文件)

    ls -ldh /etc --详细显示/etc目录本身

    ls -lhv / --倒序显示/目录下所有文件(包括隐藏文件)

    ls -R /etc    --递归显示/etc下所有文件

(2)  mkdir:创建目录

 格式:mkdir [OPTION]... DIRECTORY...

   -p:自动按需创建父目录

   -m:创建目录时给定权限

 示例:mkdir -p /data/test/A/B --在/data目录下递归创建/test/A/B三个目录

   mkdir -m 711 -p /data/MODE/A --在/data目录下递归创建MODE/A两个目录同时指定目录A的权限为711

(3)rmdir:删除目录

 格式:rmdir [OPTION]... DIRECTORY...

   -p:删除目录后如果其父目录为空,则一并删除

 示例:rmdir -p /data/test/A --删除A目录后,test目录为空,一并删除

(4)cd:切换目录

示例:cd ..:切换到上级目录

   cd ~:切换回自己的家目录

   cd -:在上一次目录与当前目录直接来回切换

(5)pwd:显示当前目录

(6)cp:复制

格式:单源复制:cp [OPTION]... [-T] SOURCE DEST(如果DEST不存在则创建,存在则覆盖)

    多源复制:cp [OPTION]... SOURCE... DIRECTORY(DEST必须为directory)

    -i:交互式复制,即覆盖前提醒用户确认

   -f:强制覆盖目标文件

    -r,-R:递归复制目录

 示例:cp -if /data/[1-3].txt /data/test --test必须为目录,把三个文件一起复制到test中

    cp -r /data /practice --把data目录及目录下的内容一起复制到practice中

(7)mv:剪切

格式:单源复制:mv [OPTION]... [-T] SOURCE DEST(如果DEST不存在则创建,存在则覆盖)

    多源复制:mv [OPTION]... SOURCE... DIRECTORY(DEST必须为directory)

   -i:交互式复制,即覆盖前提醒用户确认

   -f:强制覆盖目标文件

 示例:mv -i /data/[1-3].txt /practice --把/data目录下三个txt文件剪切到/practice下

(8)rm:删除

格式:rm [OPTION]... FILE...

    -i:交互式复制,即覆盖前提醒用户确认

    -f:强制覆盖目标文件

   -r,-R:递归处理,将制定目录下的所有文件包括目录一并删除

 示例:rm -rf /practice --递归删除/practice目录 (3)文本内容管理命令

(9)cat:正向查看文本内容

 格式:cat [OPTION]... [FILE]...

   -n:给显示的文本行编号

   -E:显示行结束符号$

 示例:cat -n /etc/fstab --查看/etc/fatab内容并显示行号

(10)tac:倒叙查看文本内容

 格式:tac [OPTION]... [FILE]...

示例:tac /etc/passwd --倒叙查看文本内容

(11)head:显示文本内容,默认显示头10行 格式:head [OPTION]... [FILE]...

   -n #:显示文本头#行内容

 示例:head -5 /etc/passwd --显示/etc/passwd文件头5行内容

 (12)tail:显示文本内容,默认显示后10行

格式:tail [OPTION]... [FILE]...

   -n #:显示文本后#行内容

   -f:查看文件尾部内容结束后不退出,跟随显示新增的行

示例:tail -8 /etc/passwd --显示/etc/passwd文件后8行内容

(13)more:分屏显示文本内容,每次显示一屏显示完停止

 格式:more [options] file [...]

   Space键:显示文本下一屏内容

   Enter键:只显示文本下一行内容

   b键:显示文本上一屏内容

   q键:退出

(14)less:分屏显示文本内容,不主动退出

 格式:less [options] file [...]

   Space键:显示文本下一屏内容

    Enter键:只显示文本下一行内容

   b键:显示文本上一屏内容

   q键:退出

2.使用命令行展开功能,创建/tmp/a1, /tmp/a2,/tmp/a1/a,/tmp/a1/b,在tmp目录下创建目录:X_Y,X_Z,Q_Y,Q_Z

mkdir -p /tmp/a{1/{a,b},2}

mkdir x_{y,z} q_{y,z}

3.文件的元数据有哪些?分别表示什么含义?如何查看?如何修改文件的时间戳信息?

文件的数据分两种:一种元数据,既属性数据;

一种就是数据本身;可使用stat命令查看文件的元数据:

 例如: ]# stat /etc/passwd

 文件:”/etc/passwd”

大小:2483

块:8

IO 块:4096 普通文件

设备:fd00h/64768d

 Inode:136755684

硬链接:1

权限:(0644/-rw-r–r–)

Uid:( 0/ root)

Gid:( 0/ root)

环境:systemu:objectr:passwdfilet:s0

 最近访问:2016-09-22 22:07:14.897045766 +0800

最近更改:2016-09-20 18:10:23.223086880 +0800

 最近改动:2016-09-20 18:10:23.227086888 +0800

创建时间:-

其中:

 file:文件名;

size:文件大小

block:文件占了多少个数据块

 IO Block:文件所占数据块的块大小

 Device:硬件,既说明该文件在硬盘的那个柱面

 Inode:节点号

links:链接

 Access(第一个):权限

 Uid:该文件所属的属主

 Gid:该文件所属的属组

context:安全上下文

Access(第二个):文件上一次的访问时间

 Modify:文件上一次修改的时间

 Change:文件上一次属性更改的时间

 2.修改文件的时间戳信息:

 可以使用touch命令更改文件的时间戳:

语法: touch [OPTION]… FILE…

常用选项:

-c: 指定的文件路径不存在时不予创建;

 -a: 仅修改access time;

 -m:仅修改modify

4.创建以tfile开头,后跟当前日期和时间的文件,文件名形如:tfile-2018-12-23-09-32-22.

touch /tmp/tfile-$(date +%Y-%m-%d-%h-%M-%S)

5.复制/etc目录下所有以p开头,以非数字结尾的文件或目录至/tmp/mytest1目录中

mkdir /tmp/mytest1

cp -r /etc/p*[^0-9] /tmp/mytest1

6.创建用户tom,指定UID为5001,指定家目录为/tmp/tom,指定shell为/bin/zsh,指定基本组为tom,附加组是jack

先创建组

groupadd tom

groupadd jack

创建用户

useradd -u 5001 -d /tmp/tom -s /bin/zsh -g tom -G jack

 7、常用的用户以及文件管理命令有哪些,并演示命令以及用法

用户管理命令:

 useradd(创建用户)

 -u 指定uid

 -g 指定主组

 -G 指定附加组

-c 注释

 -d 指定家目录(不用默认家目录)

 -s 指定shell

usermod (修改用户属性)

-u 指定新的uid

 -g 指定新的主组

 -G 指定新的附加组(加-a保留原有附加组)

 -s 指定新的shell

-e YYYY-MM-DD:指定用户账号过期日期

 userdel(a删除用户)

 -r 删除家目录

 -f 强制删除用户,即使是正在登陆的用户

 id

 -u显示uid

 -g显示gid

 -G显示附加组id

 passwd

 -l 锁定、停止该用户

 -u 解锁该用户

 -e 强制用户下次登录用户修改密码

 -n 指定该账号使用最短期限天数

 -x 指定该账号使用最长期限天数


 

你可能感兴趣的:(Linux常用文件管理命令及用法)