Linux文件管理及bash特性详解

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

 文件管理工具:cp,mv,rm

      cp命令:copy

      源文件:目标文件

 单源复制:cp [OPTION]… [-T] SOURCE DEST

 多源复制:cp [OPTION]… SOURCE… DIRECTORY

        cp [OPTION]… -t DIRECTORY SOURCE…

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

          如果DEST存在:

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

              如果DEST是目录文件:则先在DEST目录下创建一个与源文件同名的文件,并复制其数据流至目标文件;

 多源目录:如果DEST不存在,错误

          如果DEST存在:

              如果DEST是非目录文件,错误

              如果DEST是目录文件;分别复制每个文件至目标目录中,并保存原名;

 常用选项:

     -i:交互式复制,即覆盖之前提醒用户确认;

     -f:强制覆盖目标文件;

     -r:递归复制目录

     -d:复制符号链接文件本身,而非其指向的源文件;

     -a:-dR –preserve=all,archive,用于实现归档

     –preserv=

        mode:权限

        ownership:属主和属组

        timestamp:时间戳

        context:安全标签

        xattr:扩展属性

        links:符号链接

        all:上述所有属性

 mv命令:跟cp差不多,只不过是mv把源文件删除了

        -f:force,强制删除

        -i:交互式

 rm命令:remove,删除文件,还可以删除目录

        -i:interacive

        -f:force,强制删除

        -r:递归删除

        删除目录:rm -rf /PATH/TO/DIR

        危险操作:rm -rf /

 注意:所有不用的文件不要直接删除,而是移动至某个专用目录:(模拟回收站)

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

 bash的基础特性之:命令行展开

   ~:自动展开为用户的家目录,或指定的家目录;

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

       例如:/tmp/{a,b}相当于/tmp/a /tmp/b

tree命令:

  tree [options] [direcrory]

      -L level:指定要显示的层级

bash的基础特性:命令的执行状态结果

  命令执行的状态结果:

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

          成功:0

          失败:1-255

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

  命令正常执行时,有的还会有命令返回值;

      根据命令及其功能不同,结构各不相同;

 

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

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

# mkdir {a,b}_{c,d}

   (2)、创建/tmp/mylinux目录下的:

# mkdir -p /tmp/mylinux1/{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}}

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.文件的元数据信息有哪些,分别表示什么含义,如何查看?如何修改文件的时间戳信息。

  文件:两类数据

        元数据:metadate,用stat查看出来的信息,就是元数据

        数据:data,用cat命令查看出来的信息,称为数据

    

    时间戳:每一个文件都有三个时间戳

    Access: 2016-10-27 20:22:43.389000014 +0800——–atime

    Modify: 2016-10-27 20:22:36.544000003 +0800——–mtime

    Change: 2016-10-27 20:22:42.078000012 +0800——–ctime

    touch命令:改变文件的时间戳,也可以创建空文件(不推荐此方法)

    -c:指定的文件路径不存在时不予创建;

    -a:仅修改access time

    -m:仅修改modify time

    -t STAMP:自定义时间戳

       use [[CC]YY]MMDDhhmm[.ss] instead of current time

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

 命令别名:获取所有可用别名的定义:alias

     定义别名:alias NAME=‘COMMAND’,注意:仅对当前shell进程有效

     撤销别名:unalias NAME

 引用命令的执行结果:

          $(COMMAND)

          或者‘COMMAND’

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

# ls -d /var/l?[[:lower:]]

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

 #ls -d /etc/[0-9]*[^0-9]

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

 #ls -d /etc/[^a-z][a-z]*

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

 #touch "tfile-$(date +%Y-%m-%d-%H-%M-%S)"

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

 #cp -d /etc/p*[^0-9] /tmp/mytest1

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

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

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

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

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

(0)
evergreen1989evergreen1989
上一篇 2016-11-06
下一篇 2016-11-06

相关推荐

  • CentOS软RAID实现配置

     实现软raid1、fdisk t fd //修改磁盘分区类型fd2、创建raid设备     创建一个RAID5,5块儿硬盘4块做RAID,1块儿做空闲硬盘(顶替硬盘使用)    mdadm -C /dev/md0 -a yes -l 5  -n …

    Linux干货 2016-08-30
  • DNS

    DNS DNS解析 DNS名称解析方式:名称 –> IP:正向解析IP –> 名称:反向解析注意:二者的名称空间,非为同一个空间,即非为同一棵树;因此,也不是同一个解析库; DNS查询类型:递归查询:一般是客户机和服务器之间的查询;即只发送一个请求,其他的工作交由上层服务器去解决;迭代查询:一般是服务器和服务器之间的凡是,…

    Linux干货 2017-05-31
  • iptables的使用

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

    Linux干货 2016-10-29
  • DNS实验

    本实验需的注意问题:      1、运营商的服务器需要更改根指向服务器地址      2、根服务器上的配置文件/etc/named.conf需要将"."根区域禁用;      3、更改区域数据库文件的属组为named;c…

    Linux干货 2016-12-12
  • Centos6上安装cobbler及cobbler常见参数详解

    前言 Cobbler是一个自动化和简化系统安装的工具,通过使用网络引导来控制和启动安装。Cobbler的特性包括存储库镜像、Kickstart模板和连接电源管理系统。使用Cobbler之前需要先了解下PXE和Kickstart的基本原理,文章包含了Cobbler工作原理和Cobbler部署实践两部分内容,交叉关联性的内容还是蛮多的,遇到报错也不要怕,都会一步…

    Linux干货 2016-11-11
  • sed和awk的用例及pam安全措施-第十五周

    总结sed和awk的详细用法; sed用法 sed(Stream EDitor)是一款流编辑器,用来对文本进行过滤与替换操作。其原理是:通过文件或管道读取文件内容,但是sed默认并不直接修改源文件,而是一次仅读取文件的一行至模式空间(pattern space)根据sed指令进行编辑并输出结果后清除模式空间,即所有的操作都是在模式空间中进行的。 语法格式 s…

    2017-06-05

评论列表(1条)

  • 马哥教育
    马哥教育 2016-11-10 18:57

    总结的不错,赞~~可以多想几种方法来实现~继续加油~