本节内容

1.  什么是shell

2.  命令的优先级

3.  元字符

4.  登录shell与非登录shell

一  什么是shell

shell一般代表两个层面的意思,一个是命令解释器,如bash;另外一个就是shell脚本

命令解释器shell的发展历史 sh -> csh -> ksh -> tcsh -> bash,重点学习bash

二  命令的优先级
==> alias
==> Compound Commands
==> function
==> builtin
==> hash
==> $PATH
==> error:command not found

获取一个命令会按照上述优先级去寻找,先找同名的alias,再早compound命令......

==========================part1======================================

让我们从最简单的入手:别名、内部命令、外部命令,来探讨它们三者的优先级

别名:别名命令是为了简化输出给一个长参数命令的整合,别名的定义方法:alias la="ls -al" 取消别名 unalias la

内部命令:是bash自带的命令,功能简单, man builtin

外部命令:小程序存在 /bin/  /sbin/  /usr/bin/等地方

[root@localhost ~]# alias cd
-bash: alias: cd: not found

cd是一个内部命令,属于bash自带命令(man cd) 它没有定义别名

[root@localhost ~]# alias ls
alias ls='ls --color=auto'

ls定义了别名

[root@localhost ~]# which ls
alias ls='ls --color=auto'
           /usr/bin/ls

ls 实际是一个外部命令,属于可执行程序 通过C代码编译得出的可执行程序

[root@localhost ~]# file /usr/bin/ls
/usr/bin/ls: ELF 64-bit LSB executable, x86-64, version 1 (SYSV), dynamically linked (uses shared libs), for GNU/Linux 2.6.32, BuildID[sha1]=3d705971a4c4544545cb78fd890d27bf792af6d4, stripped

测试优先级原理:别名、内部命令、$PATH中设置相同的命令名,测试哪个命令先执行

[root@localhost ~]# alias cd='ls -l'   # 建立一个别名cd实际指向 /usr/bin/ls

[root@localhost ~]# cp /bin/hostname /usr/local/sbin/cd  # 在PATH第一个目录放入一个cd命令

[root@localhost ~]# cd
total 8
-rw-------. 1 root root 1791 Sep 21 11:00 anaconda-ks.cfg
-rw-r--r--. 1 root root 1819 Sep 21 03:10 initial-setup-ks.cfg

[root@localhost ~]# unalias cd    删除别名

[root@localhost ~]# cd    执行真正的内部命令
[root@localhost ~]#

[root@localhost ~]# /usr/local/sbin/cd
localhost.localdomain
[root@localhost ~]#

[root@localhost ~]# rm -rf /usr/local/sbin/cd

小结一:命令的执行顺序

别名(alias 查看别名)   >  bash 内部命令 > $PATH 中按冒号分割的每个路径中去搜索

ps: 登录后的预置别名从何而来(应该学会:建立别名和取消别名,固话别名配置无非将alias定义到文件中)

[root@localhost ~]# alias
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/.bashrc/ (rc-> run command) ,普通用户的.bashrc不包含别名,因为普通用户的.bashrc模板是/etc/skel/.bashrc

而root这个.bashrc是按照系统完毕就预置的

[root@localhost ~]# grep '^alias' /root/.bashrc
alias rm='rm -i'
alias cp='cp -i'
alias mv='mv -i'

一部分来自 /etc/profile.d/目录里的可执行文件

[root@localhost ~]# grep -rn 'alias' /etc/profile.d/
/etc/profile.d/colorgrep.csh:9:alias grep 'grep --color=auto'
/etc/profile.d/colorgrep.csh:10:alias egrep 'egrep --color=auto'
/etc/profile.d/colorgrep.csh:11:alias fgrep 'fgrep --color=auto'
......

==================================part2=============================

内置命令bash built-in commands

很多种

第一种:bash自身带的功能 参见 man cd

第二种:Compound Commands

例如 for if while 等

参见man bash

第三种:function

[root@localhost ~]# function cd(){ echo 'my function cd:'; }

有什么函数可以通过set命令找到

[root@localhost ~]# set | cd
my function cd:

验证:alias,compound优先级

