第二周作业

作业

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
下一篇 2018-03-21

相关推荐

  • 马哥教育21期网络班—第三周课程+练习

    1、列出当前系统上所有已经登录的用户的用户名,注意:同一个用户登录多次,则只显示一次即可。 who |cut -d" " -f1 |sort -u 2、取出最后登录到当前系统的用户的相关信息。 id `who | tail -n …

    Linux干货 2016-07-12
  • N25第二周作业

    第二周作业 一、Linux上的文件管理类命令有哪些,其常用的使用方法以及相关实例演示 演示用结构  [root@centos01 yanshi]# tree -a /tmp/yanshi/   /tmp/yanshi/ ├── a │   └── 1…

    Linux干货 2016-12-14
  • keepalive实验

    实验环境centos 7 server x2 做keepalived主备 地址分别是192.168.0.200 192.168.0.201 Centos 7 server x2 做real server 采用DR模型   yum -y install ntp#安装ntp client ntpdate 47.95.253.33#时间同步到自己的ntp…

    2017-12-11
  • Linux权限基本介绍,管理

     Linux权限机制采用UGO模式。其中 u(user)表示所属用户、g(group)表示所属组、o(other)表示除了所属用户、所属组之外的情况。 u、g、o 都有读(read)、写(write)、执行(excute) 三个权限,所以UGO模式是三类九种基本权限。         用命令 ls …

    Linux干货 2017-07-22
  • 苦上半年时间

    这是一种享受

    Linux干货 2016-08-08
  • 磁盘管理、文件系统、挂载

    磁盘管理 一磁盘分区 磁盘分区有两种方式:MBR和GPT MBR:1)按照柱面进行分区;分区不超过2T 2)关于0磁道0扇区的前512bytes;其中的446bytes为boot loader;中间的64bytes装有分区表;2bytes为55AA 3)可分4个分区;3个主分区+1扩展(N个逻辑分区)扩展分区最多一个。 GPT分区:1)GUID patiti…

    Linux干货 2016-08-29