文件管理命令以及bash特性之命令行展开

一 Linux文件管理

Linux中对文件管理的命令主要有:mkdir rmdir mv rm cp touch file stat等命令

  • 创建目录mkdir

mkdir [OPTION]... DIRECTORY...
[root@MiWiFi-R3-srv testdir]# mkdir /root/dirtest  在/root下创建一个dirtest的目录
常用选项:
    -p 如果父目录不存在同事创建父目录
    -v 显示创建目录的纤细信息
    -m 创建目录时同时设置目录的权限
[root@MiWiFi-R3-srv testdir]# mkdir -vpm 755 /root/dirtest/harry 当父目录不存在先创建父目录再创建子目录并设置权限为755
mkdir: created directory ‘/root/dirtest’ 
mkdir: created directory ‘/root/dirtest/harry’
  • rmdir删除目录

rmdir [OPTION]... DIRECTORY...
[root@MiWiFi-R3-srv testdir]# rmdir /root/dirtest/harry/ 删除一个目录
  • mv移动文件或给文件重命名

mv [OPTION]... [-T] SOURCE DEST
   mv [OPTION]... SOURCE... DIRECTORY
   mv [OPTION]... -t DIRECTORY SOURCE...  
[root@MiWiFi-R3-srv testdir]# mv /etc/fstab /root/  将/etc/fastab移动至/root
[root@MiWiFi-R3-srv testdir]# mv testfile mytestfile 将testfile重命名为mytestfile
  • cp复制文件或目录

cp [OPTION]... [-T] SOURCE DEST
  cp [OPTION]... SOURCE... DIRECTORY
  cp [OPTION]... -t DIRECTORY SOURCE...
 [root@MiWiFi-R3-srv testdir]# cp /etc/passwd /root/ 单源复制将/etc/passwd复制到/root目录下
 [root@MiWiFi-R3-srv testdir]# cp /etc/fstab /etc/profile /root/多源复制将/etc下的fstab和profile复制到root目录下
 常用选项:
    -i 交互复制,复制之前提醒用户
    -f 强制复制目标文件
    -r 递归复制目录,复制目录及目录中的文件
    -d 不复制符号链接的源文件,仅复制符号链接
    -a 保留文件或目录原有属性,进行归档
  • rm删除文件或目录

rm [OPTION]... FILE...
[root@MiWiFi-R3-srv testdir]# rm -rf /root/testdir/ 强制删除该目录以及目录中的内容
常用选项:
       -i 交互式删除
       -r 递归删除
       -f 强制删除

  • stat 显示文件或文件系统状态

[root@MiWiFi-R3-srv ~]# stat abc 显示某文件的大小,块大小访问以及修改时间等
File: ‘abc’
Size: 0     Blocks: 0  IO Block: 4096   regular empty file
Device: fd00h/64768d    Inode: 4186704 Links: 1
    Access: (0644/-rw-r--r--)  Uid: (0/root)   Gid: (0/root)
Context: unconfined_u:object_r:admin_home_t:s0
Access: 2017-08-05 18:40:00.000000000 +0800
Modify: 2017-08-05 18:40:00.000000000 +0800
Change: 2017-08-05 18:47:05.289878820 +0800
  • touch 创建一个空文件或修改某个文件时间戳

touch [OPTION]... FILE...
[root@MiWiFi-R3-srv testdir]# touch /root/abc 创建一个abc的空文件
[root@MiWiFi-R3-srv ~]# touch -a abc 仅修改access时间
[root@MiWiFi-R3-srv ~]# touch -m abc  仅修改文件modify时间
[root@MiWiFi-R3-srv ~]# touch -t 201708051840 abc 修改为指定的时间
  • file显示文件类型

[root@MiWiFi-R3-srv ~]# file /bin/ls 查看某个文件的类型
/bin/ls: ELF 64-bit LSB executable, x86-64, version 1 (SYSV), dynamically linked (uses shared libs), for GNU/Linux 2.6.32, BuildID[sha1]=aa7ff68f13de25936a098016243ce57c3c982e06, stripped

二 Linux的命令状态返回值以及命令行展开

在bash中可通过查看命令状态返回码来判断上一条的命令是否执行成功

  • 成功:0
  • 失败:1-255

[root@MiWiFi-R3-srv ~]# date  输入命令
Sat Aug  5 18:57:01 CST 2017
[root@MiWiFi-R3-srv ~]# echo $? 通过特殊变量查看上一条命令的执行状态返回码
0  代表成功执行
[root@MiWiFi-R3-srv ~]# dater   输入错误命令状态返回码为127
[root@MiWiFi-R3-srv ~]# echo $?
127