[root@localhost ~]# alias if='ls -l'
[root@localhost ~]# if                   # 证明别名比compound的优先级高
total 8
-rw-------. 1 root root 1791 Sep 21 11:00 anaconda-ks.cfg
-rw-r--r--. 1 root root 1819 Sep 21 03:10 initial-setup-ks.cfg

验证:compound与function的优先级

[root@localhost ~]# function for() { echo 'my function for'; }
[root@localhost ~]# for((i=1;i<3;i++));do echo $i;done        #  执行的仍然是compound命令,证明compound优先级比函数高
1
2

验证:function与内置命令的优先级高

[root@localhost ~]# function cd() { echo 'my function cd';}
[root@localhost ~]# cd     # 执行的是自己的函数而不是内置命令cd,证明函数比内置命令优先级高
my function cd

小结二:

别名 alias > Compound Commands > function > 内置命令

==================================part3============================

当别名和内部命令搜索不到时,找$PATH

[root@localhost ~]# sed -n 's/:/\n/gp' <<< $PATH
/usr/local/sbin
/usr/local/bin
/usr/sbin
/usr/bin
/root/bin
/usr/local/python3/bin

因为这个变量包含的路径太多,每个路径中的可执行文件也很多,如果每次都要搜索每个路径下的所有可执行文件,显然是不明智的

为了减少$PATH的搜索,上一次搜索的内容能够被下一次执行重用,bash对从$PATH中搜索得出的外部命令建立hash表,用于缓存

这个缓存是会话级别独立拥有的,不可以对其他终端共享,因为每个用户的$PATH可能不同

[root@localhost ~]# hash -r          # 清除缓存
[root@localhost ~]# hostname    # 每执行一次就缓存一次
localhost
[root@localhost ~]# hash              # 查看缓存表,发现多了一条缓存
hits   command
1      /usr/bin/hostname

验证:hash 与 $PATH的优先级

[root@localhost ~]# mv /usr/bin/hostname /usr/sbin/
[root@localhost ~]# hostname     # 再次执行hostname,没有找到,说明hash寻找路径的优先级高于$PATH
-bash: /usr/bin/hostname: No such file or directory
[root@localhost ~]# hash
hits command
2 /usr/bin/hostname
1 /usr/bin/mv

总结命令执行顺序:

alias   如,alias ls='ls -l'

compound commands 流程控制关键字  如,if  while for

function 如,function test() { echo 'my function test'; }

function test(){
read -p 'please input hostname:' name;
echo $name;
hostnamectl set-hostname $name;
} test

unset test   # 函数包括定义、调用、取消

builtin,内置命令 ,如cd ; source 执行脚本

hash  缓存命令路径

$PATH 安装第三方软件包

三  元字符

bash中的特殊字符,键盘上能敲出的特殊字符都有其特殊意义,元字符会被shell解释的

编程 本质 处理数据的变化或者状态的变化

1----->2

500----->1000

True----->False

level = 1

level = 2

~ 家目录 区别root用户和普通用户

[root@localhost local]# cd ~
[root@localhost ~]# pwd
/root

` ` 命令替换  取命令的执行结果

[root@localhost ~]# res=`ls`        # 取命令运行结果,赋值给变量res,中间没有空格
[root@localhost ~]# echo $res   # 查看变量res值 
anaconda-ks.cfg initial-setup-ks.cfg

$()同上,但它弥补了``的嵌套缺陷,推荐使用

[root@localhost ~]# res=$(echo $(ls))
[root@localhost ~]# echo $res
anaconda-ks.cfg initial-setup-ks.cfg

!取非

[root@localhost tmp]# ls [abcd].txt    [] 只取中括号里一个字符
a.txt b.txt c.txt d.txt

[root@localhost tmp]# ls [a-z].txt       [] 只取中括号里一个字符,从a到z,也包括从A到Z, aAbBcC...z

[root@localhost tmp]# ls [!0-9].txt     [] 首先取一个字符,且不是0-9数字的
a.txt b.txt B.txt c.txt d.txt Z.txt

!历史命名调用

[root@localhost tmp]# !308
cd /tmp

$?

0 表示上一条命令执行成功

非0 表示没有成功

[root@localhost tmp]# echo $?
0
[root@localhost tmp]# djina
bash: djina: command not found...
[root@localhost tmp]# echo $?
127

