第二周的作业

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

命令:ls

NAME:用于列出目录的内容;

SYNOPSIS:ls [OPTION]… [FILE]…

FILE:

如果FILE是个文件的话,则显示文件名;

如果FILE是个目录的话,则列出目录的内容;

OPTION:

-l:显示长格式的信息,一共包含了7个字段的信息;

-rw-r–r– 1 root root 0 Sep  8 15:28 1.txt

字段1:-rw-r–r–

mode bit,模式位

第1位表示文件的类型,常规文件是-,目录文件是d,等等;

第2位至第10位,3位1组,表示相关用户对此文件锁拥有的权限,第一组表示文件所有者,第二组表示文件所有组,第三组表示其他人;

字段2:1

硬链接的数量

字段3:root

文件的所有者

字段4:root

文件的所有组

字段5:0

文件的大小

字段6:Sep  8 15:28

文件的修改时间的时间戳

字段7:1.txt

文件名

-a:显示所有文件,包含隐藏文件;

-A:同-a,但是不显示.和..文件;

-h,–human-readble:对文件大小的单位换算,但是换算后的结果不精确;

-r,–reverse:排序时逆序显示;

-R,–recursive:递归显示子目录;

-d:如果参数是个目录的话,可以查看目录的属性,结合-l选项使用;

命令:mkdir

NAME:创建目录

SYNOPSIS:mkdir [OPTION]… DIRECTORY…

OPTION:

-p:按需创建父目录;

-v:verbose,显示详细过程;

-m MODE:创建目录时给定权限;

注意:mkdir创建的是目标目录,如果目标目录的父目录或其他上级目录不存在,则默认情况下创建失败;

命令:rmdir

NAME:删除一个空目录

SYNOPSIS:rmdir [OPTION]… DIRECTORY…

必须是空目录,由于此特性,所以此命令很少使用

OPTION:

-p:删除目标目录以及它的上级目录,举个例子:

rmdir -p a/b/c等同于rmdir a/b/c a/b a

命令:touch

NAME:修改文件的时间戳

SYSNOPSIS:touch [OPTION]… FILE…

当该命令不添加任何的OPTION,并且FILE是新的文件名的时候,默认情况下,它会创建一个空内容的新文件;

不过该命令主要还是用于修改时间戳的,这次的作业是讲文件管理类命令,所以修改时间戳这块,这里就不说了;

命令:cp

在操作系统中,复制的本质是创建一个空文件,读取源文件并写入到空文件中。

NAME:复制文件和目录

SYNOPSIS:

SOURCE表示源文件,DEST表示目标文件;

单源复制:

cp [OPTION]… [-T] SOURCE DEST

如果DEST不存在,则事先创建DEST,并复制源文件的数据至DEST中;

如果DEST存在:

如果DEST是非目录文件,则会覆盖目标文件;

如果DEST是目录文件,则在DEST目录下创建一个与源文件同名文件并复制

多源复制:

cp [OPTION]… SOURCE… DIRECTORY

cp [OPTION]… -t DIRECTORY SOURCE…

注:第二种多源复制很少使用,用第一种即可。

如果DEST不存在:error;

如果DEST存在:

如果DEST是非目录文件,error;

如果DEST是目录文件,则分别复制多个源文件至目标目录下,并保持原名;

OPTION:

-i:interactive,交互式的,若需要覆盖,提醒用户确认;

-f:force,若需要覆盖,不提醒用户,强制覆盖;

-R,-r:recursive,递归复制目录;

-d,–no-dereference –preserve=links:在默认情况下,如果SOURCE是一个字符链接文件的话,cp会将字符链接文件参考的文件的数据复制到DEST中,复制之后的文件就不再是一个链接文件了;而如果加上此参数的话,那么会保留链接文件本身的参考信息,复制后的DEST仍会是一个链接文件;

–preserve:保留源文件的指定属性,包括权限mode、时间戳timestamp、归属ownship、上下文context、扩展属性xattr、字符链接links、以上所有all,多个属性之间,使用逗号分隔;

-a,–archive:等同于-dR –preserve=all,用于实现归档做备份;

命令:rm

NAME:删除文件或者目录

SYNOPSIS:rm [OPTION]… FILE…

OPTION:

-f, –force:强制删除,不提示;

-i:每次删除之前都要提示;

-r, -R, –recursive:递归删除,用于删除一个目录的时候;

命令:mv

NAME:移动或者重命名文件

大部分用法和机制,类似于cp命令;

mv的SOURCE如果是一个目录的话,无需加类似-r的递归选项;

如果SOURCE和DEST在同一路径下,则mv的功能由mv变为rename

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

命令执行状态返回值和命令行展开都属于bash的基础特性

命令执行状态返回值:

bash通过状态返回值来输出此结果:

成功:0

失败:1~255

命令执行完成之后,其状态返回值保存于bash的特殊变量$?中;

命令行展开:

