N21-第二周博客

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

文件管理命令有复制、删除与移动:cp,mv,rm

cp(复制档案或目录)

[root@study ~]# cp [-adfilprsu] 源(source) 目标(destination)

[root@study ~]# cp [options] source1 source2 source3 …. directory

选项与参数:

-a  :相当于 -dr –preserve=all 的意思,至于 dr 请参考下列说明;(常用)

-d  :若来源文件为链接文件的属性(link file),则复制链接文件属性而非档案本身;

-f  :为强制(force)的意思,若目标档案已经存在且无法开启,则移除后再尝试一次;

-i  :若目标文件(destination)已经存在时,在覆盖时会先询问动作的进行(常用)

-l  :进行硬连结(hard link)的连结档建立,而非复制档案本身;

-p  :连同档案的属性(权限、用户、时间)一起复制过去,而非使用默认属性(备份常用);

-r  :递归持续复制,用于目录的复制行为;(常用)

-s  :复制成为符号链接文件 (symbolic link),亦即『快捷方式』档案;

-u  :destination 比 source 旧才更新 destination,或 destination 不存在的情况下才复制。

–preserve=all :除了 -p 的权限相关参数外,还加入 SELinux 的属性, links, xattr 等也复制了。

最后需要注意的,如果来源档有两个以上,则最后一个目的文件一定要是『目录』才行!

示例1:

[root@localhost ~]# cp install.log /tmp/
[root@localhost ~]# cp -i install.log /tmp/  #加i选项,覆盖前会询问用户
cp: overwrite `/tmp/install.log'? n
#默认alias里会有cp='cp -i',所以平时可以不用敲-i,默认就有

示例2:复制文件,并对比属性

[root@localhost ~]# cd /tmp
[root@localhost tmp]# cp /var/log/wtmp . #注意最后的“点”,代表本目录(/tmp)
[root@localhost tmp]# ll /var/log/wtmp wtmp 
-rw-rw-r--. 1 root utmp 166656 Jul 12 20:18 /var/log/wtmp
-rw-r--r--. 1 root root 166656 Jul 12 20:25 wtmp
#不加任何参数,文件的属性或者权限可能会改变
#如果要保持原样,加-a参数
[root@localhost tmp]# cp -a /var/log/wtmp wtmp2
[root@localhost tmp]# ll /var/log/wtmp wtmp2
-rw-rw-r--. 1 root utmp 166656 Jul 12 20:18 /var/log/wtmp
-rw-rw-r--. 1 root utmp 166656 Jul 12 20:18 wtmp2

示例3:复制/etc整个文件夹到/tmp

[root@localhost tmp]# cp /etc /tmp
cp: omitting directory `/etc'
[root@localhost tmp]# cp -r /etc /tmp

rm(移除文件或文件夹)

[root@study ~]# rm [-fir] 档案或目录

选项与参数:

-f  :就是 force 的意思,忽略不存在的档案,不会出现警告讯息;

-i  :互动模式,在删除前会询问使用者是否动作

-r  :递归删除!最常用在目录的删除!这是非常危险的选项!!

示例1

