马哥教育网络班22期-第2周博客作业2

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

bash的基础特性:命令的执行状态结果

  命令执行的状态结果:

  bash通过状态返回值来输出此结果:

    成功:0

    失败:1-255

    命令执行完成之后,其状态返回值保存于bash的特殊变量$?中;

    命令正常执行时,有的还会有命令返回值:

    根据命令及其功能不同,结果各不相同;

实例:

[root@zck ~]# echo $SHELL
/bin/bash
[root@zck ~]# echo $?
0
[root@zck ~]# 12name=VBird
bash: 12name=VBird: command not found...   #发生错误
[root@zck ~]# echo $?
127    
#错误代码127,错误代码返回值根据软件而有不同,我们可根据代码来找出错误的原因。
[root@zck ~]# echo $?
0   
#这里返回了正确的值,这是因为“?”只与“上一个执行命令”有关,
#所以,我们上一个命令执行的是“echo $?”,所以返回正确的值0。

3、请使用命令行展开功能来完成以下练习:

   (1)创建/tmp目录下的:a_c、a_d、b_c、b_d

[root@zck ~]# 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目录下的

/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

    ├── lock

    ├── log

    └── run

[root@zck ~]# 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/{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/grub’
mkdir: created directory ‘/tmp/mylinux/dev’
mkdir: created directory ‘/tmp/mylinux/etc’
mkdir: created directory ‘/tmp/mylinux/etc/rc.d’
mkdir: created directory ‘/tmp/mylinux/etc/rc.d/init.d’
mkdir: created directory ‘/tmp/mylinux/etc/sysconfig’
mkdir: created directory ‘/tmp/mylinux/etc/sysconfig/network-scripts’
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@zck ~]# 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
    ├── lock
    ├── log
    └── run
24 directories, 0 files

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

  匹配模式:元字符        

     *:匹配任意长度的任意字符                

        pa*,*pa*,*pa,*p*a*                        

        pa,paa,passwd        

     ?:匹配任意单个字符                

        pa?,??pa,p?a,p?a?                        

        pa,paa,paawd        

     []:匹配指定范围内的任意单个字符                

  有几种特殊格式:                        

     [a-z],[A-Z],[0-9],[a-z0-9]                        

     [[:upper:]]:指定匹配所有大写字母                        

     [[:lower:]]:指定匹配所有小写字母                        

     [[:alpha:]]:匹配所有字母                        

     [[:digit:]]:匹配所有数字                        

     [[:alnum:]]:匹配所有的字母和数字                        

     [[:space:]]:匹配所有空白字符                        

     [[:punct:]]:匹配所有标点符号                        

     pa[0-9][0-9],2[0-9][0-9]        

     [^]:匹配指定范围外的任意单个字符                

     [^[:upper:]]:匹配不是大小的字母                

     [^0-9]:匹配不是数字的字符                

     [^[:alnum:]]:匹配不是字母即不数字的字符

touch 命令

  touch – change file timestamps

  改变文件或目录时间

【SYNOPSIS】

  touch [OPTION]… FILE…

【OPTIONS】

  -a:仅修改access time(时间)        

  -m:仅修改modify time(更改时间);        

  -c:仅修改文件的时间,若该文件不存在则不创建新文件;        

  -t:STAMP,后面可以接需要修改的时间而不用系统当前的时间,格式为[YYMMDDhhmm]或[[CC]YY]MMDDhhmm[.ss]        

  -d:后面可以接需要修改的日期而不用系统当前的日期,也可以使用–date="日期或时间"

【EXAMPLES】

实例1:新建一个空的文件并查看时间

[root@zck test]# touch test1
[root@zck test]# ls -l test1
-rw-r--r--. 1 root root 0 Aug 17 23:28 test1
[root@zck test]# stat test1   #查看文件时间戳信息
  File: ‘test1’
  Size: 0         	Blocks: 0          IO Block: 4096   regular empty file
Device: 803h/2051d	Inode: 72449663    Links: 1
Access: (0644/-rw-r--r--)  Uid: (    0/    root)   Gid: (    0/    root)
Context: unconfined_u:object_r:user_tmp_t:s0
Access: 2016-08-17 23:28:18.678545086 +0800  #访问时间
Modify: 2016-08-17 23:28:18.678545086 +0800  #更改时间
Change: 2016-08-17 23:28:18.678545086 +0800  #改动时间
 Birth: -
