脚本函数与程序包管理

一、函数调用

1.while循环的特殊用法(遍历文件的每一行):

while read line; do
    循环体
done < /PATH/FROM/SOMEFILE

依次读取/PATH/FROM/SOMEFILE文件中的每一行,且将行赋值给变量line
示例:
扫描/etc/passwd文件每一行,如发现GECOS字段为空,则填充用户名和单位电话为62985600,并提示该用户的GECOS信息修改成功。

    #!/bin/bash
    #
    while read line ; do
            var=`echo $line | cut -d ":" -f 5`
            user=`echo $line | cut -d ":" -f 1`
            [[ -z "${var}" ]] && chfn -f ${user} -p 62985600 ${user} ;echo "${user}'s information change successful"
    done < /etc/passwd

2.for循环的特殊用法
双小括号方法,即((…))格式,也可以用于算术运算
双小括号方法也可以使bash Shell实现C语言风格的变量操作

for循环的特殊格式:
for ((控制变量初始化;条件判断表达式;控制变量的修正表达式)) ;do
    循环体
done

控制变量初始化:仅在运行到循环代码段时执行一次
控制变量的修正表达式:每轮循环结束会先进行控制变量修正运算,而后再做条件判断

示例:
打印正序九九乘法表

    

      #!/bin/bash
      for ((j=1;j<=9;j++)) ; do
          for ((i=1;i<=j;i++)) ; do
              echo -ne "$iX$j=$[i*j]\t"
          done
          echo
      done

3.select 循环与菜单

select variable in list ;do
    循环体命令
done

主要用于创建菜单,按数字顺序排列的菜单项将显示在标准错误上,并显示PS3 提示符,等待用户输入
用户输入菜单列表中的某个数字,执行相应的命令
用户输入被保存在内置变量REPLY 中。

select与case
select 是个无限循环,因此要记住用break 命令退出循环,或用exit 命令终止脚本。也可以按ctrl+c 退出循环。
select 经常和case 联合使用
与for 循环类似,可以省略in list ,此时使用位置参量

4.函数介绍
函数function是由若干条shell命令组成的语句块,实现代码重用和模块化编程。
它与shell程序形式上是相似的,不同的是它不是一个单独的进程,不能独立运行,而是shell程序的一部分。
函数和shell程序比较相似,区别在于:
Shell程序在子Shell中运行
而Shell函数在当前Shell中运行。因此在当前Shell中,函数可以对shell中变量进行修改

(1).函数定义
函数由两部分组成:函数名和函数体。

语法一:
function f_name {
…函数体…
}

语法二:
function f_name(){
…函数体…
}

语法三:
f_name(){
…函数体…
}

(2).函数使用
函数的定义和使用:
可在交互式环境下定义函数
可将函数放在脚本文件中作为它的一部分
可放在只包含函数的单独文件中

调用:函数只有被调用才会执行;
调用:给定函数名
函数名出现的地方,会被自动替换为函数代码
函数的生命周期:被调用时创建,返回时终止

函数返回值
函数有两种返回值:
函数的执行结果返回值:
(1) 使用echo或printf命令进行输出
(2) 函数体中调用命令的输出结果

函数的退出状态码:
(1) 默认取决于函数中执行的最后一条命令的退出状态码
(2) 自定义退出状态码,其格式为:
return 从函数中返回,用最后状态命令决定返回值
return 0 无错误返回。
return 1-255 有错误返回

示例:
dir () {
 ls -l $1
}
定义该函数后,若在$后面键入dir,其显示结果同ls-l的作用相同。
该dir函数将一直保留到用户从系统退出,或执行了如下所示的unset命令:unset dir

(3).在脚本中定义及使用函数
函数在使用前必须定义,因此应将函数定义放在脚本开始部分,直至shell首次发现它后才能使用
调用函数仅使用其函数名即可。

示例:

#!/bin/bash
# func1
hello () {
    echo "Hello there today's date is `date +%F`"
}
echo "now going to the function hello"
hello
echo "back from the function"

使用函数文件
可以将经常使用的函数存入函数文件,然后将函数文件载入shell。
文件名可任意选取,但最好与相关任务有某种联系。例如:functions.main
一旦函数文件载入shell,就可以在命令行或脚本中调用函数。可以使用set命令查看所有定义的函数,其输出列表包括已经载入shell的所有函数。
若要改动函数,首先用unset命令从shell中删除函数。改动完毕后,再重新载入此文件。

创建函数文件示例:

