学以致用

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

cp – copy files and directories

复制文件或目录

使用格式:

单文件复制

cp [OPTION]… [-T] SOURCE DEST

如果DEST不存在,即创建文件并复制源文件数据流;

如果DEST存在,且为非目录文件时,将覆盖目标文件;如果为目录文件时,将在此目录下创建一个同名的新文件。

多文件复制

cp [OPTION]… SOURCE… DIRECTORY

cp [OPTION]… -t DIRECTORY SOURCE…

如果DIRE不存在,将报错,提示:cannot create regular file ‘root/’: Not a directory;

如果DIRE存在,复制到目标目录内,保持原名。

常用选项:

      -a,–archive :same as -dr –preserve=all,常用于文档归档、备份

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

      -f,–force:如果目标文件存在,强制覆盖目标文件

      -i,–interactive:覆盖前提示

      -l,–link:硬链接文件代替复制

      -r,-R,–recursive:递归,复制目录及其子文件和目录

      –preserve[=ATTR_LIST]:保留被复制文件的:mode权限,ownership从属关系,timestamps时间戳,context安全上下文,links链接关系,all所有

      –parents: use full source file name under DIRECTORY

e.g:

[root@yyy tmp Wed Oct 12 22:17]# cp /root/Zhahaha /tmp/

[root@yyy tmp Wed Oct 12 22:31]# ll /tmp/Zhahaha

-rwxr-xr–. 1 root root 0 Oct 12 22:31 /tmp/Zhahaha

 

mv – move (rename) files 移动(重命名)文件

使用格式:

      mv [OPTION]… [-T] SOURCE DEST

mv [OPTION]… SOURCE… DIRECTORY

mv [OPTION]… -t DIRECTORY SOURCE…

常用选项:

      -f,–force:覆盖前不提示

      -i,–interactive:覆盖前提示

e.g:

重命名:

[root@yyy tmp Wed Oct 12 22:31]# ll /tmp/Zhahaha

-rwxr-xr–. 1 root root 0 Oct 12 22:31 /tmp/Zhahaha

[root@yyy tmp Wed Oct 12 22:31]# mv Zhahaha Yhahaha

[root@yyy tmp Wed Oct 12 22:32]# ll /tmp/Yhahaha

-rwxr-xr–. 1 root root 0 Oct 12 22:31 /tmp/Yhahaha

移动文件:

[root@yyy tmp Wed Oct 12 22:32]# ll /root/a.out

-rwxr-xr-x. 1 root root 8511 Sep  6 01:00 /root/a.out

[root@yyy tmp Wed Oct 12 22:33]# mv /root/a.out /tmp/

[root@yyy tmp Wed Oct 12 22:33]# ll /root/a.out

ls: cannot access /root/a.out: No such file or directory

[root@yyy tmp Wed Oct 12 22:33]# ll /tmp/a.out

-rwxr-xr-x. 1 root root 8511 Sep  6 01:00 /tmp/a.out

 

rm – remove files or directories 删除文件或目录

使用格式:

rm [OPTION]… FILE…

常用选项:

      -i,–interactive:删除前提示prompt

      -f,–force:强制删除不提示

      -r,-R,-recursive:递归删除,用于删除目录(rmdir只能删除空目录,非空不能删除)

e.g:

      [root@yyy tmp Wed Oct 12 22:34]# rm a.out

rm: remove regular file ‘a.out’? y

[root@yyy tmp Wed Oct 12 22:38]# ll /tmp/a.out

ls: cannot access /tmp/a.out: No such file or directory


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

执行状态返回值:

每一条命令在执行完成后,不论成功失败,都会有0-255中的1个数值来表示执行结果,这个值将保存在shell的内置变量"?"中.但是,只能保存最近一次执行命令的返回值.

其返回值主要分两类:

成功,则返回0

失败,则返回非0(1-255)

获取执行状态返回值:

#echo $?

命令行展开用法

~ 自动展开为用户家目录

e.g:

[root@yyy tmp Wed Oct 12 23:03]# cd ~

[root@yyy ~ Wed Oct 12 23:05]#

{} 可承载以逗号分割的路径列表,并能够展开为多个路径

e.g:

创建/tmp/y1,/tmp/y2,/tmp/y1/a,/tmp/y1/b目录