[root@localhost tmp]# rm -i install.log #加-i选项会询问确定删除?
rm: remove regular file `install.log'? y
#默认alias里会有cp='rm -i',所以平时可以不用敲-i,默认就有

示例2 删除/tmp/etc

[root@localhost tmp]# rm etc目录无法直接删除
rm: cannot remove `etc': Is a directory
[root@localhost tmp]# rm -r etc加上-r选项可以删除,但是会每个文件都询问
rm: descend into directory `etc'? y
rm: remove regular file `etc/system-release-cpe'? y
rm: descend into directory `etc/udev'? y
[root@localhost tmp]# rm -rf etc 加上-rf选项,强制删除

mv(移动文件和文件夹,或者改名)

[root@study ~]# mv [-fiu] source destination

[root@study ~]# mv [options] source1 source2 source3 …. directory

选项与参数:

-f  :force 强制的意思,如果目标文件已经存在,不会询问而直接覆盖;

-i  :若目标文件 (destination) 已经存在时,就会询问是否覆盖!

-u  :若目标文件已经存在,且 source 比较新,才会更新 (update)


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

    使用echo $? 查看命令执行返回值,为0表示执行成功,非0表示执行失败

    示例

[root@localhost tmp]# ls
a_c  a_d  b_c  b_d  vmware-root
[root@localhost tmp]# echo $?
0
[root@localhost tmp]# lll
bash: lll: 未找到命令...
[root@localhost tmp]# echo $?
127

    命令行展开示例

[root@localhost ~]# cd /tmp
[root@localhost tmp]# cd ~#切换到家目录
[root@localhost ~]# pwd
/root
[root@localhost ~]# cd -#切换到上一目录
/tmp
[root@localhost tmp]# cd -#再切换到上一目录
/root

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

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

    [root@localhost ~]# cd /tmp
    [root@localhost tmp]# mkdir {a,b}_{c,d}
   [root@localhost tmp]# ls

    a_c  a_d  b_c  b_d 

   (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

mkdrir -p /tmp/mylinx/{bin,boot/grub,dev,etc/{rc.d/init.d,sysconfig/network-scripts},lib/modules,lib64,proc,sbin,sys,tmp,usr/local/{bin,sbin},var/{local,log,run}}

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

[root@localhost ~]# stat install.log   #查看文件元数据
  File: `install.log'文件名
  Size: 9562 #大小           Blocks: 24         IO Block: 4096   regular file  #文件类型
Device: fd00h/64768d    Inode: 131074      Links: 1 #链接数
Access: (0644/-rw-r--r--) #访问权限 Uid: (    0/    root) #属主  Gid: (    0/    root) #属组
Access: 2016-07-12 20:19:09.589869445 +0800 atime
Modify: 2016-05-15 07:41:01.961999987 +0800mtime
Change: 2016-05-15 07:41:07.976999985 +0800ctime

修改文件时间戳:touch

touch [OPTION]… FILE…

-a: 仅修改atime

-m: 仅修改mtime

-t STAMP:指定时间

[[CC]YY]MMDDhhmm[.ss]

-c: 如果文件不存,则不予创建

示例1:不加任何参数,默认修改所有时间戳为当前时间

[root@localhost ~]# touch install.log
[root@localhost ~]# stat install.log 
  File: `install.log'
  Size: 9562            Blocks: 24         IO Block: 4096   regular file
Device: fd00h/64768d    Inode: 131074      Links: 1
Access: (0644/-rw-r--r--)  Uid: (    0/    root)   Gid: (    0/    root)
Access: 2016-07-12 21:08:23.102867914 +0800
Modify: 2016-07-12 21:08:23.102867914 +0800
Change: 2016-07-12 21:08:23.102867914 +0800

示例2:仅修改atime为当前时间

[root@localhost ~]# touch -a install.log 
[root@localhost ~]# stat install.log    
  File: `install.log'
  Size: 9562            Blocks: 24         IO Block: 4096   regular file
Device: fd00h/64768d    Inode: 131074      Links: 1
Access: (0644/-rw-r--r--)  Uid: (    0/    root)   Gid: (    0/    root)
Access: 2016-07-12 21:10:21.632863145 +0800
Modify: 2016-07-12 21:08:23.102867914 +0800
Change: 2016-07-12 21:10:21.632863145 +0800

示例3:仅修改mtime,并指定时间