#!/bin/bash
#functions.main
findit () {
    if [ $# -lt 1 ] ; then
        echo "Usage:findit file"
        return 1
    fi
    find / -name $1 –print
}

(4).载入函数
函数文件已创建好后,要将它载入shell
定位函数文件并载入shell的格式:
. filename 或source filename
注意:此即<点> <空格> <文件名>
这里的文件名要带正确路径

示例:上例中的函数,可使用如下命令:
 . functions.main

检查载入函数
使用set命令检查函数是否已载入。set命令将在shell中显示所有的载入函数。

示例:

set
findit () {
    if [ $# -lt 1 ]; then
        echo "usage :findit file";
        return 1
    fi
    find / -name $1 -print
}

执行shell函数
要执行函数,简单地键入函数名即可:

删除shell函数
现在对函数做一些改动。首先删除函数,使其对shell不可用。使用unset命令完成此功能.
命令格式为:
unset function_name

函数参数
函数可以接受参数:
传递参数给函数:调用函数时,在函数名后面以空白分隔给定参数列表即可;例如“testfunc arg1 arg2 …”
在函数体中当中,可使用$1, $2, …调用这些参数;还可以使用$@, $*, $#等特殊变量

函数变量
变量作用域:
环境变量:当前shell和子shell有效
本地变量:只在当前shell进程有效,为执行脚本会启动专用子shell进程;因此,本地变量的作用范围是当前shell脚本程序文件,包括脚本中的函数。
局部变量:函数的生命周期;函数结束时变量被自动销毁
注意:如果函数中有局部变量,如果其名称同本地变量,使用局部变量。
在函数中定义局部变量的方法
local NAME=VALUE

函数的变量由函数名后的参数赋值
脚本的变量由脚本名后的参数赋值
当函数的参数为脚本的参数时两者相等
示例

pritvar.sh
#!/bin/bash
fun () {
    echo $1 ; echo $2
}
fun a b
echo $1 $2

执行bash printvar.sh c d
结果为
函数的$1=a $2=b
脚本的$1=c $2=d

(5).函数递归实例
函数递归:
函数直接或间接调用自身
注意递归层数

递归实例:
阶乘是基斯顿·卡曼于1808年发明的运算符号,是数学术语
一个正整数的阶乘(factorial)是所有小于及等于该数的正整数的积,并且有0的阶乘为1。自然数n的阶乘写作n!。
n!=1×2×3×…×n。
阶乘亦可以递归方式定义:0!=1,n!=(n-1)!×n。
n!=n(n-1)(n-2)…1
n(n-1)! = n(n-1)(n-2)!

示例

#!/bin/bash
#
fact() {
if [ $1 -eq 0 -o $1 -eq 1 ]; then
echo 1
else
echo $[$1*$(fact $[$1-1])]
fi
}
fact $1

二、rpm程序包管理器

1.包查询
rpm -q[p] {PACKAGE_FILE|PACKAGE_NAME|NAME}

对已安装的程序:-q  {PACKAGE_NAME|NAME}

14 46 56 --.png

-a: 查询安装的所有程序包

14 48 01 --.png

-c: 查询程序的配置文件

14 48 47 --.png

-d: 查询程序的帮助文档

14 49 11 --.png

-f: 查看指定的文件由哪个程序包安装生成

14 50 55 --.png

-i: 查询程序的简要说明信息

14 51 49 --.png

-l: 查看指定的程序包安装后生成的所有文件;

14 50 45 --.png

-R|–requires: 查询指定的程序包所依赖的CAPABILITY;

14 52 13 --.png

–scripts:程序包自带的脚本片断

14 53 18 --.png

–changelog:查询rpm包的changelog

14 54 04 --.png

–provides: 列出指定程序包所提供的CAPABILITY

14 54 44 --.png

–whatprovides CAPABILITY:查询指定的CAPABILITY由哪个包所提供

–whatrequires CAPABILITY:查询指定的CAPABILITY被哪个包所依赖

对尚未安装的程序:-qp  {PACKAGE_FILE}
-c:
-d:
-i:
-l:
-R:

rpm2cpio 包文件 | cpio –itv 预览包内文件

14 59 27 --.png

rpm2cpio 包文件 | cpio –id “*.conf”释放包内文件

2.包卸载:
rpm -e {PACKAGE_NAME|NAME}

–test: 测试卸载,并不真正卸载

15 01 29 --.png

–nodeps: 忽略依赖关系
–almatches: 如果一个程序同时安装多个版本,将其全部卸载

注意:如果程序包的配置文件安装后曾被修改,卸载时,此文件同常不会删除,而是被重命名(加.rpmsave后缀)后保存

3.程序文件完整性查询

rpm -V {PACKAGE_NAME|NAME} 查询包安装之后生成的文件是否发生了改变

15 14 50 --.png

-a:查询所有已安装的程序

15 09 42 --.png

-f: 查询指定的文件是否被更改过
-p:查询指定的rpm包是否被更改过
没有查询结果表示生成的文件没有改变

查询结果
S file Size differs
M Mode differs (includes permissions and file type)
5 digest (formerly MD5 sum) differs  
D Device major/minor number mismatch  
L readLink(2) path mismatch  
U User ownership differs
G Group ownership differs
T mTimediffers
P capabilities differ

4.包校验
包来源合法性验正及完整性验正:
完整性验正:SHA256
来源合法性验正:RSA

公钥加密:
对称加密:加密、解密使用同一密钥;
非对称加密:密钥是成对儿的
public key: 公钥,公开所有人
secret key: 私钥, 不能公开

导入所需要公钥:rpm –import /etc/pki/rpm-gpg/RPM-GPG-KEY-CentOS-7
检查包的完整性和签名rpm -K {PACKAGE_FILE}
rpm –import /etc/pki/rpm-gpg/RPM-GPG-KEY-CentOS-7
公钥文件由CentOS 7发行版光盘在安装系统时复制到/etc//pki/rpm-gpg/RPM-GPG-KEY-CentOS-7
rpm -qa gpg-pubkey* 查询公钥文件
rpm -e gpg-pubkey*  卸载公钥文件

15 18 44 --.png

5.rpm数据库
数据库位置:/var/lib/rpm
rpm {–initdb|–rebuilddb}
initdb: 初始化;如果事先不存在数据库,则新建之;否则,不执行任何操作
rebuilddb:重建,无论当前存在与否,直接重新创建数据库

三、yum程序包管理器
CentOS: yum, dnf
YUM: YellowdogUpdate Modifier,rpm的前端程序,用来解决软件包相关依赖性,可以在多个库之间定位软件包,up2date的替代工具
yum repository: yum repo,存储了众多rpm包,以及包的相关的元数据文件(放置于特定目录repodata下)

文件服务器:
ftp://
http://
file:///
nfs://

1.yum配置文件
yum客户端配置文件:
/etc/yum.conf:为所有仓库提供公共配置
/etc/yum.repos.d/*.repo:为仓库的指向提供配置

仓库指向的定义:
[repositoryID]
name=Some name for this repository
baseurl=url://path/to/repository/
enabled={1|0}  默认为1,启用
gpgcheck={1|0}  默认为1,启用
gpgkey=URL  公钥文件路径
enablegroups={1|0}  默认为1,启用
failovermethod={roundrobin|priority} 默认为:roundrobin,意为随机挑选;
cost= 默认为1000 cost值越小,优先级越高

yum -config-manager –disable “仓库名" :禁用仓库
yum -config-manager –enable “仓库名” :启用仓库

原创文章,作者:anonymous,如若转载,请注明出处:http://www.178linux.com/38396

(0)
anonymousanonymous
上一篇 2016-08-21
下一篇 2016-08-21

相关推荐

  • 浅谈Openssl与私有CA搭建

        随着网络技术的发展、internet的全球化,信息共享程度被进一步提高,各种基于互联网的应用如电子政务、电子商务日益增多并愈加被人们工作和生活依赖。但是,由于互联网的开放性和通用性,网络上的信息是对所有人公开的,这就使网络上的数据传输过程中存在被窃听、篡改等安全隐患,并极有可能给用户带来不可估量的损失。为此,各种保证数据在互联网上…

    Linux干货 2015-06-04
  • MySQL应用管理

    这篇文章主要讲述基本的SQL语句,以供新手参考使用,不过最好的办法还是查阅官方文档和help命令。 进入正题 什么是SQL?        SQL结构化查询语言,是关系型数据库查询和管理语言,是一种数据库查询和程序设计语言,用于存取数据以及查询,更新和管理关系型数据库系统。 SQL的分类 &nbsp…

    Linux干货 2015-09-23
  • 一键搭建mysql集群系列二

    mysql 5.7  主从复制 本节是在上一节的基础之上做的操作,上节我们通过脚本实现了一键自动化安装mysql5.7,这次我们要在三台机器上部署msyql5.7,并实现主从复制,实现的宗旨是,能自动化,就尽量自动化,实在不能自动化,那就手工化 用的脚本和文件说明1.install_mysql.sh 自动化安装mysql脚本2.ntpdate.sh 时间同步…

    2017-05-21
  • 利用 yum 查找某个命令属于哪个包

    当我们在安装一个不熟悉的命令是,会遇到个问题:Error: Nothing to do 而你又不知道该命令的是属于哪个rom包,莫慌~我们可以借助一个叫yum的基于rpm的软件包管理器。 以 dig 这个命令为例,当我安装它时会出现如下情况  [root@localhost ~]# yum install dig  Loaded plug…

    Linux干货 2016-03-27
  • Linux系统shell脚本

                                          &n…

    系统运维 2016-09-01
  • linux中用户、组和权限认识

    linux中用户、组和权限认识 Linux 用户和组的主要配置文件:/etc/passwd :用户及其属性信息( 名称、UID 、主组ID 等)                  …

    Linux干货 2017-02-23

评论列表(1条)

  • 马哥教育
    马哥教育 2016-08-21 20:59

    对当天所学的东西总结的很全面,对于脚本而言需要我们多写,多看优秀代码,yum源的配置是基本能力,同时rpm包管理器中查询语句是我们能平常用挺多的,需要多加练习。