一、Shell概述
1.Shell概述:
Shell:壳,Shell是一个命令行解释器,它为用户提供了一个向Linux内核发送请求以便运行程序的界面级程序,用户可以用Shell来启动、挂起、停止甚至是编写一些程序。类似于翻译,相当windows的操作界面
Shell同时还是一个功能相当强大的编程语言,易编写,易调试,灵活性较强。Shell是解释执行的脚本语言,在Shell中可以直接调用Linux命令。
2.Shell的分类:
Bourne Shell:从1979起Unix就开始使用的Bourne Shell
Bourne Shell的主文件名为sh
C Shell:C Shell主要是在BSD版的unix系统中使用,其语法和c语言类似而得名
Shell主要有两种语法:Bourne和C,这两种语法彼此不兼容。
Bourne家族主要包括:sh、ksh、Bash(标准Shell)、psh、zsh;
C家族主要包括:csh、tcsh;主要用于Unix
Bash:Bash与sh兼容,现在使用的Linux就是使用bash作为用户的基本Shell。
3.Linux支持的Shell
保存在/etc/shells目录下
[root@localhost ~]# vi /etc/shells
/bin/sh
/bin/bash
/sbin/nologin
/bin/tcsh
/bin/csh
[root@localhost ~]# sh
sh -4.1# exit
exit
[root@localhost ~]# csh
[root@localhost ~]# exit
exit
[root@localhost ~]#
#那么如何判断我们进入的当前shell类型呢,使用echo $SHELL可以查看当前Shell
[root@localhost ~]# echo $SHELL
/bin/bash
父shell:初始时进入的Shell
子Shell:后面调用的Shell
二、脚本执行方式
1.echo输出命令
echo [选项][输出内容]
选项:
-e :支持反斜线控制的字符转换
控制字符:
\a :输出警告音
\b :退格键,也就是向左删除键
\n :换行符
\r :回车键
\t :制表符,也就是Tab键
\v :垂直制表符
\0nnn :按照八进制ASCll码表输出字符。其中0为数字0,nnn为三位八进制数
\xhh :按照十六进制ASCll码表输出字符。其中hh是两位十六进制数
[root@localhost ~]# echo "what do you want to do?"
what do you want to do?
[root@localhost ~]# echo -e "what do you want to\b do?"
what do you want t do?
[root@localhost ~]# echo -e "\x68\t\x65\t\x6c\n\x6c\t\x6f\t"
#按照十六进制ASCⅡ码也同样可以输出
h e l
l o
#注意,感叹号在echo命令中是有特殊含义的
[root@localhost ~]# echo -e "\e[1;31m Do you want do \e[0m"
#输出颜色:
#30m=黑色,31m=红色,32m=绿色,33m=***
#34m=蓝色,35m=洋红,36m=青色,37m=白色
#\e[1;:开启颜色
#\e[0m:关闭颜色
2.第一个脚本
#!/bin/bash
#The first Shell program
echo -e "\e[1;34m 天上掉下个林妹妹 \e[0m"
wq
[root@localhost ~]# vi hello.sh
#!/bin/bash标称下面所写的脚本是标准,纯Shell是不会出错,但是调用其他程序时会出错
#学会写注释
3.脚本执行
(1).赋予执行权限,直接运行
chmod 755 hello.sh
./hello.sh 相对路径
(2).通过Bash调用执行脚本
bash hello.sh #用bash直接解释命令
如果脚本语法有错误可以通过:
[root@localhost ~]# vim hello.sh进行返回修改
注意用英文书写符号
[root@localhost ~]# bash hello.sh
直接调用,或者:
[root@localhost ~]# chmod 755 hello.sh
[root@localhost ~]# ll
总用量 48
-rwxr-xr-x. 1 root root 91 7月 28 11:25 hello.sh
权限变成可执行了
[root@localhost ~]# ./hello.sh
天上掉下个林妹妹
[root@localhost ~]# /root/hello.sh
天上掉下个林妹妹
三、Bash的基本功能
1.命令别名与快捷键
命令别名==小名,另外一个称呼
a.有些命令特别长,那么我们可以取个别名,方便操作
b.操作系统升级后,命令格式发生了变化,那我们可以用旧的得命令去映射新的命令
(1).alias
#查看系统中所有的命令别名
[root@localhost ~]# alias
alias cp = 'cp -i'
alias l.= 'ls -d .* --color=auto'
...
(2).alias 别名= ‘原命令’
#设定命令别名
[root@localhost ~]# vi /etc/passwd #不支持颜色
[root@localhost ~]# vim /etc/passwd #支持颜色
我们可以:
[root@localhost ~]# alias vi='vim'
(3).别名永久生效与删除别名
vi ~/.bashrc
#写入环境变量配置文件(定义操作环境的配置文件)
进入到root下的.bashrc即兴配置即可
alias rm ='rm -i'其中-i就使用询问是否删除的
(4).unalias 别名
#删除别名
(5).命令生效顺序
第一顺序:执行用绝对路径或相对路径执行的命令
第二顺序:执行别名
第三顺序:执行Bash的内部命令,Linux自带的
第四顺序:执行按照$PATH环境变量定义的目录查找顺序找到的第一个命令
[root@localhost ~]# echo $PATH
(6).常用快捷键
Ctrl+c 强制终止当前命令
Ctrl+l 清屏
Ctrl+a 光标移动到命令行首
Ctrl+e 光标移动到命令行行尾
Ctrl+u 从光标所在位置删除到行首
Ctrl+z 把命令放到后台
Ctrl+r 在历时命令中搜索
[root@localhost ~]# ^c
2.历史命令
(1).历史命令
history [选项][历史命令保存文件]
选项:
- c:清空历史命令
- w:把缓存中的历史命令写入历史命令保存文件 ~/,bash_history
保存文本其实占用很小
[root@localhost ~]# ls -alh
总用量 104K
-rw-------. 1 root root 7.2K 10月 10 02:27 .bash history
可以保存起来
另外:历史命令默认会保存1000挑,可以在环境变量配置文件/etc/profile中进行修改
[root@localhost ~]# vi /etc/history
HISTSIZE=1000
可以直接修改
(2).历史命令的调用
使用上、下箭头调用以前的历史命令
使用"!n"重复执行第n条历史命令
使用"!!"重复执行上一条命令
使用"!字符串"重复执行最后一条以该字符串开头的命令
[root@localhost ~]# history#可以查看所有在有效范围出现了的历史命令记录
[root@localhost ~]# service network restart
正在关闭接口eth0: [确定]
关闭环回接口: [确定]
弹出环回接口: [确定]
弹出界面 eth0: [确定]
这个时候我们再次使用就可以这样输入命令:
[root@localhost ~]# !ser
service network restart
(3).命令与文件补全
在Bash中,命令与文件补全是非常方便与常用的功能,我们只要在输入命令或者文件时,
按一下"Tab"键会自动补全,如果存在多个相关的命令
我们可以:按两下"Tab"会弹出提示所有的相关命令
其实命令补全依赖$PATH命令,文件补全依赖与操作路径
3.输出重定向
(1).概述:
输出重定向和输入重定向:
把结果写入计算机中叫做输入,把结果显示出来叫做输出
设备 设备文件名 文件描述符 类型
键盘 /dev/stdin 0 标准输入
显示器 /dev/sdtout 1 标准输出
显示器 /dev/sdterr 2 标准错误输出
(2).输出重定向:
类型 符号 作用
标准输出重定向 命令>文件 以覆盖的方式,把命令的正确输出输出到指定 的文件或设备当中
命令>>文件 以追加的方式,把命令的正确输出输出到指定 的文件或设备当中
标准错误输出重定向 错误命令2>文件 以覆盖的方式,把命令的错误输出输出到指定 的文件或设备当中
错误命令2>>文件 以追加的方式,把命令的错误输出输出到指定 的文件或设备当中
正确输出和错误输出 命令>文件 2>&1 以覆盖的方式,把命令的正确和错误输出输出 同时保存到指定的文件当中
命令>>文件 2>&1 以追加的方式,把命令的正确和错误输出输出 到指定的文件当中
命令&>文件 以覆盖的方式,把正确输出和错误输出都保存 在同一个文件当中
命令&>>文件 以追加的方式,把命令的正确和错误输出输出 到指定的文件当中
命令>>文件1 2>>文件2 以追加的方式,把命令的正确输出保存到文件 1,把错误的输出保存到文件2
通过输出重定向,把输出结果保存起来,可以实现无人值守
[root@localhost ~]# ifconfig > test.log
[root@localhost ~]# cat test.log
#输出结果:...
只要命令有输出,都可以保存到指定位置,注意>大于号会覆盖之前的结果,不想覆盖就使用>>,如果目标文件不存在会自动创建。
如果命令不存在,或者有错误,我们应该用2>或者2>>来保存错误信息,错误信息和正确信息应该用不同的重定向格式,注意>或>>左右两边没有空格
注意:
[root@localhost ~]# ls &>/dev/null
其中/dev/null是一个空,里面的文件会直接删除掉,那么保存的日志将会销毁,找不到了
作用:在写脚本时,不需要过程,只查看结果
(3).输入重定向
[root@localhost ~]# wc [选项][文件名]
选项:
-c 统计字节数 count
-w 统计单词数 word
-l 统计行数 list
[root@localhost ~]# wc
abd
ert
#ctrl+d
2 2 6
单词之间靠空格来分隔
命令<文件 把文件作为命令的输入,统计文件的字节数,单词数
命令<<标识符
[root@localhost ~]# wc << dy(相当于结束标记)
>asd
>
>erty
>dy
4 3 11
...
标识符把标识符之间内容作为命令的输入
4.管道符
(1).多命令顺序执行
多命令执行符 格式 作用
; 命令1; 命令2 多个命令顺序执行,命令之间没有任何逻辑联系
&& 命令1&&命令2 逻辑与(没有数据传递)
当命令1正确执行,则命令2才会执行
当命令1执行不正确,则命令2不会执行
|| 命令1||命令2 逻辑或(没有数据传递)
当命令1执行不正确时,命令2才会执行
当命令1正确执行时,命令2不会执行
注意分号是英文的;
[root@localhost ~]# ls && echo yes || echo no
acces.log ....
yes
[root@localhost ~]# lsa && echo yes || echo no
-bash: lsa:command not found
no
顺序不能颠倒: && echo yes || echo no
这里的命令1可以有多个命令,如果其中有一个命令执行了,那么命令1就是存在正确,&&会
执行,||命令2不执行
[root@localhost ~]# ls || echo no && echo yes
yes
[root@localhost ~]# lsa || echo no && echo yes
no
yes
(2)管道符
命令格式:
[root@localhost ~]# 命令1 | 命令2
#命令1的正确输出作为命令2的操作对象
例子:
[root@localhost ~]# ls -l /etc | more
把etc的文件分屏显示
[root@localhost ~]# netstat -an | grep ESTABLISHEN
tcp 0 52 192.168.0.156:22 192.168.0.155:1459 ESTABLISHEN
#提取网络监听端口情况
[root@localhost ~]# netstat -an | grep ESTABLISHEN | wc -l
1 #统计连接结果个数
5.通配符
(1).概述:可以用来匹配其他符号的字符
通配符 作用
? 匹配任意一个字符
* 匹配0个或多个任意字符,也就是可以匹配任意内容
[] 匹配中括号中任意一个字符。例如:[abc]代表一定匹配其中一个字符:a或b
或c
[-] 匹配中括号中任意一个字符,-代表一个范围,例如:[a-z]代表从a-z的一个
小写字母
[^] 逻辑非,表示匹配不是中括号内的一个字符。例如:[^0-9]代表匹配的不是一
个数字的字符
注:除了*可以匹配多个字符,其他一次只能匹配一个
例子:
[root@localhost ~]# mkdir dy
[root@localhost ~]# cd /root/dy
[root@localhost dy]# pwd
/root/dy
[root@localhost dy]# touch dzp
[root@localhost dy]# touch dzp2
[root@localhost dy]# touch dzp3
[root@localhost dy]# touch dzp34
[root@localhost dy]# touch dzpcang
[root@localhost dy]# touch dzpbols
[root@localhost dy]# touch dzpa
[root@localhost dy]# ls
dzp dzp2 dzp3 dzp34 dzpcang dzpbols
[root@localhost dy]# ls dzp
dzp
[root@localhost dy]# ls dzp*
dzp dzp2 dzp3 dzp34 dzpcang dzpbols
[root@localhost dy]# ls dzp?
dzp2 dzp3
[root@localhost dy]# ls dzp[0-9]
dzp2 dzp3
[root@localhost dy]# ls dzp[0-9][0-9]
dzp34
[root@localhost dy]# ls dzp[^0-9]
dzpa
注:通配符主要用来匹配文件名或者文件目录,如果要匹配文件内容,需要用到正则表达式
(3).Bash中其他特殊符号:
符号 作用
'' 单引号,在单引号中所有的特殊符号,如“$”和“`”和“\”都没有特殊含义
"" 双引号。在双引号中特殊符号都没有特殊含义,但是“$”和“`”和“\”例外
拥有“调用变量的值”,“引用命令”和“转义符”的特殊含义
`` 反引号。反引号括起来的内容是系统命令,在Bash中会先执行它,和$()作用一
样,不过推荐使用$(),反引号容易看错
$() 和反引号作用一样,用来引用系统命令
# 在shell脚本中,#开头的行代表注释
$ 用于调用变量的值,如需要调用变量name的值时,需要使用$name的方式得到变
量的值
\ 转义符,跟在\之后的特殊符号都将失去意义,变成普通字符,如\$将输出“$
”符号,而不是当作变量引用
[root@localhost dy]# a=123
[root@localhost dy]# echo $a
123
[root@localhost dy]# echo '$a'
$a
[root@localhost dy]# echo "$a"
123
[root@localhost dy]# a=ls
[root@localhost dy]# echo "$a"
ls
[root@localhost dy]# a=`ls`
[root@localhost dy]# echo "$a"
dzp
dzp2
dzp3
dzp34
dzpcang
dzpbols
dzpa
一般不是用``容易和''单引号混淆,我们可以使用$()