第二周作业

作业

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

1.1、cp – copy files and directories

 单源复制: 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 :  递归复制目录;
        -d :  如果源文件是符号链接,复制符号链接本身,而非其指向的源文件
        -a :  -dR --preserve=all    用于实现归档

        --preserv=
              mode : 权限
              ownership: 属主和属组
              timestamps:时间戳
              context : 安全标签
              xattr : 扩展属性
              links: 符号链接
              all: 上述所有属性

1.2、 mv – move (rename) files

命令格式:

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

常用选项:

-i : 交互式
-f : force(强制)

1.3、rm – remove files or directories

常用选项:

 -i : 交互式
 -f : force(强制)
 -r : recursive(递归)

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

2.1、命令的执行状态结果:

bash通过状态返回值来输出此结果:命令执行后的状态返回值保存于特殊变量 $? 中
    成功:0
    失败:1-255
        注意:只记录最近一次的
[root@localhost ~]# pwd
/root
[root@localhost ~]# echo $?
0

2.2、命令行展开:

~ :自动展开为用户的家目录,或指定的用户的家目录
~USERNAME : 展开为指定用户的家目录
{}:可承载一个以逗号分隔的路径列表,并能够将其展开为多个路径:
    例如: /tmp/{a,b} 相当于/tmp/a /tmp/b

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

3.1、创建/tmp目录下的:a_c, a_d, b_c, b_d

[root@localhost ~]#mkdir /tmp/{a,b}_{c,d}
[root@localhost ~]# ll /tmp/
total 24
drwxr-xr-x.  2 root root    6 Mar 18 10:26 a_c
drwxr-xr-x.  2 root root    6 Mar 18 10:26 a_d
drwxr-xr-x.  2 root root    6 Mar 18 10:26 b_c
drwxr-xr-x.  2 root root    6 Mar 18 10:26 b_d

3.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,lib64,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
 |-- lib64
 |-- proc
 |-- sbin
 |-- sys
 |-- tmp
 |-- usr
 |   `-- local
 |       |-- bin
 |       `-- sbin
 `-- var
     |-- lock
     |-- log
     `-- run

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

文件的元数据信息有:

  • Size
  • Blocks
  • IO Block
  • Device
  • Inode
  • Links
  • Access
  • Context
  • access time
  • modify time
  • change time

查看方式:

 [root@localhost ~]# stat /etc/issue
 File: '/etc/issue'
 Size: 23           Blocks: 8          IO Block: 4096   regular file
 Device: 805h/2053d Inode: 67149976    Links: 1
 Access: (0644/-rw-r--r--)  Uid: (    0/    root)   Gid: (    0/    root)
 Context: system_u:object_r:etc_t:s0
 Access: 2018-03-18 07:48:28.417267763 +0800
 Modify: 2015-04-01 06:27:02.000000000 +0800
 Change: 2018-03-16 01:27:14.433986745 +0800
 Birth: -

修改方式文件的时间戳:使用touch命令

 touch
 touch - change file timestamps

          -c :指定的文件路径不存在时不予创建;
          -a : 仅修改atime
          -m : 仅修改mtime
          -t STAMP : 
                [[CC]YY]MMDDhhmm[.ss]

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

定义一个命令的别名使用 alias

  定义别名:alias NAME=`COMMAND`  只对当前shell进程有效
   例:[root@localhost ~]# alias tt='ls -al'

命令执行结果的引入:

   $(COMMAND)或者 `COMMAND`

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

 [root@localhost ~]# ls -d /var/l*[0-9]*[[:lower:]]

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

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

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

 [root@localhost ~]# ls -d /etc/[^[:alpha:]][[:alpha:]]*

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

 [root@localhost ~]# touch /tmp/ftile-$(date +%Y-%m-%d-%H-%M-%S)

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

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

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

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

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

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

 

本文来自投稿,不代表Linux运维部落立场,如若转载,请注明出处:http://www.178linux.com/92760

(0)
nininini
上一篇 2018-03-20 17:23
下一篇 2018-03-21 11:39

相关推荐

  • 马哥网络班21期,第三周作业

    1、列出当前系统上所有已经登录的用户的用户名,注意:同一个用户登录多次,则只显示一次即可。     who | cut -d " " -f1 | sort -u     who:查看当前系统所有用户的会话     cut:剪切命令       cut…

    Linux干货 2016-07-26
  • 测试Markdown

    测试markdown是否可用

    Linux干货 2018-03-10
  • 第九周作业

    1、写一个脚本,判断当前系统上所有用户的shell是否为可登录shell(即用户的shell不是/sbin/nologin);分别统计这两类用户的个数;通过字符串比较来实现;    #!/bin/bash     echo "可登录类型有有$(awk -F: '/[^\<nologin\&gt…

    Linux干货 2017-02-07
  • Linux安全与加密基础(二)

    Linux安全与加密基础(二) 常见的加密算法 SSL: Openssl与CA认证 ssh服务 dropbear AIDE sudo gpg gpg亦可用于对称加密与文件检验。 文件完整性的两种实施方式 被安装的文件     MD5单向散列     rpm –veri…

    Linux干货 2016-10-06
  • N26-第五周-孙逸

    1、 显示当前系统上root、fedora或user1用户的默认shell;命令:cat /etc/passwd | grep -E “^(root|fedroa|user1)” | cut -d: -f1,7 2、 找出/etc/rc.d/init.d/functions文件中某单词后面跟一组小括号的行,形如:hello(…

    2017-03-10
  • RAID概述

    1、引言 RAID全称Redundant Arrays of Inexpensive Disks / Redundant Arrays of Independent Disks,即独立冗余磁盘阵列。RAID可以通过相关技术(软件/硬件),将多个较小的磁盘整合成为一个较大的磁盘整体,而且能从某些方面提高数据的读写及数据保护。RAID分为不同…

    Linux干货 2016-12-24