@ 无特殊含义

# 注释

$ 变量取值

$() 同 ``

${} 变量名的范围

$[] 整数计算 echo $[2+3] - * / % 浮点数用 echo "scale=3; 10/3" | bc -l

[root@localhost tmp]# money=10
[root@localhost tmp]# echo $money
10
[root@localhost tmp]# echo 000$money
00010
[root@localhost tmp]# echo $money100

[root@localhost tmp]# echo ${money}1000
101000

% 取模;杀后台进程jobs号

^ 取反和! 雷同

& 在后台执行;&&逻辑与运算,如make && make install

[root@localhost tmp]# pwd && echo 123
/tmp
123

|  管道符号;  || 逻辑或运算,第一个命令执行成功后,停止;第一个命令执行失败后,再执行第二个命令

[root@localhost tmp]# pwd || echo '123'
/tmp

*  乘号

-  减号;范围;cd - 返回上一个工作目录

+

= 赋值 ;== 判断

[root@localhost tmp]# y=2
[root@localhost tmp]# x=1
[root@localhost tmp]# [ $y > $x ]   # 逻辑判断,注意空格隔开
[root@localhost tmp]# echo $?
0

{} 命令列表 ,注意括号内的开头和结尾必须是空格{    ls; cd /;   }

\  转义字符

[root@localhost tmp]# x=1
[root@localhost tmp]# echo "$x"   # 软引用,区域于' ' 引用
1
[root@localhost tmp]# echo "\$x"
$x

; 分割多个命令

: 空命令,返回真

[root@localhost tmp]# while :;do echo 123;done

while :;
do
echo ;
sleep 0.5;
done

/ 目录分割符

?  只匹配一个字符;* 任意字符

>  比较大小;> 覆盖;>> 追加

元字符和命令是一个级别的,被bash解析,而正则表达式是被命令解析的

四  登录shell与非登录shell

登录shell,是通过用户名密码或 su - 获得的shell

非登录shell,则是通过bash命令和脚本开启的shell环境

Linux中一切皆文件,shell的属性加载也写到文件里,在登录时就会加载对应的文件的内容来初始化shell环境

非登录与登录shell区别就在于加载的文件不同,从而导致获得的shell环境不同

登录shell都加载了哪些文件呢

测试:

/etc/profile                 添加   echo '/etc/profile'

/etc/profile.d/a.sh     新建脚本 a.sh   echo '/etc/profile.d/a.sh'

~/.bash_profile          添加  echo '/root/.bash_profiile'

~/.bashrc                    添加  echo '/root/.bashrc'

/etc/bashrc                添加  echo '/etc/bashrc'

结果 :

结论:

1. 登录shell 会加载一些脚本并执行,且脚本之间有顺序

2. 可以在脚本中定义变量,bash中可以直接使用

实例:

1. 在 /etc/profile中添加x=1;y=2  那么,登录之后可以 echo $x;echo $y

2.  编译安装Python时,更改环境变量  PATH

非登录shell都加载了哪些文件呢

非登录shell加载的文件就少了很多,并且顺序也不同

所以,我们想要固化一个配置在那种登录下有效

将环境变量设置在 $HOME/.bash_profile

不管那种登录都想使用的变量就设置在 $HOME/.bashrc

补充:

命令补齐TAB键
简化输入 提示 防止书写错误

历史记录
上下键查
history 查询 用!ID 调用
ctrl+r 输入匹配

快捷键
CTRL+A 行首
CTRL+E 行尾
CTRL+U 删除自光标到行首串
CTRL+K 删除自光标到行尾串
CTRL+L 清屏

更多内容请参考

http://www.cnblogs.com/linhaifeng/p/6592572.html

