"1、Linux上的文件管理类命令都有哪些,其常用的使用方法及其相关示例演示。

       cp - copy files and directories 拷贝文件和目录


        

        源文件:目标文件

     单源复制:cp [OPTION]... [-T] SOURCE DEST

多源复制:cp [OPTION]... SOURCE... DIRECTORY

         cp [OPTION]... -t DIRECTORY SOURCE...


  单源复制:cp [OPTION]... [-T] SOURCE DEST

     如果DEST不存在:则事先创建此文件,并复制源文件的数据流至DEST中;

如果DEST存在:

  如果DEST是非目录文件:则覆盖目标文件;

  如果DEST是目录文件:则先在DEST目录下创建一个与源文件同名的文件,并复制其数据流;            

       [root@localhost ~]# ls /tmp/fstab                  

             #查看/tmp 目录下是否有fstab这个文件

        ls: 无法访问/tmp/fstab: 没有那个文件或目录

        [root@localhost ~]# cp -v /etc/fstab /tmp/fstab #将源文件复制到目标文件下,并显示做了什么操作

        "/etc/fstab" -> "/tmp/fstab"

    

   源复制:cp [OPTION]... SOURCE... DIRECTORY

   cp [OPTION]... -t DIRECTORY SOURCE...

      如果DEST不存在:错误;

      如果DEST存在:

        如果DEST是非目录文件:错误;

      [root@localhost ~]# cp -r /etc/skel /tmp/fstab  /tmp/test  #多源复制,但是目标非目录

        cp: 目标"/tmp/test" 不是目录


      如果DEST是目录文件:分别复制每个文件至目标目录中,并保持原名;

                   

                   [root@localhost ~]# ll -ad /tmp/test               #查看文件详细信息

                        drwxr-xr-x. 2 root root 6 1月   5 22:27 /tmp/test      #是目录文件 

                        [root@localhost ~]# cp -r /etc/skel /tmp/fstab  /tmp/test  #递归多源复制

                        [root@localhost ~]# ll -A /tmp/test/                               #查看文件详细信息

                        总用量 4

                        -rw-r--r--. 1 root root 465 1月   5 22:29 fstab

                        drwxr-xr-x. 2 root root  59 1月   5 22:29 skel

      

常用选项:

      -i:交互式复制,即覆盖之前提醒用户确认;  #此为默认选项。

                   [root@localhost ~]# alias cp    #centos7中默认cp的别名就是-i

                        alias cp='cp -i'


      -f:强制覆盖目标文件;             

      -r, -R:递归复制目录;     #可以将文件目录层级关系一起复制

                      [root@localhost ~]# cp -r /etc/skel /tmp/fstab  /tmp/test  #递归多源复制

      -d:复制符号链接文件本身,而非其指向的源文件;

      -a:-dR --preserve=all, archive,用于实现归档;

      --preserv=

      mode:权限

                   [root@localhost ~]# cp --preserv=mode  /etc/fstab /tmp/   #copy文件并保存该文件的权限

                        cp:是否覆盖"/tmp/fstab"? 

      ownership:属主和属组

                   类似

      timestamps: 时间戳

      context:安全标签

      xattr:扩展属性

      links:符号链接

      all:上述所有属性



mv命令:move

    mv - move (rename) files    #移动文件  移动后源文件所在的目录该文件将被移动到目标文件下


      mv [OPTION]... [-T] SOURCE DEST

      mv [OPTION]... SOURCE... DIRECTORY 

      mv [OPTION]... -t DIRECTORY SOURCE..  

         

                

                [root@localhost ~]# mv /tmp/fstab /opt/   #移动文件

                [root@localhost ~]# ll -a /tmp/fstab           #查看原目录文件

                ls: 无法访问/tmp/fstab: 没有那个文件或目录

                [root@localhost ~]# ll -a /opt/fstab            #查看目标目录文件

                -rw-r--r--. 1 root root 465 12月 27 17:05 /opt/fstab


      常用选项:

      -i:交互式;

      -f:force      



