第二周作业

作业

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

相关推荐

  • 用户管理类命令

    2018-03-18

    Linux干货 2018-03-18
  • Linux用户管理相关(2)

    Q1:复制/etc/skel目录为/home/tuser1,要求/home/tuser1及其内部文件的属组和其他用户均没有任何访问权限。 [root@CentOS7_2 home]# cp -r /etc/skel/ /home/tuser1 [root@CentOS7_2 home]# …

    Linux干货 2016-11-16
  • linux系统启动流程

    linux系统启动流程 CentOS(5、6)系统启动流程 具体流程: 加载BIOS的硬件信息与进行自我测试,并依据设置取得第一个可启动的设备; 读取并执行第一个启动设备内MBR的boot Loader 依据boot Loader的设置加载Kernel,Kernel会开始检测硬件与加载驱动程序 硬件驱动成功后,Kernel会主动调用init进程,而init会…

    Linux干货 2016-09-11
  • iptables

    iptables Firewall:防火墙 隔离工具;Packets Filter Firewall;工作于主机或网络的边缘,对经由的报文根据预先定义的规则(匹配条件)进行检测,对于能够被规则匹配到的报文实行某预定义的处理机制的一套组件; 分类: 硬件防火墙:在硬件级别实现部分功能的防火墙;另一个部分功能基于软件实现; 软件防火墙:应用软件处理逻辑运行于通用…

    Linux干货 2016-11-07
  • 虚拟机的三种网络模式

    前言     虚拟机的网络模式,是环境部署时的重要环节。不同的运行环境对网络的要求也是不用的,本章节重点介绍虚拟机的三种网络模式、以及他们之间的区别 虚拟机网络模式      无论是vmware,virtual box,virtual pc等虚拟机软件,一般来说,虚拟机有三种网络模式: 1.桥接 2…

    2017-07-11
  • Linux http服务

                               Linux http服务   网络服务通信基础:   1、端口号就是进程标识,每个用户最多只能打开1024个进程。   2、MAC地址仅…

    系统运维 2016-11-18