学以致用

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)
上一篇 2016-10-12 20:44
下一篇 2016-10-13 11:17

相关推荐

  • 七.Linux博客-2016年8月4日cat、cut、less、head、tail、wc、sort、uniq、grep

    格式说明: 操作 概念 命令 说明及举例 七.cat、cut、less、head、tail、wc、sort、uniq、grep cat cat -A a.txt 查看隐藏内容 cat -n a.txt 显示行号 cat -s a.txt 压缩空行,把多行空行压缩为一行 …

    Linux干货 2016-08-24
  • shell脚本进阶

    一、流程控制 过程式编程语言:顺序执行、选择执行、循环执行 1.1 条件语句 1.1.1 if条件选择语句  选择执行: (注意: if 语句可嵌套) v  单分支:if  判断条件;then           条件为真的分支代…

    Linux干货 2016-11-27
  • 马哥教育网络班22期+第三周课程练习

    1、列出当前系统上所有已经登录的用户的用户名,注意:同一个用户登录多次,则只显示一次即可。     [root@zabbix ~]# who|awk '{print $1}'|sort| uniq 2、取出最后登录到当前系统的用户的相关信息。 &nb…

    Linux干货 2016-08-23
  • selinux介绍

    本章内容 SELinux概念启用SELinux管理文件安全标签管理端口标签管理SELinux布尔值开关管理日志查看SELinux帮助 SELinux介绍 SELinux: Secure Enhanced Linux,是美国国家安全局「NSA=The National Security Agency」和SCC(Secure Computing Corporat…

    Linux干货 2016-09-19
  • VSFTPD+PAM+[基于文件虚拟用户认证 | 基于MYSQL虚拟用户认证]

    VSFTPD+PAM+[基于文件虚拟用户认证 | 基于MYSQL虚拟用户认证] VSFTPD+PAM+[基于文件虚拟用户认证 | 基于MYSQL虚拟用户认证] 一、实验环境 二、实验步骤 1、通过mysql数据库方式虚拟用户认证 1.1数据库配置 1.2FTP配置 1.3测试 2、通过文件方式进行虚拟用户认证 一、实验环境 CentOS 6.7+vsftpd…

    Linux干货 2016-04-18