Red Hat Enterprise Linux 8系统学习(五)

一、Vim文本编辑器

在Linux系统中一切都是文件,而配置一个服务就是在修改其配置文件的参数

命令模式:控制光标移动,可对文本进行复制、粘贴、删除和查找等工作。

输入模式:正常的文本录入。

末行模式:保存或退出文档,以及设置编辑环境。

第4章 Vim编辑器与Shell命令脚本第4章 Vim编辑器与Shell命令脚本)

命令模式中最常用的一些命令

命令作用
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脚本程序的名称, 0Shell#对应的是总共有几个参数, ∗ 对 应 的 是 所 有 位 置 的 参 数 值 , *对应的是所有位置的参数值, ?对应的是显示上一次命令的执行返回值,而$1、$2、$3……则分别对应着第N个位置的参数值,如下图所示。

外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传(img-ztl9ERJx-1610764982112)

3、判断用户的参数

条件测试语句可以分为4种:

文件测试语句;

逻辑测试语句;

整数值比较语句;

字符串比较语句。

文件测试所用的参数

操作符作用
-d测试文件是否为目录类型
-e测试文件是否存在
-f判断是否为一般文件
-r测试当前用户是否有权限读取
-w测试当前用户是否有权限写入
-x测试当前用户是否有权限执行

三种逻辑运算符:

&&是逻辑“与”,只有当前面语句执行成功的时候才会执行后面的命令。

||是逻辑“或”,只有当前面语句执行失败的时候才会执行后面的命令。

!是逻辑“非”,代表对逻辑测试结果取反值,之前是正确则变错误,错误则变正确。

整数比较运算符仅是对数字的操作,不能将数字与字符串、文件等内容一起操作,而且不能想当然地使用日常生活中的等号、大于号、小于号等来判断。因为等号与赋值命令符冲突,大于号和小于号分别与输出重定向命令符和输入重定向命令符冲突。因此一定要使用规范的整数比较运算符来进行操作。可用的整数比较运算符如下图所示。

​ 可用的整数比较运算符

操作符作用
-eq是否等于
-ne是否不等于
-gt是否大于
-lt是否小于
-le是否等于或小于
-ge是否大于或等于

四、if条件测试语句

if语句分为:单分支结构、双分支结构、多分支结构;

if条件语句的单分支结构由if、then、fi关键词组成,而且只在条件成立后才执行预设的命令,相当于口语的“如果……那么……”。单分支的if语句属于最简单的一种条件判断结构,语法格式如下图所示。

外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传(img-AIR9ByKd-1610764982113)

使用单分支的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条件语句的双分支结构也是一种很简单的判断结构,语法格式如下图所示。

外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传(img-bVaCBR3Z-1610764982115)

下面使用双分支的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,取决于系统版本)。因此可以使用整数比较运算符来判断 ?012使?变量是否为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条件语句的多分支结构是工作中最常使用的一种条件判断结构,尽管相对复杂但是更加灵活,语法格式如下图所示。

外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传(img-LmtC3Lfc-1610764982117)

下面使用多分支的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

  • 0
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

Carlos Zhang

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值