BASH 环境的更多相关文章

  1. bash环境变量读取顺序

    bash环境变量读取顺序: 交互式登录的用户: /etc/profile --> /etc/profile.d/*.sh --> ~/.bash_profile --> ~/.bas ...

  2. 20181225-Linux Shell Bash环境下自动化创建ssh互信脚本

    20181225-Linux Shell Bash环境下自动化创建ssh互信脚本 1. 我的Blog 博客园 https://www.cnblogs.com/piggybaba/ 个人网站 http: ...

  3. 第6天【egrep、bash环境配置及脚本、vim编辑器】

    bash环境配置及脚本(02)_recv bash环境配置及脚本(02)_recv bash环境配置文件: 按生效范围划分,存在两类: 全局配置: /etc/profile /etc/bashrc 个 ...

  4. source 命令的用法,是在当前bash环境下执行脚本文件

    原文: http://www.cnblogs.com/softwaretesting/archive/2012/02/13/2349550.html source命令用法: source FileNa ...

  5. [转帖]linux bash环境变量简单总结

    linux bash环境变量简单总结 来源链接:http://www.178linux.com/8005 原创文章,如有转载,请注明原文地址 需要简单学习一下. 其实 我都是直接放一个 .sh文件到 ...

  6. linux bash环境变量简单总结

    来源链接:http://www.178linux.com/8005 原创文章,如有转载,请注明原文地址 一.环境变量简介 Linux是一个多用户的操作系统.每个用户登录系统后,都会有一个专用的运行环境 ...

  7. Linux系列(10):入门之bash基础与bash环境设置

    了解什么是shell吗? 知道如何查询当前系统支持的shell版本吗? 了解如何判断某个指令是否是bash的内置指令吗? 了解Linux的变量吗,知道如何定义与删除变量吗,知道如何赋值吗,知道如何获取 ...

  8. Bash环境配置文件

    一.环境配置文件读取优先级 其中~/.bash_profile,~/.bash_login,~/.profile三个文件只有一个有效,查找优先级从左至右降低.bash会一直检查是否有~/.bashrc ...

  9. shell:bash环境

    1.什么是shell shell一般代表两个层面的意思,一个是命令解释器,比如BASH,另外一个是shell脚本. 命令解释器shell的发展史,sh-csh-ksh-tcsh-bash. 2.命令的 ...

  10. Shell第一篇:BASH 环境

    一 什么是SHELL shell一般代表两个层面的意思,一个是命令解释器,比如BASH,另外一个就是shell脚本.本节我们站在命令解释器的角度来阐述shell 命令解释器SHELL的发展历史,SH- ...

随机推荐

  1. 26.python常用端口号

    MySQL默认端口 3306 Redis默认端口 6379 MongoDB默认端口 27017 django端口 8000 flask端口 5000 pyspider服务端口 5000(由flask开 ...

  2. django在centos部署

    各种坑各种蛋疼,搞了两天终于能用了.整体分2步: 1. 通过uwsgi 启动django项目 在manage.py同级目录,新建uwsgi.ini文件 [uwsgi] # 配置服务器的监听ip和端口, ...

  3. 第二篇*2、Python字符串格式化

    1.字符串格式化 Python的字符串格式化有两种方式: 百分号方式.format方式 1)百分号方式 %[(name)][flags][width].[precision]typecode (nam ...

  4. 一个free异常引发的异常

    有同事反馈说自己的线程不工作,查看堆栈发现其打印如下: # # # # # # # # , info= # <signal handler called> # # # # # # # , ...

  5. git command line 提交代码

    echo "# spring-boot-apollo-demo" >> README.md git init git add README.md git commit ...

  6. ceph结构详解

    引言 那么问题来了,把一份数据存到一群Server中分几步? Ceph的答案是:两步. 计算PG 计算OSD 计算PG 首先,要明确Ceph的一个规定:在Ceph中,一切皆对象. 不论是视频,文本,照 ...

  7. P1147连续自然数和-(尺取法)

    https://www.luogu.org/problemnew/show/P1147 题意:输入一个n,求连续几个数加起来等于n,输出这几个连续的数的第一个和最后一个.10<=n<=20 ...

  8. JSON转Excel

    1.引入js (dist目录下JsonExportExcel.min.js) <script src="https://cuikangjie.github.io/JsonExportE ...

  9. Spring使用Jackson处理json数据

    1.搭建SpringMVC+Spring环境 2.配置web.xml.SpringMVC-config.xml <?xml version="1.0" encoding=&q ...

  10. Cobbler安装CentOS7系统时报错 What do you want do now?

    问题的根源: 在cobbler服务主机中执行了  createrepo --update  /var/www/cobbler/ks_mirror/CentOS-7-x86_64/ 导致的. cobbl ...