[root@yyy tmp Wed Oct 12 23:08]# mkdir -pv /tmp/{y1/{a,b},y2}

mkdir: created directory ‘/tmp/y1’

mkdir: created directory ‘/tmp/y1/a’

mkdir: created directory ‘/tmp/y1/b’

mkdir: created directory ‘/tmp/y2’
3、请使用命令行展开功能来完成以下练习:
   (1)、创建/tmp目录下的:a_c, a_d, b_c, b_d

[root@yyy tmp Wed Oct 12 23:08]# mkdir -v {a,b}_{c,d}

mkdir: created directory ‘a_c’

mkdir: created directory ‘a_d’

mkdir: created directory ‘b_c’

mkdir: created directory ‘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@yyy tmp Wed Oct 12 23:15]# mkdir -pv /tmp/mylinux/{bin,boot/grup,dev,etc/{ec.d/init.d,sysconfig/network-script},lib/modules,lib64,proc,sbin,sys,tmp,usr/local/{bin,sbin},var/{lock,log,run}}

mkdir: created directory ‘/tmp/mylinux’

mkdir: created directory ‘/tmp/mylinux/bin’

mkdir: created directory ‘/tmp/mylinux/boot’

mkdir: created directory ‘/tmp/mylinux/boot/grup’

mkdir: created directory ‘/tmp/mylinux/dev’

mkdir: created directory ‘/tmp/mylinux/etc’

mkdir: created directory ‘/tmp/mylinux/etc/ec.d’

mkdir: created directory ‘/tmp/mylinux/etc/ec.d/init.d’

mkdir: created directory ‘/tmp/mylinux/etc/sysconfig’

mkdir: created directory ‘/tmp/mylinux/etc/sysconfig/network-script’

mkdir: created directory ‘/tmp/mylinux/lib’

mkdir: created directory ‘/tmp/mylinux/lib/modules’

mkdir: created directory ‘/tmp/mylinux/lib64’

mkdir: created directory ‘/tmp/mylinux/proc’

mkdir: created directory ‘/tmp/mylinux/sbin’

mkdir: created directory ‘/tmp/mylinux/sys’

mkdir: created directory ‘/tmp/mylinux/tmp’

mkdir: created directory ‘/tmp/mylinux/usr’

mkdir: created directory ‘/tmp/mylinux/usr/local’

mkdir: created directory ‘/tmp/mylinux/usr/local/bin’

mkdir: created directory ‘/tmp/mylinux/usr/local/sbin’

mkdir: created directory ‘/tmp/mylinux/var’

mkdir: created directory ‘/tmp/mylinux/var/lock’

mkdir: created directory ‘/tmp/mylinux/var/log’

mkdir: created directory ‘/tmp/mylinux/var/run’

[root@yyy tmp Wed Oct 12 23:16]# tree mylinux/

mylinux/

├── bin

├── boot

│   └── grup

├── dev

├── etc

│   ├── ec.d

│   │   └── init.d

│   └── sysconfig

│       └── network-script

├── lib

│   └── modules

├── lib64

├── proc

├── sbin

├── sys

├── tmp

├── usr

│   └── local

│       ├── bin

│       └── sbin

└── var

    ├── lock

    ├── log

    └── run

 

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

文件的两类数据:

数据:data(文件正文内容)

元数据:metadata,主要有:

文件属性,

文件大小:size

块:所占blocks数

文件类型:常规文件、执行程序、目录等等

inode:存放在分区上的那个节点

links:链接到该文件的硬链接数目

权限:用户、组、其他用户对此文件的操作权限

uid:文件所属者

属组:文件所属组

安全上下文:有点类似文件系统的rwx,主体(subject,进程)与目标(object,文件系统)的安全上下文必须保持一致。

时间戳:atime 最近一次访问时间 mtime 最近一次修改时间 ctime最近一次改变时间(指文件属性改变)

 

查看命令介绍:stat

stat – display file or file system status 显示文件或文件系统的状态

[root@yyy tmp Wed Oct 12 23:21]# stat yyy

  File: ‘yyy’

  Size: 88         Blocks: 0          IO Block: 4096   directory

Device: fd00h/64768d Inode: 37203114    Links: 7

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

