n25第二周

  • linux文件管理类命令

    mkdir,rmdir,cp,mv,rm,chwon,chmod

    1.mkdir->make directories(创建目录)

    用法:

    mkdir [OPTION]… DIRECTORY…
    -p: 自动按需创建父目录;
    -v: verbose,显示详细过程;
    -m MODE:直接给定权限;

    注意:路径基名方为命令的作用对象;基名之前的路径必须得存在;

    例子:

    — stu]#mkdir -pv  stu/{t1,t2}->创建及显示过程
    mkdir: 已创建目录 "stu"
    mkdir: 已创建目录 "stu/t1"
    mkdir: 已创建目录 "stu/t2"

    —stu]#mkdir -m 444 stu2->给权限

    stu]#ll -d stu2
    dr–r–r–. 2 root root 6 12月 11 10:56 stu2

    2.rmdir-》删除目录

    rmdir [OPTION]… DIRECTORY…

    -p:删除某目录后,如果其父目录为空,则一并删除之;

    -v: 显示过程;

    

    ~]# rmdir -pv test1/{t1,t2}

    rmdir: 正在删除目录 "test1/t1"

    rmdir: 正在删除目录 "test1"

    rmdir: 删除目录 "test1" 失败: 目录非空

    rmdir: 正在删除目录 "test1/t2"

    rmdir: 正在删除目录 "test1"

    3.cp->copy

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

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

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

    -r, -R:递归复制目录;

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

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

    –preserv=

        mode:权限

        ownership:属主和属组

        imestamps: 时间戳

        context:安全标签

        xattr:扩展属性

        links:符号链接

        all:上述所有属性

    

    test]# cp h1.txt  h1-2.txt

    ps:

    如果DEST不存在:错误;

