马哥教育网络班21期第2周课程练习

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

        cp [OPTION]… [-T] SOURCE DEST

        cp [OPTION]… SOURCE… DIRECTORY

        cp [OPTION]… -t DIRECTORY SOURCE…

        cp SRC DEST

         SRC是文件:

         如果目标不存在:新建DEST,并将SRC中内容填充至DEST中;

[root@MyServer ~]# cp /etc/inittab  /tmp
[root@MyServer ~]# ll /tmp/
total 8
-rw-r--r--  1 root root 158 Jul 17 13:49 hosts
-rw-r--r--  1 root root 884 Jul 17 21:05 inittab
-rw-------. 1 root root   0 Dec 21  2011 yum.log

        如果目录存在:

        如果DEST是文件:将SRC中的内容覆盖至DEST中;

        此时建议为cp命令使用-i选项;

        如果DEST是目录:在DEST下新建与原文件同名的文件,并将SRC中内容填充至新文件中;

[root@MyServer ~]# ll /tmp/
total 8
-rw-r--r--  1 root root 158 Jul 17 13:49 hosts
-rw-r--r--  1 root root 884 Jul 17 21:05 inittab
-rw-------. 1 root root   0 Dec 21  2011 yum.log
[root@MyServer ~]#  cp -i /etc/inittab /tmp
cp: overwrite `/tmp/inittab'? y
[root@MyServer ~]# 
[root@MyServer ~]# ll /tmp/
total 8
-rw-r--r--  1 root root 158 Jul 17 13:49 hosts
-rw-r--r--  1 root root 884 Jul 17 21:06 inittab
-rw-------. 1 root root   0 Dec 21  2011 yum.log

        cp SRC… DEST

        SRC…:多个文件

        DEST必须存在,且为目录,其它情形均会出错;

        cp SRC DEST

        SRC是目录:

        此时使用选项:-r

        如果DEST不存在:则创建指定目录,复制SRC目录中所有文件至DEST中;

        如果DEST存在:

        如果DEST是文件:报错

        如果DEST是目录:

        常用选项:

        -i:交互式

        -r, -R: 递归复制目录及内部的所有内容;

        -a: 归档,相当于-dR –preserv=all

        -d:–no-dereference –preserv=links

        –preserv[=ATTR_LIST]

        mode: 权限

        ownership: 属主属组

        timestamp: 时间戳

        links 链接

        xattr 扩展属性

        context 安全上下文

        all 以上所有

        -p: –preserv=mode,ownership,timestamp

        -v: –verbose

        -f: –force

    移动命令:mv

       move,移动文件

       mv [OPTION]… [-T] SOURCE DEST

       mv [OPTION]… SOURCE… DIRECTORY

       mv [OPTION]… -t DIRECTORY SOURCE…

        常用选项:

           -i: 交互式

           -f: 强制

    删除命令:rm

        remove,删除

    rm [OPTION]… FILE…

[root@MyServer ~]# ll 
total 12
-rw-r--r-- 1 root root    0 Jul 17 11:09 3
-rw-r--r-- 1 root root   27 Jul 12 20:43 aa.txt
-rw-r--r-- 1 root root    2 Jul 17 21:08 a.txt
drwxr-xr-x 2 root root 4096 Jul 16 21:34 shell
[root@MyServer ~]# rm a.txt 
rm: remove regular file `a.txt'? y

    常用选项:

    -i: 交互式

    -f: 强制删除

    -r: 递归

        rm -rf

[root@MyServer ~]# rm -rf /tmp/aaaa/
[root@MyServer ~]# ll /tmp/
total 8
-rw-r--r--  1 root root 158 Jul 17 13:49 hosts
-rw-r--r--  1 root root 884 Jul 17 21:06 inittab
-rw-------. 1 root root   0 Dec 21  2011 yum.log
[root@MyServer ~]# ll /tmp/aaaa/
ls: cannot access /tmp/aaaa/: No such file or directory

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

[root@MyServer ~]# ll /
total 94
dr-xr-xr-x.  2 root root  4096 Sep 28  2014 bin
dr-xr-xr-x.  5 root root  1024 Apr 30  2013 boot
drwxr-xr-x  16 root root  3500 Jul 11 20:13 dev
drwxr-xr-x. 58 root root  4096 Jul 17 09:59 etc
drwxr-xr-x   4 root root  4096 Jul 16 20:05 home
dr-xr-xr-x. 10 root root  4096 Apr 30  2013 lib
dr-xr-xr-x.  8 root root 12288 Apr 30  2013 lib64
drwx------.  2 root root 16384 Dec 21  2011 lost+found
drwxr-xr-x.  2 root root  4096 Sep 23  2011 media
drwxr-xr-x.  3 root root  4096 Dec 21  2011 mnt
drwxr-xr-x.  2 root root  4096 Sep 23  2011 opt
dr-xr-xr-x  94 root root     0 Jul 11 20:13 proc
dr-xr-x---.  3 root root  4096 Jul 17 21:09 root
dr-xr-xr-x.  2 root root 12288 Apr 30  2013 sbin
drwxr-xr-x.  2 root root  4096 Dec 21  2011 selinux
drwxr-xr-x.  2 root root  4096 Sep 23  2011 srv
drwxr-xr-x  13 root root     0 Jul 11 20:13 sys
drwxrwxrwt.  3 root root  4096 Jul 17 21:11 tmp
drwxr-xr-x. 13 root root  4096 Dec 21  2011 usr
drwxr-xr-x. 17 root root  4096 Dec 21  2011 var
[root@MyServer ~]# echo $?
0

