文件相关命令

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

cpcopy

源文件:目标文件

单源复制: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:递归复制目录

                    如果DEST不存在,创建一个空目录并源目录递归复制过去

                    如果DEST存在:在目标目录下创建同源目录名相同的目录,并将源        目录中的文件递归复制

            -d:复制链接文件本身,不会指向源文件

            -a-dR –preserv=all 拷贝时保留源文件所有属性

            –preserv=

                    mode:权限

                    ownership:属主和属组

                    timestamps:时间戳

                    context:安全标签

                    xattr:扩展属性

                    links:符号链接

                    all:上述所有

mvmove

mv [OPTION]… [-T] SOURCE DEST

                     mv [OPTION]… SOURCE… DIRECTORY

                       mv [OPTION]… -t DIRECTORY SOURCE…

 

rmremove files or directories

             rm [OPTION]… FILE…

                     -iinterctive

                     -r:递归删除,可以删除

                     -rf:强制顺产

 

             

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

命令执行的状态结果:

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

成功:0

失败:1-255

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

[root@edu ~]# ls

anaconda-ks.cfg  initial-setup-ks.cfg  公共  模板  视频  图片  文档  下载  音乐  桌面

[root@edu ~]# echo $?

0

[root@edu ~]# ls /etc/sls

ls: 无法访问/etc/sls: 没有那个文件或目录

[root@edu ~]# echo $?

2

 

 

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

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

命令行展开

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

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

 

 

 

 

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

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

[root@edu /]# mkdir -pv /tmp/{a,b}_{c,d}

mkdir: 已创建目录 "/tmp/a_c"

mkdir: 已创建目录 "/tmp/a_d"

mkdir: 已创建目录 "/tmp/b_c"

mkdir: 已创建目录 "/tmp/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

 

[root@edu /]# 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,rum}}

mkdir: 已创建目录 "/tmp/mylinux"

mkdir: 已创建目录 "/tmp/mylinux/bin"

mkdir: 已创建目录 "/tmp/mylinux/boot"

mkdir: 已创建目录 "/tmp/mylinux/boot/grub"

mkdir: 已创建目录 "/tmp/mylinux/dev"

mkdir: 已创建目录 "/tmp/mylinux/etc"

mkdir: 已创建目录 "/tmp/mylinux/etc/rc.d"

mkdir: 已创建目录 "/tmp/mylinux/etc/rc.d/init.d"

mkdir: 已创建目录 "/tmp/mylinux/etc/sysconfig"

mkdir: 已创建目录 "/tmp/mylinux/etc/sysconfig/network-scripts"

mkdir: 已创建目录 "/tmp/mylinux/lib"

mkdir: 已创建目录 "/tmp/mylinux/lib/modules"

mkdir: 已创建目录 "/tmp/mylinux/lib64"

mkdir: 已创建目录 "/tmp/mylinux/proc"

mkdir: 已创建目录 "/tmp/mylinux/sbin"

mkdir: 已创建目录 "/tmp/mylinux/sys"

mkdir: 已创建目录 "/tmp/mylinux/tmp"

mkdir: 已创建目录 "/tmp/mylinux/usr"

mkdir: 已创建目录 "/tmp/mylinux/usr/local"

mkdir: 已创建目录 "/tmp/mylinux/usr/local/bin"

mkdir: 已创建目录 "/tmp/mylinux/usr/local/sbin"

mkdir: 已创建目录 "/tmp/mylinux/var"

mkdir: 已创建目录 "/tmp/mylinux/var/lock"

mkdir: 已创建目录 "/tmp/mylinux/var/log"

mkdir: 已创建目录 "/tmp/mylinux/var/rum"

[root@edu /]# tree /tmp/mylinux/

/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

    └── rum

 

 

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

元数据用来描述一个文件的属性信息,如访问权限,文件拥有者,文件数据块的分部,文件的时间戳等信息

 

# stat file  使用stat命令查看文件的元数据

 

修改文件的时间戳

touch命令:用于改变atimemtime

touch [option]…file…

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

-a:仅修改 atime

-m:仅修改 mtime

-t:指定修改的时间:[[CC]YY]MMDDhhmm[.ss]

 

 

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

定义别名:

# alias NAME=‘COMMAND’   仅对当前shell进程有效

撤销别名:

# unalias NAME

 

[root@edu ~]# alias cle='clear'

[root@edu ~]# cl

cle                 clear               clibrary2           clockdiff

clean-binary-files  clibrary            clock               clpi_dump

[root@edu ~]# unalias cle

[root@edu ~]# cl

clean-binary-files  clibrary            clock               clpi_dump

clear               clibrary2           clockdiff

 

引用命令的执行结果:

$(COMMAND)

或者`COMMAND`

 touch $(date +%H_%M_%S)

 

[root@edu test]# touch $(date +%H_%M_%S)

[root@edu test]# ls

18_44_55

 

 

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

# ls -d /var/I*[0-9]*[[:lower:]]

 

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

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

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

# ls -d /etc/[^[: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 /etc/p*[^0-9] /tmp/mytest1

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

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

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

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

 

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

(0)
panghlpanghl
上一篇 2016-09-22
下一篇 2016-09-23

相关推荐

  • 用户和组管理的命令

    用户管理概念: 用户类别:         管理员,普通用户,(系统用户和登录用户) 组类别:         管理组员,普通用户组         基本组和附加组         私有组,公共组 数…

    Linux干货 2016-12-21
  • rsyslog+mysql+loganalyzer安装部署

    log:syslog:syslogd,klogd 日志:历史日志 级别: debug info notice warning,warn(same as warning) err,error(same as err) crit alert emerg,panic(same as emerg) facility:设施 auth authpriv cron dae…

    Linux干货 2016-10-24
  • Linux系统发展历史

    一、什么是Linux? Linux是一种自由和开放源代码的类UNIX操作系统。该操作系统的内核由林纳斯·托瓦兹在1991年10月5日首次发布。在加上用户空间的应用程序之后,成为Linux操作系统。Linux也是自由软件和开放源代码软件发展中最著名的例子。只要遵循GNU通用公共许可证,任何个人和机构都可以自由地使用Linux的所有底层源代码,也可以自由地修改和…

    Linux干货 2016-10-14
  • Linux Sysadmin–part3

    1、写一个脚本,判断当前系统上所有用户的shell是否为可登录shell(即用户的shell不是/sbin/nologin);分别这两类用户的个数;通过字符串比较来实现 #!/bin/bash for i in `cut -d’:’ -f7 /etc/passwd`;do if [ $i == “/sbin/nologin…

    2017-09-19
  • 系统基础之文件管理grep练习题

    1、显示/proc/meminfo文件中以大小s开头的行; (要求:使用三种方式) [root@wen-7 ~]# grep -i "^s" /proc/meminfo  SwapCached:       &…

    Linux干货 2016-08-07
  • 基于nginx实现7层http的负载均衡

    一、实验环境实验环境为三台服务器:1. nginx负载均衡器1. 内网ip:192.168.11.1002. 外网ip:172.16.251.892. 提供网页服务的RS-1服务器:192.168.11.2013. 提供网页服务的RS-2服务器:192.168.11.2024. 拓扑如下:二、实验配置后台服务器配置:1. 后台提供网页服务的两台服务器配置:y…

    Linux干货 2017-06-29

评论列表(1条)

  • luoweiro
    luoweiro 2016-10-10 23:06

    开始的部分看着稍有凌乱,后面的作业做的还不错,知识点总结的蛮到位。