如果DEST存在:

    如果DEST是非目录文件:错误;

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

    多源复制:

    cp [OPTION]… SOURCE… DIRECTORY

    cp [OPTION]… -t DIRECTORY SOURCE…

    test]# cp {h1.txt,h1-2.txt} hhh

    cp: 目标"hhh" 不是目录

    ps:

    如果DEST不存在:错误;

    如果DEST存在:

        如果DEST是非目录文件:错误;

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

    4.mv->move

    mv [OPTION]… [-T] SOURCE DEST

    mv [OPTION]… SOURCE… DIRECTORY

    mv [OPTION]… -t DIRECTORY SOURCE..

    常用选项:

    -i:交互式;

    -f:force

    ps:与cp命令差不多,但此命令会删除源文件

    5.rm->删除文件remove  

    rm [OPTION]… FILE…

    常用选项:

        -i:interactive

        -f:force

        -r: recursive

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

    test]# rm -r hhh

    rm:是否进入目录"hhh"? y

    rm:是否删除普通文件 "hhh/h1.txt"?y

    rm:是否删除普通文件 "hhh/h1-2.txt"?y

    rm:是否删除目录 "hhh"?y

    危险操作:rm -rf /*

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

    6.chwon

    chmod命令:

    chmod [OPTION]… MODE[,MODE]… FILE…

    chmod [OPTION]… OCTAL-MODE FILE…

    chmod [OPTION]… –reference=RFILE FILE…

    -R, –recursive:递归修改      

    test]# chmod u+x h1.txt

    test]# chmod 775 h1.txt

    注意:用户仅能修改属主为自己的那些文件的权限;

    7.chwon-

    chown [OPTION]… [OWNER][:[GROUP]] FILE…

    -R:递归修改

    test]# chown meil:liao a_c

    drwxr-xr-x. 2 meil liao    6 12月  9 23:42 a_c

    test]# chown liao.meil a_c

    drwxr-xr-x. 2 liao meil    6 12月  9 23:42 a_c

    test]$ chown meil.liao a_c

    [liao@localhost test]$ chown meil.liao a_c

    注意:仅管理员可修改文件的属主和属组;

  • bash 的命令返回值及其命令行展开所涉及的内容

    命令执行的状态结果:

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

成功:0

失败:1-255

    例

    test]$ ll

    test]$ echo $?

    0

    test]$ ly /etc

    bash: ly: 未找到命令

    test]$ echo $?

    127

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

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

    引用命令的执行结果:

        $(COMMAND)

        或`COMMAND`

    例

    test]# mkdir $(date +"%Y%m%d")

    drwxr-xr-x. 2 root root    6 12月 11 15:17 20161211

  • 命令行展开功能

    1.创建/tmp目录下的:a_c,a_d,b_c,b_d

    

    /]# tree tmp

    tmp

    ├── a_c

    ├── a_d

    ├── b_c

    ├── b_d

    2.创建/tmp/mylinux目录下的多文件

    mylinux]# mkdir -pv {bin,boot,boot/grub,dev,etc,

    etc/{rc.d/init.d,sysconfig/network-scripts},lib,lib/modules,lib64,proc,sbin,sys,tmp

    ,usr,usr/local/{bin,sbin},var,var/{lock,log,run}}

    tree ../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

    24 directories, 0 files

  • 文件的元数据信息有哪些,分别是什么含义,如何查看,如何修改时间戳

    tmp]# stat mylinux/

    文件:"mylinux/"

    大小:4096       块:8          IO 块:4096   目录

    设备:fd00h/64768d Inode:361         硬链接:14

    权限:(0755/drwxr-xr-x)  Uid:(    0/    root)   Gid:(    0/    root)

    环境:unconfined_u:object_r:user_tmp_t:s0

    最近访问:2016-12-11 15:43:58.777688397 +0800

    最近更改:2016-12-11 15:43:50.110688550 +0800

    最近改动:2016-12-11 15:43:50.110688550 +0800

    stat 命令的修改符 -f 显示了有关文件系统(而非文件)的信息:

    tmp]# stat -f mylinux/

    文件:"mylinux/"

    ID:fd0000000000 文件名长度:255     类型:xfs

    块大小:4096       基本块大小:4096

    块:总计:13100800   空闲:12858455   可用:12858455

    Inodes: 总计:52428800   空闲:52404757

    tmp]# stat -t mylinux/

    mylinux/ 4096 8 41ed 0 0 fd00 361 14 0 0 1481442238 1481442230 1481442230 0 4096     unconfined_u:object_r:user_tmp_t:s0

    修改文件时间戳touch

            touch – change file timestamps

    touch [OPTION]… FILE…

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

    -a: 仅修改access time;

    -m:仅修改modify time;

    -t STAMP

    [[CC]YY]MMDDhhmm[.ss]

            etc]# touch -a 9yyyy/

            etc]# touch -m 9yyyy/

            etc]# touch -t 1512051840.35 9yyyy/

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

    tmp]# alias mk=mkdir

    tmp]# mk $(date +"%Y%m%d")

  • 显示/var目录下 l开头,小写字母结尾,中间最少出现一位数字的文件

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

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

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

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

        # ls -d /etc/[^[:alpha:]][[:alpha:]]* 

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

        # touch /tmp/tfile-$(date "+%F-%H-%M-%S")

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

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

   # mkdir /tmp/mytest1
   # cp -r /etc/p[^[:digit:]] /tmp/mytest1

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

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

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

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

    

    

    

    

    

    

    

    

    

    

    

    

    

    

    

    

    

 

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

(0)
lllstylllsty
上一篇 2016-12-11
下一篇 2016-12-11

相关推荐

  • Linux基础之文件查找压缩

    为何学习本章节,可以设想一下,在未来工作中面对大量用户时,想要找到同一类型属性的用户文件时,需要一个工具可以快速准确的定位到所寻找的文件,那就是locate和find。   ******************************************************* 重点:     1.德摩根定律     非(P且Q) = (非P…

    2016-08-22
  • 马哥教育网络班22期+第1周课程练习

    1.描述计算机的组成及其功能。    组成:CPU (运算器+控制器),存诸器(内存与硬盘),输入设备,输出设备。    运算器:对数据进行加工处理的部件(包括算述运算与逻辑运算)。    控制器:负责从存储器取出指令,按指令的要求发出控制信号,使各部件协调的,一步步的完成各种操作。   …

    Linux干货 2016-08-22
  • net25 第15周作业

    1、总结sed和awk的详细用法; SED sed模式空间 默认不编辑源文件,仅对模式空间中的数据做处理:而后,处理结束后,将模式空间打印屏幕 sed [options]’address+command’ file… -n:静默模式,不再默认显示模式空间的内容 -i:直接修改原文件 -e script -e script 同时执行多个脚本 -f /pat…

    Linux干货 2017-05-15
  • ansible基础应用

    ansible基础 一、运维主要工作 ansible聚集以上功能于一身,能够完整轻易的实现应用部署和批量命令功能,适用于主机数量不太多,再大的用puppet。 二、ansible特性 (1)模块化:调用特定的模块,完成特定任务; (2)基于python语言实现,由paramiko,PYYAML和JINJa2三个关键模块组成 (3)部署简单:agentless…

    Linux干货 2017-01-04
  • 博客作业网络班22期+第4周(8.29-9.4)

    1、复制/etc/skel目录为/home/tuser1,要求/home/tuser1及其内部文件的属组和其它用户均没有任何访问权限。 #  ls /home/tuser1 || mkdir /home/tuser1 && cp -R /etc/skel/*  /home/tuser1 && ch…

    Linux干货 2016-09-07
  • 26期全程班-第三周博客作业

    1、列出当前系统上所有已经登录的用户的用户名,注意:同一个用户登录多次,则只显示一次即可。     # who | cut -d” ” -f 1 | sort -u   2、取出最后登录到当前系统的用户的相关信息。     # id `last …

    Linux干货 2017-02-18