[root@MyServer ~]# ls /aaaaa
ls: cannot access /aaaaa: No such file or directory
[root@MyServer ~]# echo $?
2
[root@MyServer ~]#

    执行状态返回值$?的数字含义为:

        0:成功执行;

        1-255:执行失败。
3、请使用命令行展开功能来完成以下练习:

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

[root@MyServer ~]# touch {a,b}_{c,d}
[root@MyServer ~]# ll
total 8
-rw-r--r-- 1 root root    0 Jul 17 11:09 3
-rw-r--r-- 1 root root   27 Jul 12 20:43 aa.txt
-rw-r--r-- 1 root root    0 Jul 17 21:13 a_c
-rw-r--r-- 1 root root    0 Jul 17 21:13 a_d
-rw-r--r-- 1 root root    0 Jul 17 21:13 b_c
-rw-r--r-- 1 root root    0 Jul 17 21:13 b_d
drwxr-xr-x 2 root root 4096 Jul 16 21:34 shell

   (2)、创建/tmp/mylinux目录

[root@MyServer ~]#  mkdir -pv /tmp/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}}
mkdir: created directory `/tmp/mylinux'
mkdir: created directory `/tmp/mylinux/bin'
mkdir: created directory `/tmp/mylinux/boot'
mkdir: created directory `/tmp/mylinux/boot/grub'
mkdir: created directory `/tmp/mylinux/dev'
mkdir: created directory `/tmp/mylinux/etc'
mkdir: created directory `/tmp/mylinux/etc/rc.d'
mkdir: created directory `/tmp/mylinux/etc/rc.d/init.d'
mkdir: created directory `/tmp/mylinux/etc/sysconfig'
mkdir: created directory `/tmp/mylinux/etc/sysconfig/network-scripts'
mkdir: created directory `/tmp/mylinux/lib'
mkdir: created directory `/tmp/mylinux/lib/modules'
mkdir: created directory `/tmp/mylinux/lib64'
mkdir: created directory `/tmp/mylinux/proc'
mkdir: created directory `/tmp/mylinux/sbin'
mkdir: created directory `/tmp/mylinux/sys'
mkdir: created directory `/tmp/mylinux/tmp'
mkdir: created directory `/tmp/mylinux/usr'
mkdir: created directory `/tmp/mylinux/usr/local'
mkdir: created directory `/tmp/mylinux/usr/local/bin'
mkdir: created directory `/tmp/mylinux/usr/local/sbin'
mkdir: created directory `/tmp/mylinux/var'
mkdir: created directory `/tmp/mylinux/var/lock'
mkdir: created directory `/tmp/mylinux/var/log'
mkdir: created directory `/tmp/mylinux/var/run'

[root@MyServer ~]# tree /tmp/mylinux/
/tmp/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
24 directories, 0 files

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

文件的时间戳管理工具:

touch

文件:metadata, data

查看文件状态:stat

三个时间戳:

access time:访问时间,简写为atime,读取文件内容

modify time: 修改时间, mtime,改变文件内容(数据)

change time: 改变时间, ctime,元数据发生改变

touch命令:

touch [OPTION]… FILE…

-a: only atime

-m: only mtime

-t STAMP:

[[CC]YY]MMDDhhmm[.ss]

-c: 如果文件不存,则不予创建

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

    命令别名(alias)

通过alias命令实现:

(1) alias

显示当前shell进程所有可用的命令别名;

(2) alias NAME='VALUE'

定义别名NAME,其相当于执行命令VALUE;

注意:在命令行中定义的别名,仅对当前shell进程有效;如果想永久有效,要定义在配置文件中;

仅对当前用户:~/.bashrc

对所有用户有效:/etc/bashrc

Note: 编辑配置给出的新配置不会立即生效;

bash进程重新读取配置文件:

source /path/to/config_file

.  /path/to/config_file

撤消别名:unalias

unalias [-a] name [name …]

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

[root@MyServer ~]# ls /var/1*[0-9]*[a-z]
ls: cannot access /var/1*[0-9]*[a-z]: No such file or directory

7、显示/etc目录下,以任意一个数字开头,且以非数字结尾的文件或目录。
[root@MyServer ~]#  ls /etc/[0-9]*[^0-9]
8、显示/etc目录下,以非字母开头,后面跟了一个字母以及其它任意长度任意字符的文件或目录。
[root@MyServer ~]# ls /etc/[^[:alpha:]][:alpha:]*
9、在/tmp目录下创建以tfile开头,后跟当前日期和时间的文件,文件名形如:tfile-2016-05-27-09-32-22。

[root@MyServer ~]#  touch tfile-`date +%F-%H-%M-%S`
[root@MyServer ~]# ll
total 8
-rw-r--r-- 1 root root    0 Jul 17 11:09 3
-rw-r--r-- 1 root root   27 Jul 12 20:43 aa.txt
-rw-r--r-- 1 root root    0 Jul 17 21:13 a_c
-rw-r--r-- 1 root root    0 Jul 17 21:13 a_d
-rw-r--r-- 1 root root    0 Jul 17 21:13 b_c
-rw-r--r-- 1 root root    0 Jul 17 21:13 b_d
drwxr-xr-x 2 root root 4096 Jul 16 21:34 shell
-rw-r--r-- 1 root root    0 Jul 17 21:20 tfile-2016-07-17-21-20-46

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

[root@MyServer ~]#  mkdir /tmp/mytest1
[root@MyServer ~]# 
[root@MyServer ~]# 
[root@MyServer ~]# cp -r /etc/p*[^0-9] /tmp/mytest1
[root@MyServer ~]#

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

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

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

[root@MyServer ~]#  mkdir /tmp/mytest3
[root@MyServer ~]# 
[root@MyServer ~]# 
[root@MyServer ~]#  cp -r /etc/[l,m,n]*\.conf /tmp/mytest3
[root@MyServer ~]#

原创文章,作者:liangxiaoming,如若转载,请注明出处:http://www.178linux.com/24618

(0)
liangxiaomingliangxiaoming
上一篇 2016-07-17
下一篇 2016-07-17

相关推荐

  • hadoop分布式集群

    分布式集群的实现 环境: 192.168.36.129   node1:NN,SNN,RM  192.168.36.130  node2:DN,NM 192.168.36.132   node3:DN,NM 192.168.36.133   node4:DN,NM 配置java环境,每个节点时间同步,基于主机名互相通信,定义/etc/hosts 文件 &nb…

    2017-12-09
  • CentOS 7网络属性配置

    传统命名:以太网eth[0,1,2,…], wlan[0,1,2,…] 可预测功能 udev支持多种不同的命名方案: Firmware, 拓扑结构 (1) 网卡命名机制 systemd对网络设备的命名方式: (a) 如果Firmware或BIOS为主板上集成的设备提供的索引信息可用,且可预测则根据此索引进行命名,例如eno1; (b)…

    Linux干货 2015-05-28
  • N25_第二周

    Linux文件管理类命令 cp命令:copy 源文件;目标文件; 单源复制:cp [OPTION]… [-T] SOURCE DEST 多源复制:cp [OPTION]… SOURCE… DIRECTORY |       cp [OPTION]… -t DIRECTORY SOURCE……

    Linux干货 2016-12-11
  • 第六周作业

    1、简述osi七层模型和TCP/IP五层模型 1、 osi七层模型 1、应用层:OSI 参考模型中最靠近用户的一层,为计算机用户提供应用接口,也为用户直接提供各种网络服务。我们常见应用层的网络服务协议有:HTTP,HTTPS,FTP,POP3、SMTP等。 2、表示层:提供各种用于应用层数据的编码和转换功能,确保一个主机的应用层发送的数据能被另一个主机的应用…

    2018-06-29
  • Linux运维学习历程-第十天-文件查找工具

    概述:本篇主要讲解locate命令和find命令,来帮助我们在linux中完成文件查找,方便我们快速定位文件。 一、文件查找    即在文件系统上查找符合条件的文件,常用工具有locate和find  1、locate命令    locate命令其实是find -name的另一种写法,但是要比后者快得多,原因…

    Linux干货 2016-08-21
  • 【招聘福利】UCloud/DBA工程师/上海/16-20K

    公司介绍:UCloud 主营业务:基础云服务商 网 址:www.ucloud.cn 地点:上海市杨浦区 有意向的学员,请联系magedu-小助手QQ:1522609717 任职资格: 1、有mysql、mongodb和redis等产品的运维和管理经验 2、对mysql高可用、数据备份、恢复有经验者优先 3、对ssd mysql和mysql5.6有优化经验者优…

    Linux职位 2015-11-16

评论列表(1条)

  • 马哥教育
    马哥教育 2016-07-17 21:56

    写的很好,排版还可以在改进一下,来点例子呗,加油