用一条命令’pwd’判断并证明系统命令的执行顺序。

一、命令分类
    
    在Linux系统中命令分为两类:
    
        1.内部命令:shell buildin 每次启动系统都会重新加载入内存。
        2.外部命令:即某目录下的文件,通过外部介质安装的命令工具包,如通过yum、rpm等方式安装,具体安装路径在$PATH下。

二、命令执行顺序
    
    在命令执行过程中,命令形态主要分为4类:alias(别名命令)、内部命令、hash缓存命令和外部命令。

三、命令执行顺序
    
    1. type command 查看是否是内部命令
    2. alias 定义别名 ualias取消别名
    3. enable command 启用内部命令
              -n command 关闭内部命令
    4. hash 显示hash缓存
            -d 删除具体缓存命令路径
    5. cp src dst/name 复制文件
    6. mv src dst  移动文件
    7. echo $PATH 显示PATH的内容
    8. which -a  command  查看所有包含command的路径
    9. rm 删除文件
    

四、实例:‘pwd’即是内部命令又是外部命令,以‘pwd’为例实验证明其执行顺序

1.type命令判断pwd命令是内部命令,新建alias pwd条目为ls命令并执行,结果为列出当前目录文件,说明alias优先于内部命令。

    [root@h(Brad) etc]#type pwd
    pwd is a shell builtin
    [root@h(Brad) ~]#alias -p pwd=’ls’
    [root@h(Brad) ~]#pwd
    123      723.txt          dead.letter  Documents  install.log
    
2.禁用内部命令pwd,清空hash,执行pwd仍然显示ls结果,说明不论内部命令是否启用,都会执行alias。

    [root@h(Brad) etc]#enable -n pwd
    [root@h(Brad) ~]#hash -r
    [root@h(Brad) ~]#pwd
    123      723.txt          dead.letter  Documents  install.log
    
3.删除aliaspwd,使用pwd命令,仍然有效,并且判断为外部命令,hash路径在/bin/pwd。说明相比外部命令,系统优先使用内部命令。

    [root@h(Brad) ~]#unalias pwd
    [root@h(Brad) etc]#pwd
    /etc
    [root@h(Brad) etc]#type pwd
    pwd is hashed (/bin/pwd)
    
4.删除hash -d pwd,用hash -p命令创建一条pwd的hash,cp /sbin/ifconfig到/usr/sbin/pwd执行pwd结果为查看网络信息。说明执行的是/usr/sbin/pwd,hash路径优先。

    [root@h(Brad) etc]#hash -d pwd
    [root@h(Brad) ~]#cp /sbin/ifconfig /usr/sbin/pwd
    [root@h(Brad) ~]#hash -p /usr/sbin/pwd pwd
    [root@h(Brad) ~]#pwd
    eth0      Link encap:Ethernet  HWaddr 00:0C:29:03:75:7F  
          inet addr:172.16.253.154  Bcast:172.16.255.255  Mask:255.255.0.0
    
    
5.显示PATH路径

    [root@h(Brad) etc]#echo $PATH
    /usr/lib64/qt-3.3/bin:/usr/local/sbin:/usr/local/bin:/sbin:/bin:/usr/sbin:/usr/bin:/root/bin
    
6.hash -d 删除pwd条目
  

    [root@h(Brad) etc]#hash
    hits    command
      20    /bin/grep
       1    /bin/pwd
    [root@h(Brad) etc]#hash -d pwd
    [root@h(Brad) etc]#hash
    hits    command
      20    /bin/grep
       2    /usr/sbin/groupadd

7.move pwd到/usr/sbin并执行,可以执行,并hash /usr/bin,说明在PATH的其他目录中也可以执行,并hash。      

    [root@h(Brad) etc]#mv /bin/pwd /usr/sbin
    [root@h(Brad) etc]#pwd
    /etc
    [root@h(Brad) etc]#hash
    hits    command
      20    /bin/grep
       1    /usr/sbin/pwd
       
8.删除hash中pwd ,cp /sbin/ifconfig到/bin/pwd并执行,执行pwd结果为查看网络信息。说明执行的是/bin/pwd,在PATH中左面目录为优先执行目录。

    [root@h(Brad) etc]#hash -d pwd
    [root@h(Brad) etc]#cp /sbin/ifconfig /bin/pwd
    [root@h(Brad) ~]#which -a pwd                   
    /bin/pwd
    /usr/sbin/pwd[root@h(Brad) etc]#hash -d pwd
    [root@h(Brad) etc]#pwd
        eth0      Link encap:Ethernet  HWaddr 00:0C:29:03:75:7F  
          inet addr:172.16.253.154  Bcast:172.16.255.255  Mask:255.255.0.0
          
9.rm删除/bin/pwd,执行pwd显示找不文件,说明相比PATH顺序,优先读取hash中的缓存目录命令。

    [root@h(Brad) ~]#rm /bin/pwd
    rm: remove regular file `/bin/pwd’? y
    [root@h(Brad) etc]#pwd
    -bash: /bin/pwd: No such file or directory
    
五、结论:系统执行命令的优先顺序依次为:
alias——> shell builtin——> hash ——> PATH

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

(1)
manbinnmanbinn
上一篇 2017-09-02 21:08
下一篇 2017-09-03 14:40

相关推荐

  • 实验:httpd

    虚拟主机 httpd-2.4示例步骤: 1. 进行规划虚拟主机 192.168.209.8:80,192.168.209.10:80 www.10linux.com,www.iounix.com /var/www/html/10linux,/var/www/html/iounix 2. ]# mkdir /var/www/html/{10linux,ioun…

    Linux干货 2017-06-04
  • 配额限制、RAID、LVM

    配置配额系统 在内核中执行以文件系统为单位启用,对不同组或者用户的策略不同; 根据块或者节点进行限制 软限制(soft limit) 硬限制(hard limit) 初始化(/home) 分区挂载选项( /etc/fstab ):usrquota、grpquota 创建数据库: 将selinux调为禁用状态:Permissive quotacheck -cu…

    Linux干货 2017-04-26
  • 简述计算机网络中的物理层

          简要说明物理层在网络传输中做了哪些工作解决的问题      物理层是计算机网络OSI模型中最低的一层。物理层规定:为传输数据所需要的物理链路创建、维持、拆除,而提供具有机械的,电子的,功能的和规范的特性。简单的说,物理层确保原始的数据比特流可在各种物理媒体上传输。使得…

    Linux干货 2017-05-08
  • netstat

    netstat命令 netstat 命令用于显示各种网络相关信息,如网络连接,路由表,接口状态 (Interface Statistics),masquerade 连接,多播成员 (Multicast Memberships) 等等 1 常用选项: -a :(all)显示所有选项,默认不显示LISTEN相关 -t :(tcp)仅显示tcp相关选项 -u :(…

    Linux干货 2017-05-07
  • Linux防火墙之基本原理

    本系列文章主要讲述Linux防火墙的基本原理和基础使用方法: 1.什么是防火墙: 当我们把计算机连入互联网与其他计算机进行通信时,这无疑也将自己的信息暴露了,那就意味着可能会有一些心怀不轨的人会利用这些信息来攻击自己的主机,尤其是作为一台服务器向互联网用户提供服务时,就迫切需要一种隔离和保护机制,来隔离外部网络,达到保护自我的目的。而这种隔离机制就叫做防火墙…

    Linux干货 2016-12-27
  • rpm,yum,编译安装应用详解 (Blog 5)

    rpm, yum, 编译安装全解

    2017-11-27