shell:bash环境
1、什么是shell
shell一般代表两个层面的意思,一个是命令解释器,比如BASH,另外一个是shell脚本。
命令解释器shell的发展史,sh-csh-ksh-tcsh-bash。
2、命令的优先级
alias(别名)
Compound Commands(if while for)
function(函数)
build_in(内置命令)
hash(缓存内容)
$PASH
error:command not found
别名:别名命令就是为了简化输出给一个长参数命令的整合,别名的定义方法allias la='ls -al'取消别名unalias la
内部命令:是BASH自带的命令功能简单,内部命令的帮助在builtin(1)里
外部命令:就是一个小程序存在于/bin/ /sbin/ /usr/bin 等地方
[root@seker ~]# alias cd
-bash: alias: cd: not found
cd是一个内部命令 属于bash软件自带命令(参考man cd) 它没有定义别名
[root@seker ~]# alias ls
ls被定义了别名
alias ls='ls --color=tty'
[root@seker ~]# which ls
alias ls='ls --color=tty'
/bin/ls
ls实际是一个外部命令 属于可执行程序 是通过C代码编译得出的可执行程序
登陆后的预置别名从何而来(取消别名、建立别名、固化别名)
[root@MiWiFi-R3-srv ~]# 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@seker ~]#
一部分来自/root/.bashrc 普通用户的.bashrc不包含别名,因为普通用户的.bashrc模板是:/etc/skel/.bashrc
而root这个.bashrc在安装完系统就预置了.
[root@MiWiFi-R3-srv ~]# grep '^alias' /root/.bashrc
alias rm='rm -i'
alias cp='cp -i'
alias mv='mv -i'
[root@seker ~]#
一部分来自/etc/profile.d/目录里的可执行文件
3、元字符
bath中的特殊字符,键盘上能敲出来的特殊字符都有意义,强调一点:元字符是被shell解释的
`` 命令替换,去命令的执行结果
$() 同上,但它弥补了``的嵌套缺陷
~ 家目录
! 取非,历史命令调用,匹配最近一次历史命令,
!+空格+命令 将命令的返回值取反(0-255之间,0则为真,非0位假)
@ 无特殊含义
# 注释
$ 变量取值
${} 变量名的范围
$[] 整数计算 echo $[2+3]-*/% 浮点运算用 echo "scale=3;10/3" |bc -l
[root@MiWiFi-R3-srv ~]# money=10
[root@MiWiFi-R3-srv ~]# echo $money
10
[root@MiWiFi-R3-srv ~]# echo 00000$money
0000010
[root@MiWiFi-R3-srv ~]# echo $money0000
[root@MiWiFi-R3-srv ~]# echo ${money}0000
100000
% 杀后台进程jobs号,取模
^ 替换
[root@MiWiFi-R3-srv ~]# systemctl restart network
[root@MiWiFi-R3-srv ~]# ^network^sshd^
systemctl restart sshd
& 后台执行;&&逻辑与
* 匹配任意长度字符串;计算乘法
() 在子进程中执行
[root@MiWiFi-R3-srv ~]# x=1
[root@MiWiFi-R3-srv ~]# (x=666)
[root@MiWiFi-R3-srv ~]# echo $x
1
[root@MiWiFi-R3-srv ~]#
[root@MiWiFi-R3-srv ~]# (x=666;echo $x)
666
- 减号;区间;cd -;
_ 无特殊含义
+ 加号
= 赋值
| 管道;|| 逻辑或
\ 转义
{} 命令列表#括号内的开头和结尾必须是空格
[] 字符通配,匹配括号内之一
: 空命令,真值
[root@MiWiFi-R3-srv ~]# :
[root@MiWiFi-R3-srv ~]# echo $?
0
; 可以接多个命令如 ls;pwd;echo 123;无论对错,会一直执行到最后一个命令
"" 软引用 '' 硬引用
< 输入重定向
> 输出重定向
>> 追加
<< 这里的文件
>& 合并2和1输出
, 枚举分隔符
.source; 当前目录
/ 目录分隔符
? 单个字符
回车 命令执行
* 通配符:任意字符
? 通配符:任一字符
[abc] 列表项之一
[^abc] 对列表取非,也可以使用范围[a-z]代表aAbBcC…,[0-9]代表1234…
{} 循环列表
[root@MiWiFi-R3-srv test]# touch {1..3}{a..d}.txt
[root@MiWiFi-R3-srv test]# ls
1a.txt 1b.txt 1c.txt 1d.txt 2a.txt 2b.txt 2c.txt 2d.txt 3a.txt 3b.txt 3c.txt 3d.txt
控制变量名的范围 echo${AB}C
硬引用与软引用
[root@MiWiFi-R3-srv test]# x=1
[root@MiWiFi-R3-srv test]# echo "$x" #双引号的代表软引用,引号内特殊字符有特殊意义,比如 $,``等
1
[root@MiWiFi-R3-srv test]# echo '$x' #单引号代表硬引用,引号内所有字符都无特殊意义
$x
\ 转意
[root@MiWiFi-R3-srv test]# echo \\
\
[root@MiWiFi-R3-srv test]# echo \'
'
[root@MiWiFi-R3-srv test]# echo "'"
'
4、bash属性
BASH SHELL 属性
BASH中会有存储一些自身属性的参数,启用或关闭某一项功能
例如控制*.字符是否为通配
查看参数set-0
关闭noglob参数
#set -o noglob
#ls *
ls:*.没有那个文件或目录
#set +o noglob
ls *
固化设定
我们前面所学习的更改变量 属性等等都是在内存中修改 机器重新启动后就会恢复默认值那么怎么固化这些设置 让他们永久生效呢?
这就需要了解BASH两种类型
1.登录shell :就是通过输入用户名 密码后 或 su - 获得的shell
2.非登录shell:非登录shell 则是通过bash命令和脚本开启的shell环境
那么他们有什么区别呢?和我们固化设定又有什么关系呢?
我们知道在linux里一切皆为文件,同样,shell的属性加载也是写到文件里的
在登陆时就会加载对应文件的内容来初始化shell环境,
非登录与登录区别就在于加载的文件不同 从而导致获得的shell环境不同
我们看看登录shell都加载了那些文件
--> /etc/profile
--> /etc/profile.d/*.sh
--> $HOME/.bash_profile
--> $HOME/.bashrc
--> /etc/bashrc
再看非登录shell加载的文件
--> $HOME/.bashrc
--> /etc/bashrc
--> /etc/profile.d/*.sh
可见,非登录shell加载的文件要少很多
那么我们想要固化一个配置时在哪种登录下生效,就显而易见的知道该写在哪个文件里了
通常,我们会将环境变量设置在 $HOME/.bash_profile 中
如果不管哪种登录都想使用的变量 就设置在 $HOME/.bashrc中
命令补齐TAB键
历史记录
上下键查
history 查询 用!ID 调用
ctrl+r 输入匹配
快捷键
CTRL+A 行首
CTRL+E 行尾
CTRL+U 删除自光标到行首串
CTRL+K 删除自光标到行尾串
CTRL+L 清屏