~:自动展开为当前用户的家目录或者指定的用户的家目录

{}:可承载一个以逗号分隔的路径列表,并能够将其展开为多个路径;

例如:/tmp/{a,b}等同于/tmp/a和/tmp/b

具体的演示,我们在下面那题来操作看看就知道了。

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

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

mkdir -pv {a,b}_{c,d}

第二周的作业1.png

   (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

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}}

第二周的作业2.png

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

答:

1、元数据我也不太好确定,大概有这些内容,文件的大小、属性、时间戳、块大小等等用于描述此文件的相关属性,不知道是否使用stat查出来的都算元数据。

2、查看的话,可以使用stat命令

NAME:显示文件或文件系统的状态;

第二周的作业3.png

File:文件名;Size:文件的大小,单位字节;Blocks:数据占用的块数量;IO Block:块大小,单位字节;regular file:说明文件类型;Device:设备ID之类的吧;Inode:inode节点的编号;Links:硬连接数;第一个Access:访问的权限;Uid:所有者;Gid:所有组;第二个Access:文件被访问的时间,一般是打开的时候就会记录,但是如果频繁打开的话,Linux默认不会修改此元数据;Modify:文件被修改的时间;Change:元数据改变的时间;

3、修改文件的时间戳信息,使用命令touch;

NAME:修改文件的时间戳

SYNOPSIS:touch [OPTION]… FILE…

OPTION:

-a:仅修改atime;

-m:仅修改mtime;

-t:指定时间戳,而不再是当前时间为时间戳;

[[CC]YY]MMDDhhmm[.ss]

ctime是无法指定的,因为ctime指的是元数据的改变时间,元数据是必定会被修改的;

第二周的作业4.png

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

定义一个别名

SYNOPSIS:alias ALIAS_COMMAND='COMMAND'

EXAMPLE:alias head='head -n 1'

取消一个别名的定义

SYNOPSIS:unalias ALIAS_COMMAND

EXAMPLE:unalias head

引用有两种方式

$()和“

EXAMPLE:

useradd $(head -n 1 /tmp/user.txt)

useradd `head -n 1 /tmp/user.txt`

马哥建议使用$()

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

ls -d /var/l*[[:digit:]]*[[:lower:]]

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

ls -d /etc/[[:digit:]]*[^[:digit:]]

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

ls -d /etc/[^[:alpha:]][a-z]*

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

touch /tmp/tfile-$(date +"%F-%H-%M-%S")

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

cp -r /etc/p*[^[:digit:]] /tmp/mytest1/

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

cp -r /etc/*.d /tmp/mytest2/

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

cp -r /etc/[lmn]*.conf /tmp/mytest3/

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

(0)
N24_alongdidiN24_alongdidi
上一篇 2016-11-23
下一篇 2016-11-23

相关推荐

  • 如何使用openssl工具创建私有CA

    一、CA及证书 非对称加密是为了保证互联网中通讯信息安全使用的一种算法,密钥是成对出现(公钥和私钥),它的特点是发送方A使用接收方B的公钥加密数据,所有只有B拥有与之配对的私钥解密该数据,反之亦然。那么,A和B之间怎么交换得到对方的真实安全的公钥呢?此时就需要一个权威的机构来验证公钥的合法性,这个机构称之为CA(Certification Authority…

    2017-07-16
  • ls的常用用法

    第一个命令

    2018-03-26
  • nginx 配置参数说明和实验

    nginx.org 实验版本: 1.10.2 相关命令: # nginx -t //检查配置文件格式 #nginx -s reload //重新载入配置文件 实验: 主配文件大概组成 主配置文件的设定 /etc/nginx/nginx.conf events{..} //事件驱动相关 http{..} //网站服务相关 全局配置段解读与实验: user ng…

    2017-05-12
  • vim快捷方式

    Vim是从 vi 发展出来的一个文本编辑器。代码补全、编译及错误跳转等方便编程的功能特别丰富,在程序员中被广泛使用,和Emacs并列成为类Unix系统用户最喜欢的文本编辑器

    Linux干货 2017-11-26
  • file 命令

    文件类型:             – 普通文件             d 目录文件   &nb…

    2017-07-23
  • Centos下实现多网卡绑定

    实现多网卡绑定在Centos6和Centos7可采用bonding方式,Centos7上team网络组也可实现,并且功能更强大。 Linux bonding 模块提供一种将多个网卡聚合成一块逻辑捆绑网卡的实现方法。 捆绑的网卡拥有多种模式,根据模式的特性,可实现网络负载均衡,网络冗余切换,提高网络吞吐量等功能。 大多流行Linux发行版都已装载bonding…

    Linux干货 2016-09-13

评论列表(1条)

  • luoweiro
    luoweiro 2016-11-30 22:19

    使用$()和使用$xxx的差别在有一些地方还是很关键的,不如pig=2 $pigs 和 $(pig)s就是一个典型的例子