一、Vim文本编辑器
在Linux系统中一切都是文件,而配置一个服务就是在修改其配置文件的参数
命令模式:控制光标移动,可对文本进行复制、粘贴、删除和查找等工作。
输入模式:正常的文本录入。
末行模式:保存或退出文档,以及设置编辑环境。
命令模式中最常用的一些命令
命令 | 作用 |
---|---|
dd | 删除(剪切)光标所在整行 |
5dd | 删除(剪切)从光标处开始的5行 |
yy | 复制光标所在整行 |
5yy | 复制从光标处开始的5行 |
n | 显示搜索命令定位到的下一个字符串 |
N | 显示搜索命令定位到的上一个字符串 |
u | 撤销上一步的操作 |
p | 将之前删除(dd)或复制(yy)过的数据粘贴到光标后面 |
末行模式中最常用的一些命令
命令 | 作用 |
---|---|
:w | 保存 |
:q | 退出 |
:q! | 强制退出(放弃对文档的修改内容) |
:wq! | 强制保存退出 |
:set nu | 显示行号 |
:set nonu | 不显示行号 |
:命令 | 执行该命令 |
:整数 | 跳转到该行 |
😒/one/two | 将当前光标所在行的第一个one替换成two |
😒/one/two/g | 将当前光标所在行的所有one替换成two |
:%s/one/two/g | 将全文中的所有one替换成two |
?字符串 | 在文本中从下至上搜索该字符串 |
/字符串 | 在文本中从上至下搜索该字符串 |
二、配置Yum软件仓库
最简单的配置;
[具有唯一性的标识名称,不应与其他软件仓库发生冲突。]
name=可以是一些介绍词,易于识别软件仓库的用处。
baseurl=即软件包的获取方式,可以使用FTP、HTTP与本地file。
enabled=设置此源是否被使用,1为使用,0为禁用。
gpgcheck=设置此源是否被校验,1为校验,0为禁用。
三、编写Shell脚本
Shell脚本命令的工作方式有两种:交互式和批处理。
交互式(Interactive):用户每输入一条命令就立即执行。
批处理(Batch):由用户事先编写好一个完整的Shell脚本,Shell会一次性执行脚本中诸多的命令。
1、脚本三要素
脚本声明
脚本注释
脚本命令
2、接收用户的参数
当我们执行某一个命令,加或不加参数的输出结果也是不同的:
[root@zjs ~]# wc -l anaconda-ks.cfg
44 anaconda-ks.cfg
[root@zjs ~]# wc -c anaconda-ks.cfg
1407 anaconda-ks.cfg
[root@zjs ~]# wc -w anaconda-ks.cfg
121 anaconda-ks.cfg
这意味着命令不仅要能接收用户输入的内容,还要有能力进行判断区别,根据不同的输入调用不同的功能。
其实,Linux系统中的Shell脚本语言早就考虑到了这些,已经内设了用于接收参数的变量,变量之间可以使用空格间隔。例如 0 对 应 的 是 当 前 S h e l l 脚 本 程 序 的 名 称 , 0对应的是当前Shell脚本程序的名称, 0对应的是当前Shell脚本程序的名称,#对应的是总共有几个参数, ∗ 对 应 的 是 所 有 位 置 的 参 数 值 , *对应的是所有位置的参数值, ∗对应的是所有位置的参数值,?对应的是显示上一次命令的执行返回值,而$1、$2、$3……则分别对应着第N个位置的参数值,如下图所示。
3、判断用户的参数
条件测试语句可以分为4种:
文件测试语句;
逻辑测试语句;
整数值比较语句;
字符串比较语句。
文件测试所用的参数
操作符 | 作用 |
---|---|
-d | 测试文件是否为目录类型 |
-e | 测试文件是否存在 |
-f | 判断是否为一般文件 |
-r | 测试当前用户是否有权限读取 |
-w | 测试当前用户是否有权限写入 |
-x | 测试当前用户是否有权限执行 |
三种逻辑运算符:
&&是逻辑“与”,只有当前面语句执行成功的时候才会执行后面的命令。
||是逻辑“或”,只有当前面语句执行失败的时候才会执行后面的命令。
!是逻辑“非”,代表对逻辑测试结果取反值,之前是正确则变错误,错误则变正确。
整数比较运算符仅是对数字的操作,不能将数字与字符串、文件等内容一起操作,而且不能想当然地使用日常生活中的等号、大于号、小于号等来判断。因为等号与赋值命令符冲突,大于号和小于号分别与输出重定向命令符和输入重定向命令符冲突。因此一定要使用规范的整数比较运算符来进行操作。可用的整数比较运算符如下图所示。
可用的整数比较运算符
操作符 | 作用 |
---|---|
-eq | 是否等于 |
-ne | 是否不等于 |
-gt | 是否大于 |
-lt | 是否小于 |
-le | 是否等于或小于 |
-ge | 是否大于或等于 |
四、if条件测试语句
if语句分为:单分支结构、双分支结构、多分支结构;
if条件语句的单分支结构由if、then、fi关键词组成,而且只在条件成立后才执行预设的命令,相当于口语的“如果……那么……”。单分支的if语句属于最简单的一种条件判断结构,语法格式如下图所示。
使用单分支的if条件语句来判断/media/cdrom目录是否存在,若不存在就创建这个目录,反之则结束条件判断和整个Shell脚本。
[root@zjs ~]# vim mkcdrom.sh
#!/bin/bash
DIR="/media/cdrom"
if [ ! -d $DIR ]
then
mkdir -p $DIR
fi
在正常情况下,顺利执行完脚本文件后没有任何输出信息,但是可以使用ls命令验证/media/cdrom目录是否已经成功创建:
[root@zjs ~]# bash mkcdrom.sh
[root@zjs ~]# ls -ld /media/cdrom
drwxr-xr-x. 2 root root 6 Oct 13 21:34 /media/cdrom
if条件语句的双分支结构由if、then、else、fi关键词组成,它进行一次条件匹配判断,如果与条件匹配,则去执行相应的预设命令;反之则去执行不匹配时的预设命令,相当于口语的“如果……那么……或者……那么……”。if条件语句的双分支结构也是一种很简单的判断结构,语法格式如下图所示。
下面使用双分支的if条件语句来验证某台主机是否在线,然后根据返回值的结果,要么显示主机在线信息,要么显示主机不在线信息。这里的脚本主要使用ping命令来测试与对方主机的网络联通性,而Linux系统中的ping命令不像Windows一样尝试4次就结束,因此为了避免用户等待时间过长,需要通过-c参数来规定尝试的次数,并使用-i参数定义每个数据包的发送间隔,以及使用-W参数定义等待超时时间。
[root@zjs ~]# vim chkhost.sh
#!/bin/bash
ping -c 3 -i 0.2 -W 3 $1 &> /dev/null
if [ $? -eq 0 ]
then
echo "Host $1 is On-line."
else
echo "Host $1 is Off-line."
fi
若前面的那条语句成功执行,则 ? 变 量 会 显 示 数 字 0 , 反 之 则 显 示 一 个 非 零 的 数 字 ( 可 能 为 1 , 也 可 能 为 2 , 取 决 于 系 统 版 本 ) 。 因 此 可 以 使 用 整 数 比 较 运 算 符 来 判 断 ?变量会显示数字0,反之则显示一个非零的数字(可能为1,也可能为2,取决于系统版本)。因此可以使用整数比较运算符来判断 ?变量会显示数字0,反之则显示一个非零的数字(可能为1,也可能为2,取决于系统版本)。因此可以使用整数比较运算符来判断?变量是否为0,从而获知那条语句的最终判断情况。这里的服务器IP地址为192.168.10.10,来验证一下脚本的效果:
[root@zjs ~]# bash chkhost.sh 192.168.10.10
Host 192.168.10.10 is On-line.
[root@zjs ~]# bash chkhost.sh 192.168.10.20
Host 192.168.10.20 is Off-line.
if条件语句的多分支结构由if、then、else、elif、fi关键词组成,它进行多次条件匹配判断,这多次判断中的任何一项在匹配成功后都会执行相应的预设命令,相当于口语的“如果……那么……如果……那么……”。if条件语句的多分支结构是工作中最常使用的一种条件判断结构,尽管相对复杂但是更加灵活,语法格式如下图所示。
下面使用多分支的if条件语句来判断用户输入的分数在哪个成绩区间内,然后输出如Excellent、Pass、Fail等提示信息。在Linux系统中,read是用来读取用户输入信息的命令,能够把接收到的用户输入信息赋值给后面的指定变量,-p参数用于给予用户一些提示信息。
在下面的脚本示例中,只有当用户输入的分数大于等于85分且小于等于100分,才输出Excellent字样;若分数不满足该条件(即匹配不成功),则继续判断分数是否大于等于70分且小于等于84分,如果是,则输出Pass字样;若两次都落空(即两次的匹配操作都失败了),则输出Fail字样:
[root@zjs ~]# vim chkscore.sh
#!/bin/bash
read -p "Enter your score(0-100):" GRADE
if [ $GRADE -ge 85 ] && [ $GRADE -le 100 ] ; then
echo "$GRADE is Excellent"
elif [ $GRADE -ge 70 ] && [ $GRADE -le 84 ] ; then
echo "$GRADE is Pass"
else
echo "$GRADE is Fail"
fi
[root@zjs ~]# bash chkscore.sh
Enter your score(0-100):88
88 is Excellent
[root@zjs ~]# bash chkscore.sh
Enter your score(0-100):80
80 is Pass
下面执行该脚本。当用户输入的分数分别为30和200时,其结果如下:
[root@zjs ~]# bash chkscore.sh
Enter your score(0-100):30
30 is Fail
[root@zjs ~]# bash chkscore.sh
Enter your score(0-100):200
200 is Fail
为什么输入的分数为200时,依然显示Fail呢?原因很简单—没有成功匹配脚本中的两个条件判断语句,因此自动执行了最终的兜底策略。可见,这个脚本还不是很完美,建议读者自行完善这个脚本,使得用户在输入大于100或小于0的分数时,给予Error报错字样的提示。
2021/1/10