bash特性之命令展开

  • ~:自行展开为用户的家目录,或指定用户的家目录
  • {}:可承载一个以逗号分隔的路径列表,并能将其展开为多个路径

练习 1 在/tmp 目录下创建:a_c, a_d. b_c. b_d

[root@MiWiFi-R3-srv ~]# mkdir -v /tmp/{a,b}_{c,d}
mkdir: created directory ‘/tmp/a_c’
mkdir: created directory ‘/tmp/a_d’
mkdir: created directory ‘/tmp/b_c’
mkdir: created directory ‘/tmp/b_d’*

练习2 在/tmp/mylinux目录创建如下结构

[root@MiWiFi-R3-srv ~]# 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/{look,log,run}}
[root@MiWiFi-R3-srv ~]# 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
├── log
├── look
└── run

三 Linux文件的元数据

Linux中文件的元数据包含文件的权限,时间戳,iNode,块大小,硬链接次数所属者以及所属组等等。可通过命令stat查看相信信息

[root@MiWiFi-R3-srv ~]# stat fstab       查看文件的元数据信息
  File: ‘fstab’
  Size: 617     Blocks: 8  IO Block: 4096   regular file
Device: fd00h/64768d    Inode: 4186700 Links: 1
Access: (0700/-rwx------)  Uid: (0/root)   Gid: (0/root)
Context: unconfined_u:object_r:admin_home_t:s0
Access: 2017-08-05 18:29:25.104977052 +0800
Modify: 2017-08-05 18:29:25.104977052 +0800
Change: 2017-08-05 18:29:25.104977052 +0800
[root@MiWiFi-R3-srv ~]# touch fstab  通过touch命令修改文件的时间戳
[root@MiWiFi-R3-srv ~]# touch -a fstab  仅修改access时间
[root@MiWiFi-R3-srv ~]# touch -m fstab  仅修改modify时间

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

(0)
N27_CaiShuangN27_CaiShuang
上一篇 2017-08-13 18:57
下一篇 2017-08-13 21:37

相关推荐

  • OSI七层模型

      OSI模型的七层结构 首先,OSI是什么呢?OSI(Open System Interconnection),OSI是一个开放性的通行系统互连参考模型,是一个协议规范。它把网络协议从逻辑上分为了7层。每一层都有相关、相对应的物理设备。OSI七层模型是一种框架性的设计方法 ,建立七层模型的主要目的是为解决异种网络互连时所遇到的兼容性问题,其最主要…

    2017-09-02
  • Linux 2.6.39-rc3的一个插曲

    2011年4月12日,Linux 2.6.39-rc3发布了,Linus Torvalds写了一个发布邮件,其中包含了一个长长的为这个版本做过贡献的人员名单,这个名单中有很多看上去应该是中国人的名字,我挺为他们感到骄傲的(不知道你是否还记得以前本站的”Linux是由谁写的“)。 不过,没过一会,发现了一个bug,经过大家的调查(2.6.38版没有发现这个问题…

    Linux干货 2016-06-09
  • 基于Keepalived实现LVS双主高可用集群

    前言 前面说过基于heartbeat的LVS高可用方案,今天带来另一种解决方案:基于Keepalived实现LVS双主高可用集群。什么是Keepalived呢,keepalived观其名可知,保持存活,在网络里面就是保持在线了, 也就是所谓的高可用或热备,用来防止单点故障的发生。本文将详细讲述Keepalived工作原理及高可用解决方案的实现。 相关介绍 K…

    Linux干货 2015-06-16
  • grep虐我千百遍,我待grep如初恋

    N21第四周博客作业 1、  复制/etc/skel目录为/home/tuser1,要求/home/tuser1及其内部文件的属组和其它用户均没有任何访问权限。 [root@Centos6 ~]# cp -r /etc/skel /home/tuser1 [root@Centos6 ~]#…

    Linux干货 2016-07-16
  • N25-第九周作业

    第九周 1、写一个脚本,判断当前系统上所有用户的shell是否为可登录shell(即用户的shell不是/sbin/nologin);分别这两类用户的个数;通过字符串比较来实现; #!/bin/bash # sum_login=0 sum_nologin=0 for i in $(awk -F: ‘{print $7}’ /etc/passwd);do if…

    Linux干货 2017-03-10
  • 第四周作业

    1、复制/etc/skel目录为/home/tuser1,要求/home/tuser1及其内部文件的属组和其它用户均没有任何访问权限  cp -r /etc/skel  /home/tuser1   chmod 700 /home/tuser1 2、编辑/etc/gro…

    Linux干货 2016-12-27

评论列表(1条)

  • 马哥教育
    马哥教育 2017-08-20 19:10

    一开始的作业比较简单,但都是比较重要的基础,掌握扎实非常的必要,这次作业完成的非常好,再接再励。