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

相关推荐

  • 第八周作业脚本练习

    1、写一个脚本,使用ping命令探测172.16.250.1-172.16.250.254之间的所有主机的在线状态;      在线的主机使用绿色显示;      不在线的主使用红色显示;          &…

    Linux干货 2017-02-01
  • 【Linux基础】文件管理类命令

    总结下linux系统文件管理类的命令 mkdir -> make dirtctories 创建目录 语法:mkdir [OPTION]… DIRECTORY… 常用选项-p: 自动按需创建父目录;-v: verbose,显示详细过程;-m MODE:直接给定权限;注意:路径基名方为命令的作用对象;基名之前的路径必须得存在;示例:~]# mkdir -p…

    Linux干货 2018-03-11
  • 第十周

    请详细描述CentOS的启动流程     启动第一步–加载BIOS         当打开计算机电源,计算机会首先加载BIOS信息,BIOS信息是如此的重要,以至于计算机必须在最开始就找到它,这是因为BIOS中包含了CPU的相关信息、设备启动顺序信息、硬盘信…

    Linux干货 2017-01-03
  • 使用monit搭建一个监控系统

     上周用monit搭建或者说定制了一个监控系统,来监控服务器发生事情。当然了主要是监控异常,因为我们的产品属于服务器类型,很多进程都daemon,要不停的运行。我们搭建监控目的不过是出现问题能够及时的知道,平时可从web UI上看到整个系统的状况,同时它本身要轻量级,不要影响性能。当然了类似的产品很多了,比如Ganglia,我在老科长波哥曾经搭建过…

    Linux干货 2015-02-15
  • N26-第四周作业

    1、复制/etc/skel目录为/home/tuser1,要求/home/tuser1及其内部文件的属组和其它用户均没有任何访问权限。 [root@localhost ~]# cp -rfp /etc/skel/ /home/tuser1[root@localhost ~]# chmod 700 /home/tuser1 2、编辑/etc/group文件,添…

    Linux干货 2017-02-25
  • 常用的MySQL数据库备份

    常用的MySQL数据库备份方式 前言 为什么需要备份数据? 数据的备份类型 MySQL备份数据的方式 备份需要考虑的问题 设计合适的备份策略 实战演练 使用cp进行备份 使用mysqldump+复制BINARY LOG备份 使用lvm2快照备份数据 使用Xtrabackup备份 总结 前言 我们试着想一想, 在生产环境中什么最重要?如果我们服务器的硬件坏了可…

    2016-10-01

评论列表(1条)

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

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