回忆曾经写过的第一个Bash脚本

这盘文章,算是杂谈吧,想谈谈我对于Linux操作系统的灵魂之笔 Bash的理解。

 据说Shell脚本有50种之多(陈皓老师的酷壳网上有一篇博文 http://coolshell.cn/articles/8619.html 提到),现在,用Linux调试大大小小程序,除了使用Makefile,偶尔用用CMakeList.txt, 更多程序是用bash 脚本来实现半自动化调试,就像在VS下面,每次修改重新编译一样,你总是 gcc 或者 g++,然后 ./test 运行,然后再看看有没有错,编译出错又得修改, rm -rf test, 很是繁琐,如果 一个小巧的脚本 test.sh 即可搞定:

#!/bin/bash

gcc -o test -g test.c

if [ -e test ];then
   ./test
   rm test
fi


这样,你只要每次执行脚本  sh test.sh 即可调试程序,如果出错直接vim 或 gedit 修改即可。


关于更直白的应用,可参见我之前写的一篇文章,上面有 Shell脚本,Makefile在Linux环境下安装编译和调试程序的示例,诚然,你用gdb调试 那是更深入的话题了。


啰嗦了这么多,还是切入主题吧,即我当年在工作中的第一个使用的脚本,即将主板上系统中的相关文件进行解压更新,亦或是系统的版本更新,但这个第一次使用的Shell脚本存在很多不足之处

1. 缺乏必要的脚本使用说明部分,如输入命令 sh test.sh, 若是需要参数,就需要加入必要的判断:

if [ $# -ne 1 ];then  

   echo "Usage: ......"

fi


2. 变量名风格不统一,按照我现在的思维,目录的变量名最好都大写,而其他变量名小写,不过最好是单词

 

3. 没有命令执行错误 输出到log 的习惯,其实在一些重要命令 执行后,加上 >error.log  2>&1 可以帮助分析,也可以写个脚本来对error.log 进行自动化分析。


总之能,本篇杂谈也就是感慨一下第一个用于工作的脚本是多么的拙劣,不过,人总是在进步,所以 生活也因勤奋好学而精彩~


共勉!!!


#! /bin/bash
# By GuJinjin
# 2010/08/11

# Define Path Variables
cm_DIR=/export/bta/canmore
fs_DIR=/export/bta/canmore/fsroot
host_DIR=/export/host
sdks_DIR=/mnt/bta/sdks

# define variable
b1=cm
b2=sdv
b3=gvl

# cleanup fsroot
rm -rf $fs_DIR/*


# Update fsroot 
# $1 is the name of archive
# $2 is the build number
tar -zxvf $host_DIR/$1 -C $fs_DIR/


# Update oflash
cp -rf $sdks_DIR/oflash $fs_DIR/
echo "********** cp oflash successfully ! **********"


# Update redboot_flash_nor.bin or redboot.bin
if [ -e $sdks_DIR/$2/redboot_flash_nor.bin ];then
	cp -rf $sdks_DIR/$2/redboot_flash_nor.bin $fs_DIR
	echo "********** cp redboot_flash_nor.bin successfully ! ********** "

elif [ -e $sdks_DIR/$2/redboot.bin ];then
	cp $sdks_DIR/$2/redboot.bin $fs_DIR/redboot_flash_nor.bin
	echo "********** cp redboot.bin successfully ! ********** "
else 
	echo "********** ERROR ! ********** No such a related file! ********** "
fi



# Update cefdk,config for cm, sdv & gvl
if [ "$3" = "$b1" ];then
	cp -rf $sdks_DIR/conf.canmore $fs_DIR/
	cp -rf $sdks_DIR/$2/gen3.bin $fs_DIR
	echo "********** cp conf.canmore successfully ! ********** "

elif [ "$3" = "$b2" ];then	
	cp -rf $sdks_DIR/conf.sodaville $fs_DIR
	cp -rf $sdks_DIR/$2/gen4.bin $fs_DIR
	echo "********** cp conf.sodaville successfully ! ********** "

elif [ "$3" = "$b3" ];then
	cp -rf $sdks_DIR/conf.groveland $fs_DIR/
	cp -rf $sdks_DIR/$2/gen4.5.bin $fs_DIR
	echo "********** cp conf.groveland successfully ! ********** "

else 
	echo  "********** Error Input parameters ! **********"
fi


# Update 101,102,103 for sdv or cm
if [ "$4" = "3" ];then
	cp -rf $sdks_DIR/$2/bzImage /tftpboot/101
	cp -rf $sdks_DIR/$2/bzImage /tftpboot/102
	cp -rf $sdks_DIR/$2/bzImage /tftpboot/103

	rm -rf $cm_DIR/fsroot10*
	cp -rf $cm_DIR/fsroot $cm_DIR/fsroot101
      cp -rf $cm_DIR/fsroot $cm_DIR/fsroot102
      cp -rf $cm_DIR/fsroot $cm_DIR/fsroot103
	echo "********** cp bzImage fsroot10* for 101,102,103 successfully ! **********"

elif [ "$4" = "2" ];then

      cp -rf $sdks_DIR/$2/bzImage /tftpboot/101
      cp -rf $sdks_DIR/$2/bzImage /tftpboot/102

	rm -rf $cm_DIR/fsroot101
	rm -rf $cm_DIR/fsroot102
      cp -rf $cm_DIR/fsroot $cm_DIR/fsroot101
      cp -rf $cm_DIR/fsroot $cm_DIR/fsroot102
	echo "********** cp bzImage fsroot10* for 101,102 successfully ! **********"

elif [ "$4" = "1" ];then

      cp -rf $sdks_DIR/$2/bzImage /tftpboot/103

	rm -rf $cm_DIR/fsroot103    
	cp -rf $cm_DIR/fsroot $cm_DIR/fsroot103
	echo "*********** cp bzImage fsroot10* for 103 successfully ! **********"

else
        echo  "********** Error Input parameters ! **********"
fi


echo "******************** Completed ! ********************"




  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
### 回答1: 我会尝试用bash脚本来实现以下步骤: 1. 创建一个变量,用来保存用户输入的值; 2. 使用if语句来检查用户输入的值是否正确; 3. 使用case语句来处理不同的用户输入; 4. 使用循环(for,while,until)来处理不断变化的用户输入; 5. 利用函数来封装代码,使代码更加灵活可操作; 6. 利用数组来存储用户输入的值,并利用for循环来处理; 7. 利用指针来实现数组的动态管理; 8. 利用文本处理命令(grep,sed,awk)来对文本数据进行处理; 9. 利用正则表达式来匹配搜索字符串; 10. 利用curl命令来发送http请求,并读取响应结果。 ### 回答2: 如要写一个复杂的bash脚本,可以考虑以下示例: #!/bin/bash # 获取输入参数并验证 if [[ $# -ne 3 ]]; then echo "Usage: script.sh [parameter1] [parameter2] [parameter3]" exit 1 fi # 定义变量 param1=$1 param2=$2 param3=$3 # 执行逻辑 echo "脚本开始运行..." # 根据参数1的值执行不同的操作 case $param1 in "option1") echo "选项1被选择" # 执行相关操作 ;; "option2") echo "选项2被选择" # 执行相关操作 ;; *) echo "无效的选项" exit 1 ;; esac # 根据参数2的值执行不同的操作 if [[ $param2 -gt 10 ]]; then echo "参数2大于10" else echo "参数2小于等于10" fi # 根据参数3的值循环执行某个操作 echo "开始循环操作..." for ((i=1; i<=$param3; i++)); do echo "第 $i 次循环操作" # 执行循环操作 done echo "脚本运行结束。" 这个脚本具有以下功能: - 验证脚本输入参数的数量是否正确。 - 接受3个输入参数,并将其分配给bash变量。 - 使用case语句根据参数1的值执行不同的操作。 - 使用条件语句判断参数2的大小,并输出相应的信息。 - 使用循环语句根据参数3的值循环执行某个操作。 - 输出脚本的运行开始和结束信息。 当然,具体复杂的脚本可以根据实际需求进行修改和扩展。 ### 回答3: 复杂的Bash脚本的设计可以根据实际需求和场景来进行,我在这里给出一个示例: #!/bin/bash # 这个脚本用于统计指定目录下文件的数量和总大小,并将结果输出到指定的日志文件 # 设置要统计的目录和输出日志文件路径 directory="/path/to/directory" logfile="/path/to/logfile.log" # 创建一个函数用于计算文件数量和总大小 calculate_stats() { local count=0 local total_size=0 local filename # 使用find命令遍历目录下的所有文件,并进行计数和大小总计 while IFS= read -rd '' filename; do if [[ ! -d "$filename" ]]; then ((count++)) size=$(du -bs "$filename" | cut -f1) ((total_size+=size)) fi done < <(find "$directory" -type f -print0) # 输出统计结果到日志文件 echo "$(date +%Y-%m-%d %H:%M:%S) - Found $count files with a total size of $total_size bytes" >> "$logfile" } # 调用函数计算统计结果 calculate_stats 这个示例脚本实现了以下功能: 1. 设置要统计的目录和输出日志文件路径。 2. 定义了一个名为"calculate_stats"的函数用于计算文件数量和总大小。 3. 在函数内部使用了find命令遍历指定目录下所有文件,并对文件数量和总大小进行计算。 4. 使用echo命令将统计结果以时间戳的形式输出到指定的日志文件。 请注意,这只是一个简单的示例脚本,真实的复杂脚本可能包含更多的功能和逻辑。编写复杂的Bash脚本需要有一定的编程知识和经验。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值