文件管理命令以及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
下一篇 2017-08-13

相关推荐

  • 20160802课堂作业

    作业: 在/data/testdir里创建的新文件自动属于g1组,组g2的成员如:alice能对这些新文件有读写权限,组g3的成员如:tom只能对新文件有读权限,其它用户(不属于g1,g2,g3)不能访问这个文件夹。 #groupadd g1 #groupadd g2 #groupadd g3 #useradd -G g2 alice #useradd -G…

    Linux干货 2016-08-04
  • 第十一周

    1、详细描述一次加密通讯的过程,结合图示最佳。 2、描述创建私有CA的过程,以及为客户端发来的证书请求进行办法证书。 CA 服务器端: (1)生成 CA 服务器的私钥 (umask 077; openssl genrsa -out /etc/pki/CA/private/cakey.pem 4096) (2)生成 CA服务器自谦证书 openssl req …

    Linux干货 2017-03-30
  • N22-第十一周作业

    第十一周作业 1、详细描述一次加密通讯的过程,结合图示最佳 (1)为了做到数据的安全,应该同时满足 保密性 完整性 可用性 (2)假设A,B通信,A是客户机,B是服务器 a、客户端向服务器端发送自己支持的加密方式,并且向服务器端请求其CA颁发给的证书 b、服务器选择共同支持的加密方式并发送自己的证书; c、客户端收到其证书,并验证证书,证书必须同时满足以下条…

    Linux干货 2016-12-06
  • HAProxy

    HAProxy简介 HAProxy是免费、极速且可靠的用于为TCP和基于HTTP应用程序提供高可用、负载均衡和代理服务的解决方案,尤其适用于高负载且需要持久连接或7层处理机制的web站点。HAProxy还可以将后端的服务器与网络隔离,起到保护后端服务器的作用。HAProxy的负载均衡能力虽不如LVS,但也是相当不错,而且由于其工作在7层,可以对http请求报…

    2017-05-17
  • 逻辑卷配置管理

    逻辑卷管理逻辑卷创建1、fdisk t 8e //修改分区类型 2、pvcreate  /dev/sd{a7,b} //创建物理卷pvs pvdisplay   //查看物理卷信息 3、vgcreate  vg0  /dev/sd{a7,b}  //创建卷组v…

    Linux干货 2016-08-30
  • LAMP的编译安装

    一、编译安装amp: (1)系统环境:centos6,7 httpd依赖于apr和apr-util appache protable runtime (2)开发环境: Development Tools,Server Platform Development (3)各程序的版本: httpd:2.2,2.4 php:5.x mysql:5.1,5.5,5.6…

    Linux干货 2016-10-17

评论列表(1条)

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

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