Context: unconfined_u:object_r:user_tmp_t:s0

Access: 2016-10-12 22:10:30.146038308 +0800

Modify: 2016-10-12 22:10:22.292075536 +0800

Change: 2016-10-12 22:10:22.292075536 +0800

 Birth: –

 

修改文件时间戳方法介绍:

使用touch命令可对文件时间戳进行修改:

touch – change file timestamps 改变文件的时间戳

使用格式:

touch [OPTION]… FILE…

常用选项:

-c,–no-create 不创建任何文件

-m 仅改变文件的修改时间

-a 仅改变文件的访问时间

-t STAMP 可使用[[CC]YY]MMDDhhmm[.ss]代替通用时间,e.g:

      -t 201508080808.08


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

命令别名主要命令:alias

Define or display aliases.定义或者取消别名

使用格式:

alias [-p] [name[=value] … ]

使用方法:

查看系统已有别名设置:

[root@yyy ~ Wed Oct 12 23:43]# alias

alias cp='cp -i'

alias egrep='egrep –color=auto'

alias fgrep='fgrep –color=auto'

定义命令别名:

alias name="value"

[root@yyy ~ Wed Oct 12 23:45]# alias lh="ls -l -h"

[root@yyy ~ Wed Oct 12 23:46]# alias

alias cp='cp -i'

alias lh='ls -l -h'

[root@yyy ~ Wed Oct 12 23:46]# lh

-rw-r–r–. 1 root    root  7.6M Sep  1 23:10 abc.zip

-rw——-. 1 root    root  1.2K May 29 22:54 anaconda-ks.cfg

-rw-r–r–. 1 root    root  137K Oct 12 23:46 crontabtest

取消别名定义:

unalias name

[root@yyy ~ Wed Oct 12 23:47]# unalias lh

[root@yyy ~ Wed Oct 12 23:49]# lh

bash: lh: command not found…

 

注意:使用命令定义命令别名仅在当前shell进程中有效,退出shell进程后失去效果,如需永久生效,可根据情况在/etc/profile,/etc/profile.d/以及~/.bash_profile里进行添加即可。


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

(一)

[root@yyy tmp Thu Oct 13 00:13]# ll -d /var/l*[0-9]*[a-z]

drwxr-xr-x. 2 root root 6 Oct 13 00:13 /var/lee34ff

-rw-r–r–. 1 root root 0 Oct 13 00:13 /var/ljsj7hhh

(二)

 [root@yyy tmp Wed Oct 12 23:55]# ls -R /var | grep -E '^l.*[[:digit:]].*[[:lower:]]$'

lee34ff

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

(一)

[root@yyy tmp Thu Oct 13 00:22]# ll -d /etc/[0-9]*[^0-9]

drwxr-xr-x. 2 root root 6 Oct 13 00:15 /etc/9aaaaaaaaaaaaa

(二)

 [root@yyy tmp Thu Oct 13 00:03]# ls -R /etc/ | grep -E "^[[:digit:]].*[^[:digit:]]$"

9aaaaaaaaaaaaaaaaaaaaaa

0hourly

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

(一)

[root@yyy tmp Thu Oct 13 00:22]# ll -d /etc/[^a-zA-Z][a-zA-Z]*

drwxr-xr-x. 2 root root 6 Oct 13 00:15 /etc/9aaaaaaaaaaaaa

(二)

[root@yyy tmp Wed Oct 12 23:58]# ls -R /etc | grep -E "^[[:digit:]][[:alpha:]].*"

0hourly

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

[root@yyy tmp Thu Oct 13 00:04]# touch /tmp/tfile-`date +%Y-%m-%d-%H-%M-%S`
10
、复制/etc目录下所有以p开头,以非数字结尾的文件或目录到/tmp/mytest1目录中。

[root@yyy tmp Thu Oct 13 00:25]# cp -r /etc/p*[^0-9] /tmp/mytest1/

[root@yyy tmp Thu Oct 13 00:27]# ls /tmp/mytest1/

pam.d   passwd-       php.d    pinforc  plymouth  pnm2ppa.conf  postfix  prelink.conf.d  profile    protocols  purple

passwd  pbm2ppa.conf  php.ini  pki      pm        popt.d        ppp      printcap        profile.d  pulse

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