#touch创建文件,如果该文件不存在,则会该文件的三个时间(atime、ctime、mtime)都会更新为系统当前时间。

实例2:将~/.bashrc复制成bashrc,-a复制所有属性,查看文件时间戳信息

[root@zck test]# cp -a ~/.bashrc bashrc
[root@zck test]# stat bashrc
  File: ‘bashrc’
  Size: 194       	Blocks: 8          IO Block: 4096   regular file
Device: 803h/2051d	Inode: 72458496    Links: 1
Access: (0644/-rw-r--r--)  Uid: (    0/    root)   Gid: (    0/    root)
Context: system_u:object_r:admin_home_t:s0
Access: 2016-08-17 08:43:14.717066234 +0800   #访问时间
Modify: 2016-08-15 14:38:15.169080971 +0800   #更改时间
Change: 2016-08-17 23:36:50.167559330 +0800   #改动时间

实例3:将bashrc文件日期调整为两天前

[root@zck test]# touch -d "2 days ago" bashrc
[root@zck test]# ll bashrc; ll --time=atime bashrc; ll --time=ctime bashrc
-rw-r--r--. 1 root root 194 Aug 16 09:07 bashrc
-rw-r--r--. 1 root root 194 Aug 16 09:07 bashrc
-rw-r--r--. 1 root root 194 Aug 18 09:07 bashrc
#(atime/mtime)由18日变成了16日,但是ctime并没有跟着改变

实例4:将上实例3的bashrc日期改为 2007/09/15 2:02

[root@zck test]# ll bashrc; ll --time=atime bashrc; ll --time=ctime bashrc
-rw-r--r--. 1 root root 194 Sep 15  2007 bashrc
-rw-r--r--. 1 root root 194 Sep 15  2007 bashrc
-rw-r--r--. 1 root root 194 Aug 18 09:16 bashrc
#(atime/mtime)都改变了,但是ctime则是当前文件修改的时间#

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

5.1 alias 命令

  Define or display aliases

  定义或显示别名

【SYNOPSIS】

  alias  [name[=value] … ]

【OPTIONS】

  -p:列出当前所有的别名设置;

【EXAMPLES】

[root@zck ~]# alias   #显示当前所有的命令别名
alias cls='clear'
alias cp='cp -i'
alias egrep='egrep --color=auto'
alias fgrep='fgrep --color=auto'
alias grep='grep --color=auto'
alias l.='ls -d .* --color=auto'
alias ll='ls -l --color=auto'
alias ls='ls --color=auto'
alias mv='mv -i'
alias rm='rm -i'
alias which='alias | /usr/bin/which --tty-only --read-alias --show-dot --show-tilde'
[root@zck ~]# alias md=mkdir   #将mkdir命令设置别名为md;
[root@zck ~]# alias md
alias md='mkdir'
[root@zck ~]# md dir1
[root@zck ~]# ll -d dir1/
drwxr-xr-x. 2 root root 6 Aug 18 10:07 dir1/
[root@zck ~]# alias dir='ls -al'   #将'ls -al'命令设置别名为dir
[root@zck ~]# dir
总结:在命令行中定义的别名,仅对当前shell进程有效,如果想长久有效,需要在配置文件中添加此别名定义:
~/.bashrc:仅对当前用户有效
/etc/bashrc:对所有用户有效

5.2 如何在命令中引用另一个命令的执行结果?
        引用命令的执行结果:               

                 $(COMMAND)或`COMMAND`

【EXAMPLES】

[root@zck ~]# echo $(date)
Thu Aug 18 10:27:15 CST 2016
[root@zck ~]# echo `date`
Thu Aug 18 10:27:26 CST 2016

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

[root@zck ~]# ls /var | grep '1.*[[:digit:]]\+.*[[:lower:]]$'

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

[root@zck ~]# ls /etc | grep '^[[:digit:]].*[^[:digit:]]$'
3ab23y

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

[root@zck ~]# ls /etc | grep '^[^[:alpha:]][[:alpha:]].*'
3ab23y

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

[root@zck ~]# mkdir /tmp/tfile-`date +%F-%H-%M-%S`
[root@zck ~]# ll -d /tmp/tfile-2016-08-18-11-00-23
drwxr-xr-x. 2 root root 6 Aug 18 11:00 /tmp/tfile-2016-08-18-11-00-23

10、复制/etc目录下,所有以p开头,以非数字结尾的文件或目录至/tmp/mytest1目录中。

