马哥教育网络第21期-第二周课程练习

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

   linux中经常使用的文件管理命令主要有cp,mv,rm这三个命令。
    复制命令:cp
    cp [option] SRC DEST
        SRC是文件:
            如果目标不存在:新建DEST,将SRC的内容填充到DEST中。
            目标存在:将SRC的内容覆盖到DESC中。
[root@localhost mnt]# cp -i /etc/passwd /mnt
[root@localhost mnt]# ls
lineout.sh  passwd  spaceline.sh  useridsum.sh
[root@localhost mnt]#
[root@localhost mnt]# cp -i /etc/passwd /mnt/abc
[root@localhost mnt]# ls
abc

        SRC为多个文件:

            DESC必须存在且为目录。

[root@localhost mnt]# cp  -i /etc/shadow /etc/group /mnt
[root@localhost mnt]# ls
group  lineout.sh  passwd  shadow  spaceline.sh  useridsum.sh
[root@localhost mnt]#

        SRC是目录:  

            使用选项:-r

            DESC不存在则自动创建,DESC存在时必须是目录,文件会报错。

[root@localhost home]# ls
jtah
[root@localhost home]# cp -r jtah/ /mnt
         常用选项:  
    -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
        mv [option] SRC DESC
        常用选项:
        -i: 交互式
        -f: 强制
    删除文件:rm
        rm [option] FILE
        常用选项:
    -i: 交互式
    -f: 强制删除
    -r: 递归

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

bash命令执行的结果有两种成功或失败,成功的返回值用0表示,1-255表示失败。bash使用echo $?来保存最近一条命令的执行结果。

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

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

root@localhost tmp]# mkdir {a,b}_{c,d}
[root@localhost tmp]# ls -l
总用量 76
drwxr-xr-x. 2 root root     6 7月  16 22:18 a_c
drwxr-xr-x. 2 root root     6 7月  16 22:18 a_d
drwxr-xr-x. 2 root root     6 7月  16 22:18 b_c
drwxr-xr-x. 2 root root     6 7月  16 22:18 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 tmp]# mkdir -p 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 tmp]# tree mylinux/
mylinux/
├── bin
├── boot
│   └── grub
├── dev
├── etcrc.d
│   └── init.d
├── etcsysconfig
│   └── network-scripts
├── lib
│   └── modules
├── lib64
├── proc
├── sbin
├── sys
├── tmp
├── usr
│   ├── localbin
│   └── localsbin
└── var
    ├── lock
    ├── log
    └── run

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

文件系统中的数据分为数据和元数据,数据是指普通文件的实际数据,元数据是用来描述一个文件特征的系统数据,如访问权限,文件拥有者等等。
[root@localhost tmp]# ls -l /etc/passwd
-rw-r--r--. 1 root root 3355 7月  15 11:17 /etc/passwd
第1行代表文件的格式主要有一下几种
    1.-:普通文件
    2.d:目录文件
    3.l:符号连接文件
    4.s:套接字文件
    5.p:管道文件
    6.b:块设备文件
    7.c:字设备文件
第2-9代表文件的拥有者,属组,其他用户对文件的访问权限
    r:读    w:写    x:执行
    使用stat和touch可以修改和查看文件的时间戳信息
    
[root@localhost tmp]# stat /etc/passwd
文件:"/etc/passwd"
大小:3355      	块:8          IO 块:4096   普通文件
设备:fd00h/64768d	Inode:34137289    硬链接:1
权限:(0644/-rw-r--r--)  Uid:(    0/    root)   Gid:(    0/    root)
环境:system_u:object_r:passwd_file_t:s0
最近访问:2016-07-16 22:42:49.602895353 +0800
最近更改:2016-07-16 22:42:49.602895353 +0800
最近改动:2016-07-16 22:42:49.602895353 +0800
创建时间:-

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

使用aliase可以查看当前shell的的别名。aliase=value可以定义命令别名
        (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@localhost var]# ls -d /var/l*[0-9]*[[:lower:]]
/var/lib60test

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

[root@localhost var]# ls  /etc/[0-9]*[^0-9]

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

[root@localhost var]# ls /etc/[^[:alpha:]][[:alpha:]]*

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

[root@localhost tmp]# touch /tmp/tfile`date +%F-%H-%M-%S`

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

[root@localhost tmp]# cp -rf /etc/p*[^0-9] /tmp/mytest1

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

[root@localhost tmp]# cp -rf /etc/*.d /tmp.mytest2

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

[root@localhost tmp]# cp /etc/{l.m,n}*.conf /tmp/mytest3

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

(0)
N21_619463772N21_619463772
上一篇 2016-07-17 21:50
下一篇 2016-07-19 09:06

相关推荐

  • 浅谈RPM

    浅谈RPM    [先絮叨下编译啊]   1、 库:其实就是一个程序模块(它没有执行入口,不能独立执行,只能被能独立运行的程序调用时执行)你可以把它想象成工具螺丝刀,可执行的程序是就是你自己;螺丝刀能自己干活吗?没有螺丝刀能拧螺丝吗?或者说你现在制作一个? 螺丝刀可以实现这个功能但需要你来执行这个动作。   2、静态编译:将程序所需要的所有的库都编…

    Linux干货 2015-04-27
  • 笔记整理:权限管理1-基础权限管理&默认权限

    权限管理: 权限的分配根据owner和group来进行分配的   对于文件,各个权限的意义: r:可以使用工具查看内容 w:往里写 x:运行,提请内核发起一个进程 对于目录,各个权限的意义: r:用ls 查看目录列表   w:可以创建或删除目录中的文件   x:可以使用ls -l查看文件列表,也可cd进去   管理命令…

    Linux干货 2016-08-05
  • 磁盘管理之文件系统

    一,概述 文件系统是操作系统用于明确存储设备或分区上的文件的方 法和数据结构;即在存储设备上组织文件的方法。操作系统 中负责管理和存储文件信息的软件结构称为文件管理系统, 简称文件系统。  从系统角度来看,文件系统是对文件存储设备的空间进行组 织和分配,负责文件存储并对存入的文件进行保护和检索的 系统。具体地说,它负责为用户建立文件,存入、读出、修…

    Linux干货 2016-09-05
  • gawk基础及进阶

    GUN awk: 文本处理三工具:grep,sed,awd grep,egrep,fgrep:文本过滤工具:pattern sed:行编辑器 模式空间、保持空间 awk:报告生成器,格式化文本输出; AWK:Aho,Weinberger,Kernighan –> New AWK,NAWK GNU awk,gawk gawk – …

    Linux干货 2017-05-22
  • memcache

      memcached: memcached is a high-performance, distributed memory object caching system, generic in nature, but&nbsp…

    Linux干货 2016-11-01
  • 第六周作业补充-vim简介及其使用方法详细介绍

    What       Vim是由Vi发展出来的一个文本编辑器。代码补全、编译及错误跳转等方便编程的功能特别丰富,在Unix& Unix Like操作系统中被广泛使用。和Emacs并列成为Unix& Unix Like操作系统中最受欢迎的文本编辑器 When& Who  &nb…

    Linux干货 2016-09-26

评论列表(1条)

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

    写的很好,排版也很漂亮,加油