第二周作业

1. Linux上文件管理类命令总结及示例

文件管理命令主要由查看类命令和管理类命令组成

查看类命令

  • cat:显示文本

    cat [OPTION]… [FILE]..

  • tac:倒序查看文件内容

    tac [OPTION]… [FILE]..

  • head:显示文件前几行内容

  • head [OPTION]… [FILE]..

    -n#:指定获取前#行,也可直接使用-#

    -c:指定获取前#字节内容

  • tail:显示文本后#行

    tail [OPTION]… [FILE]..

    -n#:指定获取后#行,也可直接使用-#

    -c:指定获取后#字节内容

    -f:动态显示文件新内容,如要退出使用ctrl+c

  • more:显示文本,到达文本行尾自动退出

    more [options] file […]

    -d:显示翻页及退出提示

  • less:显示文本,到达行尾必须q退出

  • stat:查看文件元数据

    access time:访问时间,即atime

    modify time:修改时间,即mtime

    change time:改变时间,即ctime

管理类命令

  • touch:改变文件时间戳

    touch [OPTION]… FILE…

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

    -a: 仅修改access time;

    -m:仅修改modify time;

    -t STAMP [[CC]YY]MMDDhhmm[.ss]

  • cp:复制文件

    单源复制:

    cp [OPTION]… [-T] SOURCE DEST

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

    如果DEST存在:

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

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

    多源复制:

    cp [OPTION]… SOURCE… DIRECTORY

    cp [OPTION]… -t DIRECTORY SOURCE…

    如果DEST不存在:错误;

    如果DEST存在:

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

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

    常用选项:

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

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

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

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

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

    –preserv=

    mode:权限

    ownership:属主和属组

    Timestamps: 时间戳

    context:安全标签

    xattr:扩展属性

    links:符号链接

    all:上述所有属性

2. bash特性命令执行返回值和展开

在bash中根据命令执行后的返回值可以判断命令是否成功执行,对于命令的展开也有其特定的语法格式
  • 命令状态执行返回值 
    成功:0 
    失败:1-255 
    命令执行完成后,其状态返回值保存于bash的特殊变量?使echo?中查看使用echo?

  • 命令行展开 
    ~:用户的家目录; 
    {}:可有展开为以逗号分隔的路径列表,并能够将其展开为多个路径; 
    如:/tmp/{a,b} 
    等同于:/tmp/a和/tmp/b

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

使用{}命令行语法格式可以一次行执行多个命令

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

touch {a,b}_{c,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

mkdir -pv {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}}

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

一个数据文件包括元数据和数据本身,元数据描述了文件本身的多个属性

文件元数据有:

  • 名称

  • 大小

  • 块数量

  • IO块数量

  • 文件类型

  • Inode

  • 链接

  • Uid

  • Gid

  • atime

  • mtime

  • ctime

使用stat命令查看

stat FILE

使用touch命令修改

touch [OPTION] FILE
-a:修改atime
-m:修改mtime
-t [[CC]YY]MMDDhhmm[.ss]:以指定时间修改时间戳

5. 如何定义一个命令的别名?如何在一个命令中应用另一个命令的结果?

shell使用者可以按照自己的习惯定义命令别名,方便调用各命令的同时也提高效率

使用alias命令查看和定义别名

alias [-p] [name[=value] ... ]
alias 查看
alias cls='clear' 设置名利别名

注:此别名只有在当前shell中有效,重启后无效。要长久保存需在bashrc中 
使用$(COMMAD)在一个命令中应用另一个命令的结果

echo "$(date +"%F %T")"

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

ls -d /var/1*[0-9]*[[:lower:]]

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

ls -d /etc/[0-9]*[^0-9]

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

ls -d /etc/[^a-z][a-z]*

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

touch /tmp/tfile-$(date +%F-%H-%M-%S)

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

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

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

cp -fr /etc/*.d /tmp/mytest2

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

cp -f /etc/[lmn]*.conf /tmp/mytest3

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

(0)
allenallen
上一篇 2016-12-10 01:41
下一篇 2016-12-10 14:48

相关推荐

  • 初识selinux

    一、selinux介绍     1.selinux历史     SELinux: Secure Enhanced Linux,是美国国家安全局「NSA=The National Security Agency」和SCC(Secure Computing Corporation)开…

    Linux干货 2016-09-21
  • 马哥教育21期网络班—第12周课程+练习—-LAMP练习

    1、请描述一次完整的http请求处理过程; (1) 建立或处理连接:接收请求或拒绝请求 (2) 接收请求: 接收来自于网络的请求报文中对某资源的一次请求的过程; 持久连接:接收到请求不会断开这个请求 非持久连接:一个连接请求断开一次 并发访问响应模型(Web I/O): 单进程I/O结构:启动一个进程处理用户请求,而且一次只处理…

    Linux干货 2016-09-26
  • Linux Service and Security(Part 2)

    接PART 1 4、SSH端口转发:SSH会自动加密和解密所有SSH客户端与服务端之间的网络数据。但是,SSH还能够将其它TCP端口的网络数据通过SSH链接来转发,并且自动提供了相应的加密及解密服务,这一过程也被叫做“隧道(tunneling)”。telnet,SMTP,LDAP这些TCP应用均能够从中得益,避免了用户名、密码以及隐私信息的明文传输。同时,如…

    Linux干货 2016-10-09
  • 文件权限

    浅谈文件权限 Linux系统中的每个文件和目录都有访问许可权限,用他来确定谁能通过何种方式对文件和目录进行访问和操作。  文件权限: 文件或目录的访问权限分为只读,只写和可执行三种。  文件的权限主要针对三类对象进行定义:          owne…

    Linux干货 2016-08-07
  • 第一周作业-03

    ifconfig命令:查看及临时修改网卡配置信息    查看的用法:ifconfig [-v] [-a] [-s] [INTERFACE]        OPTIONS            -v:详细显示接口报错信息   &nb…

    Linux干货 2016-09-19
  • N25-第6周博客作业

    N25-第6周博客作业 vim:     模式化的编辑器         基本模式:             编辑模式,…

    Linux干货 2017-01-09

评论列表(1条)

  • 马哥教育
    马哥教育 2016-12-16 15:19

    赞~阅读起来很顺~建议将查看类的命令适当展开进行描述会更好~~继续加油~