[root@zck ~]# mkdir /tmp/mytest1
[root@zck ~]# cp -r /etc/p*[^0-9] /tmp/mytest1
[root@zck ~]# ls /tmp/mytest1
pam.d    pbm2ppa.conf  plymouth      popt.d   prelink.conf.d  profile.d  purple
passwd   pinforc       pm            postfix  printcap        protocols  python
passwd-  pki           pnm2ppa.conf  ppp      profile         pulse

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

[root@zck ~]# mkdir /tmp/mytest2
[root@zck ~]# cp -r /etc/*.d /tmp/mytest2
[root@zck ~]# ls /tmp/mytest2
auto.master.d      dracut.conf.d  logrotate.d     profile.d  rc.d           sysctl.d
bash_completion.d  exports.d      modprobe.d      rc0.d      request-key.d  tmpfiles.d
binfmt.d           gdbinit.d      modules-load.d  rc1.d      rsyslog.d      usb_modeswitch.d
cgconfig.d         grub.d         my.cnf.d        rc2.d      rwtab.d        xinetd.d
chkconfig.d        init.d         oddjobd.conf.d  rc3.d      sane.d         yum.repos.d
cron.d             ipsec.d        pam.d           rc4.d      setuptool.d
depmod.d           ld.so.conf.d   popt.d          rc5.d      statetab.d
dnsmasq.d          libibverbs.d   prelink.conf.d  rc6.d      sudoers.d

12、复制/etc目录下,所有以l或m或n开头,以.conf结尾的文件或目录至/tmp/mytest3目录中。

[root@zck ~]# mkdir /tmp/mytest3
[root@zck ~]# cp /etc/{l,m,n}*.conf /tmp/mytest3
[root@zck ~]# ls /tmp/mytest3
ld.so.conf     libuser.conf  logrotate.conf  mke2fs.conf  nfsmount.conf  ntp.conf
libaudit.conf  locale.conf   man_db.conf     mtools.conf  nsswitch.conf  numad.conf

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

(0)
zhuckeezhuckee
上一篇 2016-08-22
下一篇 2016-08-22

相关推荐

  • 2016/08/07:文本处理工具及正则表达式

      在本次课程中,本以为和前面的内容难度差不多,内心毫无提防,但在做随堂练习的时候,被惨虐,不由得使我想起了高三时候拿到一张数学单元练习题,一道题也不会做的那种感觉,无助,彷徨,不甘。到了晚上总结了一下,还是有缘由可寻的。直接原因就是前面知识记得不牢固,也并未完全理解是和意思,尤其是tr命令,适用于何处,没按照5W1H方法来进行总结学习,导致应用的…

    Linux干货 2016-08-07
  • 学习宣言

            学习计划:每天至少2个小时的学习,循序渐进,先通读再精读。         学习目标:成为运维的高手,走上人生巅峰。      &nb…

    Linux干货 2016-10-25
  • 第三周:文本处理工具wc,cut,sort,uniq,tr,tee命令练习和用户及组相关命令练习

    1、列出当前系统上所有已经登录的用户的用户名,注意:同一个用户登录多次,则只显示一次即可; [root@app1 tmp]# who | cut -d" " -f1| uniq root dts centos 2、取出最后登录到当前系统的用户的相关信息; [r…

    Linux干货 2016-09-27
  • 关于生命中出现的那个男人

    绝对真男人     一个人的一生,会遇到很多很多的男人,哦,也会遇到很多很多的女人,但是我们今天就谈谈男人吧.在这芸芸众生中对于我们这些志向于在linux求发展谋生存的人来说,有个男人会是所有linux爱好者的良师益友.这个男人就是man,这个男人是绝对的男人,因为他是在linux这个系统中无所不知的那个男人. &nb…

    Linux干货 2016-10-27
  • 笔记整理:权限管理3-ACL

    ACL 访问控制列表,并不是所有的Linux文件系统,都支持ACL。FAT文件系统也不支持ACL   ACL文件系统中,不支持chmod等命令。同时不能更改文件权限。不存在文件权限。 问题提出 只让wang用户,对该文件不能够访问,同时不影响其他任何用户对该文件的操作。   ACL特点 针对单一用户或群组,单一文件或目录,进行rwx权限设…

    Linux干货 2016-08-05

评论列表(1条)

  • 马哥教育
    马哥教育 2016-09-14 08:02

    赞~