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基础学习之进程管理和任务计划

    内容:   进程相关概念(用户空间、内核空间,进程、线程)   进程及系统相关工具(ps、top、pgrep、pidof、kill)   调整nice值(nice、renice)   作业管理(jobs、fg、bg、kill,&)   计划任务(at、crontab) 一、进程相关概念 内核的功用:进…

    Linux干货 2016-09-07
  • KeepAlived高可用集群详解及拓扑实验搭建配置

    Linux Cluster:KeepAlive 1.集群类型:LB(负载均衡集群),HA(高可用集群),HP(高性能集群)     LB:均衡负载的实现LVS     HA:高可用的实现KeepAlived 2.RS:健康状态检测方式: (1)网络层:icmp ping (2)传…

    Linux干货 2016-11-01
  • 磁盘管理

    一、知识整理 1、每个扇区:512字节;每个柱面:256个磁头*63个扇区*512字节,大概为8M。centos6中分区使用起始结束柱面;centos7中分区使用起始结束扇区。EBR:扩展分区的第一个扇区。 2、MBR:master root record,1982年,使用32位表示扇区数,分区不超过2T。其中,一共512bytes字节,446bytes为b…

    Linux干货 2016-08-29
  • 如何在CentOS 6上安装配置Samba

    Samba主要用于windows与Linux之间的文件共享,使用SMB/CIFS协议。CentOS 6默认安装不包括samba软件包,所以需要我们手动进行安装。 Step 1 >> 安装samba [root@localhost ~]# yum install samba -y Step 2 >> 创建一个共享用户名和密码 [root…

    Linux干货 2016-03-22
  • 如何成为一名软件架构师

    Daniel Mohl是一名专业的软件工程师/架构师,他的兴趣包括理解各种复杂的编程语言、企业应用架构以及如何搭建业务与技术,他通晓F#、C#、CoffeeScript、JavaScript、Erlang、ASP.NET、MVC、WPF、WCF、Sliverlight、SQL Server等技术。有着多年的软件开发经验。 他经常会被一些有潜力和有前途的程序员…

    Linux干货 2016-03-22
  • 逻辑卷小结

    逻辑卷 逻辑卷:把不同大小的物理设备,抽象成一个完整的文件系统,方便对物理设备的管理与应用。 其基本步骤为: 1.将指定的设备设置为物理卷     物理卷是指定大小的固定得物理区域 2.用一个或者多个物理卷创建一个卷组 3.创建逻辑卷     在物理卷上创建的逻辑卷由物理区域组成…

    Linux干货 2016-09-01