rm命令:remove                         #删除文件

    rm [OPTION]... FILE...      

       [root@localhost ~]# rm -rf /opt/fstab    #强制递归删除目标文件



    常用选项:

    -i:interactive            #交互 是否提醒

    -f:force                   #强制 (不提醒)

    -r: recursive               #递归 (可以删除文件目录下的子目录)


    删除目录:rm -rf /PATH/TO/DIR

    危险操作:rm -rf /*          #此操作会删除根目录下的所有文件(基本等于格式化了磁盘)


    注意:所有不用的文件建议不要直接删除,而是移动至某个专用目录;(模拟回收站)      





2、bash的工作特性之命令执行状态返回值和命令行展开所涉及的内容及其示例演示。



命令执行的状态结果:

bash通过状态返回值来输出此结果:

成功:0

失败:1-255


命令执行完成之后,其状态返回值保存于bash的特殊变量$?中;

   [root@localhost ~]# ls -a /tmp/fstab  # 查看文件详细信息

                /tmp/fstab

                [root@localhost ~]# echo $?            #输出引用信息

                0                                                  #成功

                

                [root@localhost ~]# lss -a /tmp/fstab   #命令错误或者路径错误的话,会报错

                -bash: lss: 未找到命令

                [root@localhost ~]# echo $?              #输出引用的状态返回信息

                127




命令正常执行时,有的还回有命令返回值:

根据命令及其功能不同,结果各不相同;


引用命令的执行结果:

$(COMMAND)  

或`COMMAND`


                [root@localhost ~]# echo `ll -a /tmp/fstab`     #输出引用的输出结果。 `` 反引号

                -rw-r--r--. 1 root root 465 1月 5 23:42 /tmp/fstab



    bash的基础特性之:命令行展开

~:自动展开为用户的家目录,或指定的用户的家目录;

   [root@localhost tmp]# pwd   #当前所在目录

            /tmp

            [root@localhost tmp]# cd ~  #进入root用户家目录

            [root@localhost ~]# pwd     #验证

            /root


            [root@localhost ~]# cd ~centos  #进入centos家目录  相当于 cd /home/centos

            [root@localhost centos]# pwd

            /home/centos


{}:可承载一个以逗号分隔的路径列表,并能够将其展开为多个路径;  #需要展开的列表需要满足

例如:/tmp/{a,b} 相当于 /tmp/a /tmp/b

[root@localhost ~]# mkdir /tmp/{aa,bb}  

            [root@localhost ~]# ls -a /tmp/

            .  ..  aa  aaa.a  bb  .font-unix  ...            


3、请使用命令行展开功能来完成以下练习:

   (1)、创建/tmp目录下的:a_c, a_d, b_c, b_d


     [root@localhost ~]# mkdir -v /tmp/{a,b}_{c,d}   #-v 显示详细过程

      mkdir: 已创建目录 "/tmp/a_c"

      mkdir: 已创建目录 "/tmp/a_d"

      mkdir: 已创建目录 "/tmp/b_c"

      mkdir: 已创建目录 "/tmp/b_d"

   

   (2)、创建/tmp/mylinux目录下的:

mylinux/

    ├── bin

    ├── boot

    │   └── grub

    ├── dev

    ├── etc

    │   ├── rc.d

    │   │   └── init.d

    │   └── sysconfig

    │       └── network-scripts

    ├── lib

    │   └── modules

    ├── lib64

    ├── proc

    ├── sbin

    ├── sys

    ├── tmp

    ├── usr

    │   └── local

    │       ├── bin

    │       └── sbin

    └── var

        ├── lock

        ├── log

        └── run




      [root@localhost ~]# mkdir -pv /tmp/mylinux/{bin,boot/grub,dev,etc/{rc.d/init.d,sysconfig/network-scripts},lib/modules,lib,proc,sbin,sys,tmp,usr/local/{bin,sbin},var/{lock,log,run}}   

                                                          

                                

           [root@localhost ~]# tree /tmp/mylinux/

             /tmp/mylinux/

             ├── bin

             ├── boot

             │   └── grub

             ├── dev

             ├── etc

             │   ├── rc.d

             │   │   └── init.d

             │   └── sysconfig

             │       └── network-scripts

             ├── lib

             │   └── modules

             ├── proc

             ├── sbin

             ├── sys

             ├── tmp

             ├── usr

             │   └── local

             │       ├── bin

             │       └── sbin

             └── var

                  ├── lock

                  ├── log

                  └── run

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

数据:metadata  

   元数据被定义为:描述数据的数据,对数据及信息资源的描述性信息

stat FILE...

   [root@192 ~]# stat /etc/fstab     

              文件:"/etc/fstab"

              大小:541       块:8          IO 块:4096   普通文件

            设备:fd00h/64768d Inode:134320258   硬链接:1

            权限:(0644/-rw-r--r--)  Uid:(    0/    root)   Gid:(    0/    root)

            环境:system_u:object_r:etc_t:s0

            最近访问:2017-01-05 20:29:58.822328306 +0800

            最近更改:2016-12-24 22:57:02.154991037 +0800

            最近改动:2016-12-24 23:00:51.026981635 +0800

            创建时间:-


            -a: 仅修改access time;

-m:仅修改modify time; 

-t STAMP

[[CC]YY]MMDDhhmm[.ss]

[root@192 ~]# touch -a -t 199102201313.13 /etc/fstab    #仅修改最近访问访问时间

                    [root@192 ~]# stat /etc/fstab 

                      文件:"/etc/fstab"

                      大小:541       块:8          IO 块:4096   普通文件

                    设备:fd00h/64768d Inode:134320258   硬链接:1

                    权限:(0644/-rw-r--r--)  Uid:(    0/    root)   Gid:(    0/    root)

                    环境:system_u:object_r:etc_t:s0

                    最近访问:1991-02-20 13:13:13.000000000 +0800

                    最近更改:2016-12-24 22:57:02.154991037 +0800

                    最近改动:2017-01-05 20:42:50.755958903 +0800



5、如何定义一个命令的别名,如何在命令中引用另一个命令的执行结果?

[root@localhost ~]# echo `ll -a /tmp/fstab`          #会引用命令的执行结果

       -rw-r--r--. 1 root root 465 1月 5 23:42 /tmp/fstab


6、显示/var目录下所有以l开头,以一个小写字母结尾,且中间至少出现一位数字(可以有其它字符)的文件或目录。


[root@192 ~]# find /var/ -name "l*[0-9]*[a-z]"  -ls

71238979   52 -rw-r--r--   1 root     root        47416 11月 21 03:15 /var/cache/yum/x86_64/7/base/pack

ages/libteam-1.25-4.el7.x86_64.rpm71238987  176 -rw-r--r--   1 root     root       175776 11月 21 02:49 /var/cache/yum/x86_64/7/base/pack

ages/libmount-2.23.2-33.el7.x86_64.rpm




7、显示/etc目录下,以任意一个数字开头,且以非数字结尾的文件或目录。


[root@192 ~]# find /etc/ -name "[0-9]*[^[:digit:]]" -ls




8、显示/etc目录下,以非字母开头,后面跟了一个字母以及其它任意长度任意字符的文件或目录。


[root@192 ~]# find /etc/ -name "[^[:alpha:]][a-z]*" -ls 

67254025    4 -rw-r--r--   1 root     root           18 11月 20  2015 /etc/skel/.bash_logout


9、在/tmp目录下创建以tfile开头,后跟当前日期和时间的文件,文件名形如:tfile-2016-05-27-09-32-22。


[root@192 ~]# mkdir /tmp/tfile-$(date +%Y-%m-%d-%H-%M-%S) 

[root@192 ~]# find /tmp/ -name "tfile*" -ls

134634833    0 drwxr-xr-x   2 root     root            6 1月  5 21:56 /tmp/tfile-2017-01-05-21-56-23

202435925    0 drwxr-xr-x   2 root     root            6 1月  5 21:59 /tmp/tfile-2017-01-05-21-59-58



10、复制/etc目录下所有以p开头,以非数字结尾的文件或目录到/tmp/mytest1目录中。

[root@192 ~]# mkdir /tmp/mytest1

[root@192 ~]# cp -r /etc/p*[^[:digit:]]  /tmp/mytest1/

[root@192 ~]# ll -a /tmp/mytest1/

总用量 68

drwxr-xr-x. 14 root root 4096 1月   5 22:15 .

drwxrwxrwt. 32 root root 4096 1月   5 22:15 ..

drwxr-xr-x.  2 root root 4096 1月   5 22:15 pam.d

-rw-r--r--.  1 root root 2517 1月   5 22:15 passwd

-rw-r--r--.  1 root root 2474 1月   5 22:15 passwd-

...




11、复制/etc目录下所有以.d结尾的文件或目录至/tmp/mytest2目录中。


[root@192 ~]# mkdir /tmp/mytest2

[root@192 ~]# cp -r /etc/*.d /tmp/mytest2

[root@192 ~]# tree /tmp/mytest2

/tmp/mytest2

|-- auto.master.d

|-- bash_completion.d

...



12、复制/etc/目录下所有以l或m或n开头,以.conf结尾的文件至/tmp/mytest3目录中。"


[root@192 ~]# cp -r /etc/[lmn]*.conf /tmp/mytest3

[root@192 ~]# ll -A /tmp/mytest3

总用量 52

-rw-r--r--. 1 root root   28 1月   5 22:22 ld.so.conf

-rw-r-----. 1 root root  191 1月   5 22:22 libaudit.conf