首页 > 代码库 > Shell、内外部命令——Linux基本命令(2)

Shell、内外部命令——Linux基本命令(2)

1.Shell

ShellLinux系统的用户界面,提供了用户与内核进行交互操作的一种接口。它接收用户输入的命令并把它送入内核去执行.

shell也被称为LINUX的命令解释器(commandinterpreter.

vshell是一种高级程序设计语言.

技术分享


                            

2.bash shell

GNUBourne-AgainShell(bash)GNU计划中重要的工具软件之一,目前也是Linux标准的shell,与sh兼容.

1)查询当前系统使用哪个Shell

使用echo$SHELL

echo的作用是输入什么就输出什么,因此,echo一个变量值就是把变量引用出来,即可以显示当前系统的Shellbash

技术分享


PS:一定要输入$则系统会不识别它是个变量,仅仅把它当做一个字符串显示。

2)查询当前系统已安装的所有shell

使用cat/etc/shells

技术分享



3.Shell提示符

1)提示符格式

bash最原本格式为:

技术分享                            

显示名称和版本号。

但是这种提示符格式不是很实用,因此centos6将提示符默认值改成如下格式:

技术分享

此格式可以直观地显示出当前用户名root主机名centos6目录~用户类型#

 

2)查询主机名

查询主机名的命令为hostname

技术分享

可以发现,提示符显示的主机名并不是完整的主机名,只是显示最前面部分,为了方便区分。

 

3)目录显示

~表示当前目录。如果没有进入时默认为~

当进入一个目录时,会显示路径的最后一截。

技术分享

可以发现,提示符显示的路径也不是完整的路径,只是显示最后一部分,为了方便确认用户确实已经进入这个目录下。

 

4)查询当前的目录

使用命令pwd

技术分享

如图,显示当前目录。

 

5)用户类型

#表示root用户,$表示普通用户。

技术分享

 

6)修改提示符

PS1是提示符格式的变量名,因此可以使用echo查看提示符格式

技术分享

可以看出格式就是提示符的格式。

一些提示符格式如下:

\u 当前用户

\h 主机名简称

\H 完整主机名

\w:完整的工作目录名称,家目录会以 ~代替

\W:最后一个目录

\t 24小时时间格式

\T 12小时时间格式

\! 命令历史数

\# 开机后命令历史数

 

如果想要修改格式,可以将PS1重新赋值,使用=赋值。

我们将h改为大写HW改为小写w,注意要在$后面敲一个空格,使格式美观。

技术分享

我们发现,主机名和用户名都显示为完整的了。

PS$前面应输入两个\,因为$本身是一个特殊字符,\$才可以可以使它转译为普通字符。

 

7)永久修改提示符

我们发现,仅仅用上面的方法,exit退出再登陆之后又恢复为原始默认的状态。因此,我们有一个方法使其永久修改。

export PS1="[\u@\H \w]\$ "命令添加到当前登录用户的~/.bashrc文件中的最后一行,然后使用$ source ~/.bashrc#使其生效。

 

8)修改颜色

使用PS1="\[\e[33m\][\u@\h\W]\\$ \[\e[0m\]"修改提示符颜色

颜色表如下:

技术分享

如图,修改成功:

技术分享




4.内部命令与外部命令

内部命令:由shell自带的,而且通过某命令形式提供

内部命令在系统启动时就调入内存,是常驻内存的,所以执行效率高。

 

外部命令:在文件系统路径下有对应的可执行程序文件

外部命令是系统的软件功能,用户需要时才从硬盘中读入内存。

 


5.命令类型

1)判断命令类型

使用type可以判断一个命令是内部命令还是外部命令

技术分享

如图,cd为内部命令,ifconfig为外部命令。


2enable显示所有启用的内部命令

技术分享


3enable |wc -l 统计启用的内部命令数量(l是字母不是数字1

技术分享

统计出共61


4enable -n COMMAND禁用命令

输入enable –n bg,就可以禁用bg

输入enable |wc –l 查询发现只有60

再用enable查询,发现果然没有bg了,即被禁用了。

技术分享

输入enable –n可以查询所有被禁用的命令

技术分享

同样,可以使用enable-n |wc -l统计被禁用的内部命令数量


5enable COMMAND启动命令

使用enable可以使被禁用的命令重新启动

技术分享

将那三条命令重新启动,查询被禁用里面为空,且启动命令数又恢复到61个了。

 

6)关于禁用

禁用内部命令并不是说不能使用,而是需要从硬盘当中去寻找所对应的外部命令。

技术分享



6. hash

1)缓存路径

系统初始hash表为空,当外部命令执行时,默认会从PATH路径下寻找该命令,找到后会将这条命令的路径记录到hash表中,当再次使用该命令时,shell解释器首先会查看hash表,存在将执行之,如果不存在,将会去变量PATH路径下寻找。

使用 echo 查看PATH的路径:

技术分享

以冒号为间隔符,从左到右依次寻找。

利用hash缓存表可大大提高命令的调用速率。

如图,fdisk是一个外部命令,当运行过后,这个命令就多了一个hash,即将路径缓存了下来。

技术分享

缓存过后就不用去PATH路径依次去找了。

 

这里举一个例子。分别运行pwdifconfig,使其缓存到hash里,可以看到ifconfig的路径在pwd之前。然后我们使用cp命令,将ifconfig复制到pwd之前的路径并且也命名为pwd。从理论上来说,应该通过路径按照顺序从左到右去寻找,会先找到/usr/local/sbin/pwd,内容应该为ifconfig的内容,但是我们执行pwd之后发现仍然是pwd的结果,并且查询pwd的路径仍然为/bin/pwd

这就说明,在之前运行的时候就已经将pwd的路径缓存到/bin/pwd中了,所以再次运行时不需要在PATH路径中依次寻找,而是调用hash缓存中的路径。

技术分享


2hash 显示当前被hash的所有外部命令

技术分享


hash -l 显示当前被hash的外部命令,包含别名

技术分享


3hash -d name删除hash

现在我们将hash中的缓存的pwd删除,删除时需要输入的name就是用hash -l查到的别名。

技术分享

可以看出列表中没有了pwd

然后我们查看一下pwd的类型,发现地址变成之前复制过去的地址了,因为缓存被删除了。

技术分享

所以此时执行pwd,应该是ifconfig的内容了。

技术分享

PS:也可以使用hash -r 清空所有的hash

hash -p /.../.... name 可以手动增加一个hash缓存。

 

总结:当执行一个命令时,它的优先级为:内部命令> hash> PATH 


本文出自 “Ty_endless” 博客,请务必保留此出处http://tyendless.blog.51cto.com/12435756/1951492

Shell、内外部命令——Linux基本命令(2)