加入收藏 | 设为首页 | 会员中心 | 我要投稿 李大同 (https://www.lidatong.com.cn/)- 科技、建站、经验、云计算、5G、大数据,站长网!
当前位置: 首页 > 百科 > 正文

10.3函数及脚本的综合应用

发布时间:2020-12-14 02:06:59 所属栏目:百科 来源:网络整理
导读:函数及脚本的综合应用 一 shell函数 shell 函数: shell 允许将一组命令集或语句形成一个可用块,这些块称为 shell 函数 函数由两部分组成: 函数标题、函数体;标题 是函数名; 函数体 是函数内的命令集合;标题名应该唯一;如果不是,将会混淆结果,因为脚

函数及脚本的综合应用

一 shell函数

shell函数:shell允许将一组命令集或语句形成一个可用块,这些块称为shell函数

函数由两部分组成:函数标题、函数体;标题是函数名;函数体是函数内的命令集合;标题名应该唯一;如果不是,将会混淆结果,因为脚本在查看调用脚本前将首先搜索函数调用相应的shell

定义函数的格式为:

函数名(){

命令1

...

}

如果愿意,可在函数名前加上关键字function,这取决于使用者。

function函数名()

{

命令1

...

}

应用

例1:删除文件中的空行

这个脚本(脚本名为del.lines)可以处理一个或多个文件。每个文件在用sed删除空行之前要先核实是否存在。

sed的输出被导入一个文件名中含有$ $的临时文件,最后这个临时文件又被移回到原来的文件中。

该脚本使用shift命令取得所有的文件名,用while循环逐个处理所有的文件,直至处理完为止。可以使用del.lines --help获得一个简短的帮助

#!/bin/bash

TEMP_F="/tmp/del.lines.$$"

#定义函数

usage()

{

#提示脚本运行格式并查看帮助信息

echo "Usage:`basename $0` file [file...]"

echo "try `basename $0` -help for more info"

exit 1

}

#如果脚本后面的参数个数为0,即没有参数

if [ $# -eq 0 ]

then

#则提示函数里的内容

usage

fi

while [ $# -gt 0 ]

do

#提示正在执行的是位置1的参数

echo "...$1"

#如果位置1的参数时--help,则显示帮助信息

case $1 in

--help)

echo "Use this script to delete all blank lines from a text file(s)"

exit 0

;;

*)

FILE_NAME=$1

#判断位置1的文件是否存在

if [ -f $1 ]

then

#删除源文件内的空行(不是空格键的空行),并生成新的文件

sed '/^$/d' $FILE_NAME > $TEMP_F

mv $TEMP_F $FILE_NAME

else

echo "$0 cannot find this file: $1"

fi

#将 $1~$9 依次向左传递

shift

;;

esac

done

保存后给脚本文件增加执行权限:chmod +x del.lines

执行脚本进行测试:

注:

1、basename命令能够从路径中分离出文件名。通常用于shell脚本中

2、shift语句用于迁移位置变量,将 $1~$9 依次向左传递

例如,若当前脚本程序获得的位置变量如下:

$1=file1、$2=file2、$3=file3、$4=file4

则执行一次shift命令后,各位置变量为:

$1=file2、$2=file3、$3=file4

再次执行shift命令后,各位置变量为:

$1=file3、$2=file4

例2:如果某些日志文件超过了特定的长度(如8K),那么它的内容将被倒换到另一个文件中,并清除原有文件中的内容.

系统中的有些日志文件增长十分迅速,每天手工检查这些日志文件的长度并倒换这些日志文件(通常是给文件名加个时间戳)是非常乏味的。可以编写一个脚本来自动完成这项工作。该脚本将提交给cron进程来运行,如果某个日志文件超过了特定的长度,那么它的内容将被倒换到另一个文件中,并清除原有文件中的内容。

该脚本中日志文件的长度限制是由变量BLOCK_LIMIT设定的。这一数字代表了块数目,在本例中是8(块大小默认为4K)。可以按照自己的需求把这一数字设得更高。所有要检查的日志文件名都保存在变量LOGS中。

这里使用了一个for循环来依次检查每一个日志文件,使用du命令来获取日志文件长度。

如果相应的文件长度大于BLOCK_LIMIT变量所规定的值,那么该文件将被拷贝到一个文件

名含有时间戳的文件中,原先的文件长度将被截断为0。

#!/bin/bash

BLOCK_LIMIT=8

MYDATE=$(date +%d%m)

#定义文件列表集合

LOGS="/var/log/maillog /var/log/messages"

for LOG_FILE in $LOGS

do

if [ -f $LOG_FILE ]

then

F_SIZE=$(du -a $LOG_FILE | awk '{print $1}')

else

echo "$0 connot find $LOG_FILE"

#文件不存在,直接不用执行下面的语句重新开始循环

continue

fi

if [ "$F_SIZE" -gt "$BLOCK_LIMIT" ]

then

cp $LOG_FILE $LOG_FILE$MYDATE

#清空原来的文件内容

>$LOG_FILE

fi

done

注:du 并不是显示文件的实际大小,而是显示文件所占用的 block 大小,默认linux系统分区的 block size 是4k,也就是说即使文件只有1个字节,也会占用4k. ls -l则是文件的实际大小

(编辑:李大同)

【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容!

    推荐文章
      热点阅读