脚本函数与程序包管理

一、函数调用

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

相关推荐

  • Linux基础知识(四)

    1、复制/etc/skel目录为/home/tuser1,要求/home/tuser1及其内部文件的属组和其它用户均没有任何访问权限 [root@bogon ~]# cp -r /etc/skel/ /home/tuser1 [root@bogon ~]# chmod -R 700 /home/tuser1 2、编辑/etc/group文件,添加组hadoo…

    Linux干货 2016-10-17
  • https搭建

    https             http over ssl = https 443/tcp                 ssl: v3           &nb…

    Linux干货 2016-06-28
  • date(时间),timedatectl(时区),cal(日历)的用法

    date+%F 显示日期,   显示格式如 2017-07-15+%T 显示时间    显示格式如 15:00:15+%Y 显示年      显示格式如 2017+%m 月 +%d 日+%H 时+%M 分+%S 秒+%s 从linux初始到现在经历了多少秒+%w 显示数字形式的星期+%a …

    Linux干货 2017-07-14
  • 自制linux和编译内核

    自制linux:(1)  分区并创建文件系统  fdisk /dev/sdb分两个必要的分区  /dev/sdb1 对应/boot /dev/sdb2 对应根  /mkfs.ext4 /dev/sdb1mkfs.ext4 /dev/sdb2  挂载bootmkdir /mnt/boot 子目录必须为bootm…

    Linux干货 2017-04-02
  • nl命令使用解析

    nl    命令功用: nl – number lines of files 显示文件内容,并列出行号   命令样式: nl [OPTION]… [FILE]…   命令选项: -b:正文行号,参数为样式style -n:行号格式,参数为格式format -w:设定行号所占位数,参数为…

    Linux干货 2016-10-20
  • 单引号,双引号,反引号的作用(首篇)

    哈哈哈!这是我的博客生涯的开始,也是我学习Linux的开始,所以我将励志成为一名老司机带你装X带你飞。 1.首先是三兄弟中的单引号,它的作用只是单纯的呈现出自己所包含的文字并不能执行其中的命令,所以它也是三兄弟中最笨的那个,作用单一,简单。 2,再来介绍介绍双引号,他的作用和单引号大同小异,它能包含单引号,反引号,以及除了执行以$和\的字符为首的函数能认识之…

    2017-07-11

评论列表(1条)

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

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