[root@localhost ~]# touch -mt 201511222122 install.log  
[root@localhost ~]# stat install.log                  
  File: `install.log'
  Size: 9562            Blocks: 24         IO Block: 4096   regular file
Device: fd00h/64768d    Inode: 131074      Links: 1
Access: (0644/-rw-r--r--)  Uid: (    0/    root)   Gid: (    0/    root)
Access: 2016-07-12 21:13:08.386863979 +0800
Modify: 2015-11-22 21:22:00.000000000 +0800
Change: 2016-07-12 21:13:13.479864909 +0800

以上示例可以总结出:无论修改atime还是mtime,ctime时间戳都会改变,所以touch命令没有修改ctime的选项

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

[root@localhost ~]# alias vi='vim'
直接定义命令别名即可,但是仅在当前会话生效。如果想本用户下次登录还可以使用,编辑~/.bashrc文件添加别名。


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

find /var -name "1*[0-9]?*[[:lower:]]"

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

find /var -name "[0-9]?*[^0-9]"

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

find /var -name "[^[:alpha:]][[:alpha:]]*"

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

touch /tmp/tfile-`date +%Y-%m-%d-%H-%M-%S`

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

cp -r `find /etc -name "p*[^0-9]"` /tmp/mytest1/

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

cp -r `find /etc -name "*\.d"` /tmp/mytest2

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

cp -r `find /etc -name "[l|m|n]*\.conf"` /tmp/mytest3

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

(0)
N21_smileN21_smile
上一篇 2016-07-16
下一篇 2016-07-16

相关推荐

  • Python入门之闭包,匿名函数,过滤器,映射器,折叠

    在学习python函数的过程中,函数的高阶应用包括闭包lambda函数,过滤器等都让我头痛不已.接下来我把课堂中听到的笔记进行整理,再写一遍,希望在提醒自己的同时也能帮助到别人. 首先,我们来看一下什么是闭包,闭包(closure)是函数式编程的重要的语法结构。函数式编程是一种编程范式 (而面向过程编程和面向对象编程也都是编程范式)。在面向过程编程中,我们见…

    Linux干货 2015-12-19
  • CentOS开发环境搭建

        一个月之前将系统换为Linux,昨天系统运行的时候突然死机,开机之后进不了系统,并且BIOS无法识别硬盘,无奈只有在普通硬盘上重装系统。搭建开发环境,为了避免再次遇到类似现象,或在下次遇到这类问题快速搭建开发环境,记录开发环境搭建的过程。 1、启用wifi echo "blacklist&n…

    Linux干货 2016-08-04
  • 马哥教育网络班22期+第三周课程练习

    1、列出当前系统上所有已经登录的用户的用户名,注意:同一个用户登录多次,则只显示一次即可。     [root@zabbix ~]# who|awk '{print $1}'|sort| uniq 2、取出最后登录到当前系统的用户的相关信息。 &nb…

    Linux干货 2016-08-23
  • bash特性及bash脚本编程初步

    bash特性之命令hash 之前我们讲过用户在执行一个命令的时候bash会遍历环境变量$PATH中所有路径来查找执行文件。而命令hash是用来缓存之前用户使用过的命令下次执行的时候直接搜索hash缓存来减少对$PATH变量中路径的遍历次数,从而提高系统运行效率 hash:hash命令     hash:列出 &nbsp…

    Linux干货 2016-12-20
  • 正则表达式之初体验

    学习正则表达式之前,看过这复杂的表达式,犹如天书,无比高大上;怀着战战兢兢的心情,开始了学习之旅: 一、  正则表达式:Global search REgular expression and Print out the line. 我的理解是:通过一大堆符号组成的公式逐行查找文本中匹配的字符串并显示出来  分类: &…

    Linux干货 2015-03-31
  • quota AND raid

    1.磁盘配额 将home目录独立出来单独的分区,限制用户的使用。 (1)先创建分区,如下图的分区sda6 (2)命令同步系统的新增加分区:partx –a /dev/sda (3)命令格式化新分区:     (4)把创建的设备挂载到/mnt/home下    (5)迁移数据,移动之前要确保home分区没有使用。权限是保…

    Linux干货 2016-09-19

评论列表(1条)

  • 马哥教育
    马哥教育 2016-07-17 21:36

    写的很好,排版也很漂亮,最后一个这样写可以吗?加油