[root@yyy tmp Thu Oct 13 00:26]# cp -r /etc/*.d /tmp/mytest2/

[root@yyy tmp Thu Oct 13 00:26]# ls /tmp/mytest2

bash_completion.d  dnsmasq.d      init.d        modprobe.d      php.d           rc1.d  rc6.d          sane.d       tmpfiles.d

binfmt.d           dracut.conf.d  ipsec.d       modules-load.d  popt.d          rc2.d  rc.d           setuptool.d  usb_modeswitch.d

chkconfig.d        exports.d      ld.so.conf.d  my.cnf.d        prelink.conf.d  rc3.d  request-key.d  statetab.d   xinetd.d

cron.d             gdbinit.d      libibverbs.d  oddjobd.conf.d  profile.d       rc4.d  rsyslog.d      sudoers.d    yum.repos.d

depmod.d           grub.d         logrotate.d   pam.d           rc0.d           rc5.d  rwtab.d        sysctl.d
12、复制/etc/目录下所有以l或m或n开头,以.conf结尾的文件至/tmp/mytest3目录中。

[root@yyy tmp Thu Oct 13 00:28]# cp /etc/{l,m,n}*.conf /tmp/mytest3/

[root@yyy tmp Thu Oct 13 00:29]# ls /tmp/mytest3/

ld.so.conf     libuser.conf  logrotate.conf  mke2fs.conf  nfsmount.conf  numad.conf

libaudit.conf  locale.conf   man_db.conf     mtools.conf  nsswitch.conf

 

原创文章,作者:成都-yyy,如若转载,请注明出处:http://www.178linux.com/50956

(0)
成都-yyy成都-yyy
上一篇 2016-10-12
下一篇 2016-10-13

相关推荐

  • linux 网络管理

    1、ifconfig命令格式: ifconfig[interface] 查看IP ifconfig-a 查看全部网卡信息 ifconfigIFACE [up|down] 网卡开启关闭 ifconfigIFACE IP/netmask [up] ifconfigIFACE IP netmask NETMASK 命令立即生效,不能永久保存  &nbsp…

    Linux干货 2017-08-20
  • 加密·解密·PKI详解及如何创建私有CA

    加密解密技术基础: 安全的目标:   保密性:confidentiality 确保通信信息不被任何无关的人看到 完整性:integrity 实现通信双方的报文不会产生信息丢失 数据完整性 系统完整性 可用性:availability 通信任何一方产生的信息应当对授权实体可用 攻击类型:   威胁保密性的攻击:窃听、通信…

    2017-05-30
  • 五.Linux博客-2016年7月28日索引、硬链接、软连接、inode表、file、重定向、tr、管道、用户、组

    格式说明: 操作 概念 命令 说明及举例 五.索引、硬链接、软连接、inode表、file、重定向、tr、管道、用户、组 索引节点 原数据保存在inode table表中每个文件或目录都有一个独立的inode number(节点编号在一个分区中是唯一的,每个分区都有自己的inode table) ls -i 查看节点编号 硬链接 ln&n…

    Linux干货 2016-08-23
  • 关于文件查找和解压缩

                     文件查找和解压缩在文件系统上查找符合条件的文件,文件查找的工具有两个,locate 和find文件查找分为:          &nbs…

    系统运维 2016-08-18
  • LVS负载均衡实战演练

    LVS负载均衡实战之lvs-nat模型 1.准备好机器,配置好时间同步,配置号网络,主机名 172.16.251.91 client [桥接] [网关为172.16.251.90] #lvs负载均衡两块网卡 172.16.251.90  lvs [网卡1] [桥接] 192.168.42.150  lvs [网卡2] [VMnet8] 192.168.42.…

    Linux干货 2017-06-22
  • 系统启动及内核管理

    一、知识整理 1、nohup 命令:不挂断地运行命令,远程连接当断网或断开shell时还可以继续运行。无论是否将nohup命令的输出重定向到终端,输出都将附加到当前目录下的nohup.out文件中,如果当前不可写,则重定向到家目录nohup.out文件,除非定义了输出文件。 nohup COMMAND 输出重定向至文件 nohup COMMAND &…

    Linux干货 2016-09-19