2.Linux文件管理类命令

Linux文件管理类命令

  • cp命令:copy 源文件;目标文件;

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

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

    单源复制: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, -R:递归复制目录;
        -d:复制符号链接文件本身,而非其指向的源文件;
        -a:-dR --preserve=all, archive,用于实现归档;
        --preserv=
            mode:权限
            ownership:属主和属组
            timestamps: 时间戳
            context:安全标签
            xattr:扩展属性
            links:符号链接
            all:上述所有属性

    例:
    1)多源复制

    [root@server1 nac]# cp  -r    mod     log     tmp   
                           递归  源文件   源目录  目的目录
  • mv命令:move 
    mv [OPTION]… [-T] SOURCE DEST 
    mv [OPTION]… SOURCE… DIRECTORY 
    mv [OPTION]… -t DIRECTORY SOURCE..

    常用选项:

        -i:交互式;  
        -f:force
  • rm命令:remove rm [OPTION]… FILE…

    常用选项:

        -i:interactive  
        -f:force  
        -r: recursive

    删除目录:rm -rf /PATH/TO/DIR 
    危险操作:rm -rf /*

参数-f是强制删除,使用前要注意防止误删除,建议少用
建议用单独的目录来存放不用的文件,类似Windows的回收站

bash基本特性演示

bash特性之命令行返回值

bash命令执行之后,其状态返回值保存于bash的特殊变量$?中,可以用命令echo $?来查看对应值 返回值分成两类:
成功:0
失败:1-255
不同的返回值代表不同的意义

例:
[root@server1 ~]# cat /varr
cat: /varr: No such file or directory
[root@server1 ~]# echo $?
1
[root@server1 ~]# ls /varr  
ls: cannot access /varr: No such file or directory
[root@server1 ~]# echo $?
2
[root@server1 ~]# 
[root@server1 ~]#    
[root@server1 ~]# ls /var
account  cache  db     games   kerberos  local  log   nis  preserve  spool  yp
adm      crash  empty  gopher  lib       lock   mail  opt  run       tmp
[root@server1 ~]# echo $?
0
[root@server1 ~]#

bash特性之命令行展开

~:自动展开为用户的家目录,或指定的用户的家目录;
{}:可承载一个以逗号分隔的路径列表,并能够将其展开为多个路径;
例如:/tmp/{a,b} 相当于 /tmp/a /tmp/b 
实例可参考“实战测验”内容

文件元数据

元数据(metadata)主要指文件的属性等相关信息,包含权限、大小、时间戳等,通过命令stat看到的信息都是元数据的内容。

  • 元数据内容

    [root@server1 ~]# stat /nac/test
    File: ‘/nac/test’
    Size: 75              Blocks: 0          IO Block: 4096   directory
    Device: fd00h/64768d    Inode: 104016110   Links: 4
    Access: (0755/drwxr-xr-x)  Uid: (    0/    root)   Gid: (    0/    root)
    Context: unconfined_u:object_r:default_t:s0
    Access: 2016-12-10 05:50:24.307412852 -0500
    Modify: 2016-12-10 05:59:28.702810562 -0500
    Change: 2016-12-10 05:59:28.702810562 -0500
    Birth: -
    [root@server1 ~]#
  • 元数据之时间戳:
    Access time:最近访问时间
    Modify time:最近修改(数据)时间
    Change time:最近改动(元数据)时间
    Birth time:创建时间 
    修改元数据时间戳:touch
    touch [OPTION]… FILE…
    -c: 指定的文件路径不存在时不予创建;
    -a: 仅修改access time;
    -m:仅修改modify time;
    -t STAMP    [[CC]YY]MMDDhhmm[.ss]

    例:
    以上图stat /nac/test 的结果为例  
    1)修改access time:  
    [root@server1 ~]# touch -a /nac/test
    [root@server1 ~]# stat /nac/test    
    File: ‘/nac/test’
    Size: 75              Blocks: 0          IO Block: 4096   directory
    Device: fd00h/64768d    Inode: 104016110   Links: 4
    Access: (0755/drwxr-xr-x)  Uid: (    0/    root)   Gid: (    0/    root)
    Context: unconfined_u:object_r:default_t:s0
    Access: 2016-12-10 23:02:44.430190973 -0500
    Modify: 2016-12-10 05:59:28.702810562 -0500
    Change: 2016-12-10 23:02:44.430190973 -0500
    Birth: -
    [root@server1 ~]#   
    2)修改modify time
    [root@server1 ~]# touch -m /nac/test
    [root@server1 ~]# stat /nac/test    
    File: ‘/nac/test’
    Size: 75              Blocks: 0          IO Block: 4096   directory
    Device: fd00h/64768d    Inode: 104016110   Links: 4
    Access: (0755/drwxr-xr-x)  Uid: (    0/    root)   Gid: (    0/    root)
    Context: unconfined_u:object_r:default_t:s0
    Access: 2016-12-10 23:02:44.430190973 -0500
    Modify: 2016-12-10 23:05:04.587246017 -0500
    Change: 2016-12-10 23:05:04.587246017 -0500
    Birth: -
    [root@server1 ~]#   
    3)修改至指定时间  
    [root@server1 ~]# touch -a -t 201512011111.11 /etc/test
    [root@server1 ~]# stat /etc/test
    File: ‘/etc/test’
    Size: 0               Blocks: 0          IO Block: 4096   regular empty file
    Device: fd00h/64768d    Inode: 35731198    Links: 1
    Access: (0644/-rw-r--r--)  Uid: (    0/    root)   Gid: (    0/    root)
    Context: unconfined_u:object_r:etc_t:s0
    Access: 2015-12-01 11:11:11.000000000 -0500
    Modify: 2016-12-10 23:06:47.220821768 -0500
    Change: 2016-12-10 23:06:47.220821768 -0500
    Birth: -
    [root@server1 ~]#

注:access time和modify time一旦改变,change time也会跟着改变;但是change time不可直接修改

命令的别名及引用

  • alias 设置命令别名 获取所有可用别名的定义:
    ~]# alias 定义别名:
    ~]# alias NAME=’COMMAND’

注意:仅对当前shell进程有效
永久保存:/etc/bashrc(全局)、~/.bashrc(个人)文件中保存

撤销别名:
~]# unalias NAME

例:  
1)查看当前的命令别名  
[root@server1 ~]# alias
alias cp='cp -i'
alias egrep='egrep --color=auto'
alias fgrep='fgrep --color=auto'
alias grep='grep --color=auto'
alias l.='ls -d .* --color=auto'
alias ll='ls -l --color=auto'
alias ls='ls --color=auto'
alias mv='mv -i'
alias rm='rm -i'
alias which='alias | /usr/bin/which --tty-only --read-alias --show-dot --show-tilde'
[root@server1 ~]# 
2)设置别名  
[root@server1 ~]# alias Grep='grep -o'
[root@server1 ~]# grep "UUID" /etc/fstab
UUID=c114b923-c522-443a-8a3b-637836838a61 /boot                   xfs     defaults        0 0
[root@server1 ~]# Grep "UUID" /etc/fstab 
UUID
[root@server1 ~]# 
3)取消别名  
[root@server1 ~]# unalias Grep
[root@server1 ~]# 
[root@server1 ~]# Grep "UUID" /etc/fstab
bash: Grep: command not found...
Similar command is: 'grep'
[root@server1 ~]#
  • 命令引用 
    引用指定命令的执行结果:
    $(COMMAND)或`COMMAND` 
    即将$(COMMAND)或`COMMAND` 的执行结果(不是$?代表的状态)作为前一个命令的参数

    例:
    [root@server1 ~]# echo "time is `date`"
    time is Sat Dec 10 23:27:31 EST 2016
    [root@server1 ~]#     
    
    [root@server1 test]# mkdir "$(date)"
    [root@server1 test]# ll
    total 12
    -rw-r--r--. 1 root root 497 Dec 10 01:03 cut.txt
    drwxr-xr-x. 2 root root  50 Dec 10 00:43 diff.test
    -rw-r--r--. 1 root root 465 Dec 10 04:01 fstab.bak
    -rw-r--r--. 1 root root  28 Dec 10 01:59 IO.out
    drwxr-xr-x. 2 root root   6 Dec 10 23:39 Sat Dec 10 23:39:10 EST 2016
    drwxr-xr-x. 2 root root  20 Dec 10 05:50 vim
    [root@server1 test]#

实战测验

1 创建/tmp命令下的ac,ad,bc,b
mkdir /tmp/{a,b}_{c,d}

[root@server1 ~]# mkdir /tmp/{a,b}_{c,d}  
[root@server1 ~]# cd /tmp
[root@server1 tmp]# ll
total 28
drwxr-xr-x.  2 root root         6 Dec 10 08:16 a_c
drwxr-xr-x.  2 root root         6 Dec 10 08:16 a_d
drwxr-xr-x.  2 root root         6 Dec 10 08:16 b_c
drwxr-xr-x.  2 root root         6 Dec 10 08:16 b_d

2 创建/tmp/mylinux目录下的目录
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}}

3 显示/var目录下所有以l开头,以一个小写字母结尾,且中间至少出现一位数字(可以有其他字符)的文件或目录
ls -d /var/l*[0-9]*[[:lower:]]

4 显示/etc目录下,以任意一个数字开头,且以非数字结尾的文件或目录
ls -d /etc/[0-9]*[^0-9]

5 显示/etc目录下,以非字母开头,后面跟了一个字母及其它任意长度任意字符的文件或目录
ls -d /etc/[^[:alpha:]][[:alpha:]]*

6 在/tmp目录下创建以tfile开头,后面跟当前日期和时间的文件,文件名形如:tfile-2016-05-27-09-32-22 
touch /tmp/tfile-$(date +%Y-%m-%d-%H-%M-%S)

7 复制/etc目录下所有以p开头,以非数字结尾的文件或目录到/tmp/mytest1目录中
cp -r /etc/p*[^0-9] /tmp/mytest1

8 复制/etc目录下所有以.d结尾的文件或目录至/tmp/mytest2目录中
cp -r /etc/*.d /tmp/mytest2

9 复制/etc目录下所有以1或m或n开头,以.com结尾的文件至/tmp/mytet3目录中
cp /etc/[1mn]*.com /tmp/mytest3

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

(0)
上一篇 2017-07-09 19:54
下一篇 2017-07-10 08:37

相关推荐

  • 在linux中创建虚拟网卡(网卡别名)的方法

    由于业务需要,要在单个物理网卡上建立多个虚拟网卡,操作如下:cd /etc/sysconfig/network-scripts/   #进入网卡目录cp ifcfg-eth0 ifcfg-eth0:1   # 复制出ifcfg-eth0:1虚拟网卡vim ifcfg-eth0:1    #配置ifcfg-eth0:1虚…

    Linux干货 2016-09-06
  • N26-第二周

    一、文件管理类命令 pwd:显示工作目录 cd:切换目录 cd [dir] cd: 切换回家目录;注意:bash中, ~表示家目录; cd ~:切换回自己的家目录 cd ~USERNAME:切换至指定用户的家目录; cd -:在上一次所在目录与当前目录之间来回切换; 相关的环境变量 $PWD:当前工作目录 $OLDPWD:上一次的工作目录 file:查看文件…

    Linux干货 2017-03-07
  • 从Linux小白到大牛——与狼共舞的日子7

    马哥教育网络班21期+第7周课程练习 1、创建一个10G分区,并格式为ext4文件系统; (1) 要求其block大小为2048, 预留空间百分比为2, 卷标为MYDATA, 默认挂载属性包含acl; (2) 挂载至/data/mydata目录,要求挂载时禁止程序自动运行,且不更新文件的访问时间戳; [root@localhost ~]#&nbsp…

    Linux干货 2016-11-14
  • Nginx+Keepalived实现站点高可用

    Nginx+Keepalived实现站点高可用 vrrp 虚拟路由冗余协议(Virtual Router Redundancy Protocol,简称VRRP)是由IETF提出的解决局域网中配置静态网关出现单点失效现象的路由协议,1998年已推出正式的RFC2338协议标准。VRRP广泛应用在边缘网络中,它的设计目标是支持特定情况下IP数据流量失败转移不会引…

    Linux干货 2016-11-07
  • CentOS Linux解决Device eth0 does not seem to be present

    CentOS Linux解决Device eth0 does not seem to be present 今天早上打开xshell链接虚拟机,突然链接不上。然后进入虚拟机执行 ifconfig 或者 ip addr list 命令发现eth0 不见。然后执行重启网卡命令发现  解决办法:   首先,打开/etc/udev/rules.d/70-p…

    Linux干货 2016-08-02
  • haproxy 实战之haproxy实现httpd负载均衡

    haproxy 实战之haproxy实现httpd负载均衡 实验目的haproxy + httpd实现负载均衡 1.准备机器,做好时间同步,域名主机名解析 192.168.42.151 [node2 haproxy] 192.168.42.152 [node3 httpd] 192.168.42.153 [node4 httpd] 2.node3,node4…

    Linux干货 2017-06-29

评论列表(1条)

  • 马哥教育
    马哥教育 2017-07-13 17:13

    总结的非常好的,下了功夫的,希望您能牢记这些基础知识,加油!!!