第二周作业

作业

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

相关推荐

  • Nginx专题: 从编译安装到URL重写

    Nginx专题: 从编译安装到URL重写 前言 环境介绍 Nginx介绍 编译安装Nginx 配置文件解释 main和event{}的配置 http{}的基本配置 配置Nginx 搭建一个基本的Nginx Web服务器 实现https 创建CA并签署Nginx证书 修改配置文件 测试https 实现URL Rewrite将不同浏览器的请求响应不同页面 URL…

    Linux干货 2016-04-04
  • 第四周作业

    cp、grep、sueradd、chmod、vim命令的一些用法

    Linux干货 2017-12-24
  • 8.9_Linux文本处理三剑客之sed和文本编辑利器vim的使用

    本文处理三剑客之sed的使用   什么是sed? Stream EDitor(简称sed), 行编辑器,一次只读一行,只处理一行,不对源文件做处理,至输出到屏幕上。 sed是一种流编辑器,它一次处理一行内容。处理时,把当前处理的行存储在临时缓冲区中,称为“模式空间”(pattern space),接着用sed命令处理缓冲区中的内容,处理完成后,把缓…

    Linux干货 2016-08-11
  • 第三周练习

    1、列出当前系统上所有已经登录的用户的用户名,注意:同一个用户登录多次,则只显示一次: who | cut -d” ” -f1 | uniq 2、取出最后登录到当前系统的用户的相关信息 id `last | head -1 | cut -d” ” -f1` 3、列出当前系统上被用户当作默认shell的最多的那个shell cut -d: -f7 /etc/p…

    Linux干货 2017-07-16
  • Linux用户和组管理类命令以及文本处理工具的各种实例

    列出当前系统上所有已经登录的用户的用户名,注意:同一个用户登录多次,则只显示一次即可。 取出最后登录到当前系统的用户的相关信息。 取出当前系统上被用户当作其默认shell的最多的那个shell。 将/etc/passwd中的第三个字段数值最大的后10个用户的信息全部改为大写后保存至/tmp/maxusers.txt文件中。 取出当前主机的IP地址,提示:对i…

    2018-03-13
  • 第六周作业

    请详细总结vim编辑器的使用并完成以下练习题 vim总结:     模式:编辑模式                 插入模式                 末行模式  …

    Linux干货 2017-02-06