Linux作为一个强大且开放式的操作系统,被越来越多的人进行研究和使用。作为Linux系统下不可或缺的一部分,Shell作为交互式的命令解释器,为用户提供了执行命令、调用程序的接口,为系统管理增加便利性。而Shell脚本,就是一系列按照一定顺序排列的Shell命令,能够完成多样的复杂操作。本文将会介绍如何在Linux下打造高效可靠的Shell脚本。
1. 程序设计原则
在开发Shell脚本时,遵循良好的程序设计原则是至关重要的。这里我们提到的原则包括:
1.1. 模块化的编程思想
Shell脚本由多个命令组成,这些命令又可以组成更复杂的命令,这是一种简单但很强大的编程思想。在Shell脚本中,将多个命令封装成函数,可以使代码更加可复用、可维护、可扩展。
1.2. 兯用DRY原则
DRY(Don’t Repeat Yourself)原则是指在设计系统时,应该避免出现重复的、相同的代码。在Shell脚本中,可以通过编写函数和库来实现DRY原则,这样可以让代码更简洁、更容易维护。
1.3. 健壮的脚本也需有良好的错误处理
任何程序都存在错误的可能性,我们的脚本也不例外。在Shell脚本中,应该添加足够多的错误处理代码,例如提示信息、错误信息、日志记录等,以避免程序出错后无法恢复或维护的尴尬境地。
2. 常见的Linux命令
Linux下有很多强大的命令可以使得Shell脚本更加富有表现力,常用的命令包括:
2.1. 命令行参数与参数管理
在编写脚本时,常常需要从命令行中获取选项和参数。这时可以使用命令行参数和参数管理相关的命令,例如getopt和shift。
2.2. 命令在当前Shell环境执行
在Shell脚本中调用命令时,可以使用source命令使命令在当前Shell环境中执行。这样可以让命令的环境变量、函数等被当前Shell环境所使用,实现Shell脚本与命令的交互。
2.3. 命令与文件操作
可以使用Linux命令来实现文件的操作,例如cp、mv、rm、echo、cat、sed等。
2.4. 常见的系统命令
在Shell脚本中,常常需要获取系统信息,例如系统版本、CPU架构、网络参数等。在这里,可以使用uname命令、grep命令、ip命令等来获取这些信息。
2.5. 正则表达式
正则表达式是一种强大的文本匹配工具,可以理解为文本模式的描述语言。在Shell脚本中,可以使用正则表达式来匹配制定的文本,实现一些复杂的文本处理功能。
3. Shell脚本的建设工具
提高Shell脚本编写效率的一个重要条件是建设工具的高效利用。这里介绍一下两个Shell脚本的建设工具:
3.1. ShellCheck
ShellCheck是一个静态分析工具,可以检查Shell脚本中的错误、不安全、冗余或风格不合理的代码。它能够根据Shell脚本中使用的命令和语法规则,检查编码规范是否符合一定标准。如果Shell脚本中存在错误或不规范的语法,ShellCheck会给出相应的提示,以便修复代码中的问题。
Bash是一个Shell脚本解释器,可以执行Shell脚本并且提供在命令行下交互式输入和输出的环境。它支持函数和变量,可以实现逻辑分支和循环等基本结构。Bash语言可以让Shell脚本的编写更容易理解和维护,更加模块化和可扩展。
4. Shell脚本的编写实践

通过前面的介绍可以看出Shell脚本编写需要注意很多细节,下面以一个简单的计算器为例,介绍一下Shell脚本的编写实践:
#!/bin/bash
# 函数:计算加法
calc_add() {
echo $(($1+$2))
# 函数:计算减法
calc_sub() {
echo $(($1-$2))
# 函数:计算乘法
calc_mul() {
echo $(($1*$2))
# 函数:计算除法
calc_div() {
echo $(($1/$2))
# 主函数
case “$1” in
calc_add $2 $3
calc_sub $2 $3
calc_mul $2 $3
calc_div $2 $3
echo “Usage: $0 {add|sub|mul|div} num1 num2”
4.1. 函数的使用
在Shell脚本中,将相同行为封装成函数非常容易理解和维护,因此建议在Shell脚本中大量使用函数。在这个示例中,使用了4个函数分别计算加、减、乘、除,并用主函数根据用户输入选择相应的函数进行计算。这样的设计对于更复杂的脚本尤为重要。
4.2. 参数的获取
在这个示例中,通过”$1″来获取命令行参数,并通过case语句进行处理。获取命令行参数的另一个方法是使用getopt命令,它可以解析和操作命令行选项和参数。
4.3. 错误处理
在这个示例中,如果用户没有按照正确的格式输入命令,则执行”echo”语句,显示用法信息,并返回错误码1。在更复杂的Shell脚本中,可以使用更多的错误处理方法,以更好地处理不同的错误情况。
5. 结语
Shell脚本设计需要考虑到很多方面,例如编程思想、命令的选择、编程风格、错误处理等。只有在良好的设计和实践的基础上,我们才能打造高效可靠的Shell脚本。
相关问题拓展阅读:
Linux 脚本 sh 和 ./ 的区别
如果.不在PATH里面,要执行当前目录下的可执行文件,使用全路径:
./executable-file
如果要执行一个sh脚本,不管那个脚本有没有可执行权限,都可以使用:
这时file是作为参数传给sh的禅州耐,如果file不在当前目录下迹尺,也需要使用全路径。
全路径有绝对路径和相对路贺春径两种。./和../开头的都是相对路径,分别表示”在当前目录下”和”在父目录下”。
区别只有一点:
sh表示脚本默认使用sh脚本解释器。
未指定脚本解释器默认为 ./。
具体解释:
使用“./”执行脚本,对应的xxx.sh脚本必须要有执行权限。
使用“sh” 执行脚本,对应的xxx.sh没有执行权限,亦可执行。敬答源
当脚本开头使用#!设置使用的shell类型时,使用“./”执行脚本时,则使用“#!”标志的shell执行脚本;若无使用“#!”标记,则使用系统设置的默认shell执行脚本。
扩展资料:
举例:亮态
登录用户root查看权限:
-rwx—— 1 root root
执行这举隐个shell脚本 :
./test 成功。
sh test 成功。
去掉执行权限x:
-rw——- 1 root root 23:33 test
执行这个shell脚本。
./test 失败 (-bash: ./test: Permission denied)。
sh test 成功。
楼上回答对的还是蛮好的
Linux 脚本 sh 和 ./ 的区别
linux执行脚本都是.sh的,和windows的.bat批处理脚本一个意思。你问的具体是什么?
如果.不在PATH里面,要执行当前目录下的可执行文件,使用全路径:
./executable-file
如果要执行一个sh脚本,不管那个脚本有没有可执禅州耐贺春行权限,都可以使用:
这时file是作为参数传给sh的,如果file不在当前目录下,也需要使用全路径。
关于linux下sh的介绍到此就结束了,不知道你从中找到你需要的信息了吗 ?如果你还想了解更多这方面的信息,记得收藏关注本站。
香港服务器首选树叶云,2H2G首月10元开通。树叶云(shuyeidc.com)提供简单好用,价格厚道的香港/美国云 服务器 和独立服务器。IDC+ISP+ICP资质。ARIN和APNIC会员。成熟技术团队15年行业经验。
创建一个Script,Linux shell脚本
和C语言类似,在Shell中用if、then、elif、else、fi这几条命令实现分支控制。 这种流程控制语句本质上也是由若干条Shell命令组成的,例如先前讲过的if [ -f ~/ ]; then ~/ fi其实是三条命令,if [ -f ~/]是第一条,then .~/是第二条,fi是第三条。 如果两条命令写在同一行则需要用;号隔开,一行只写一条命令就不需要写;号了,另外,then后面有换行,但这条命令没写完,Shell会自动续行,把下一行接在then后面当作一条命令处理。 和[命令一样,要注意命令和各参数之间必须用空格隔开。 if命令的参数组成一条子命令,如果该子命令的Exit Status为0(表示真),则执行then后面的子命令,如果Exit Status非0(表示假),则执行elif、else或者fi后面的子命令。 if后面的子命令通常是测试命令,但也可以是其它命令。 Shell脚本没有{}括号,所以用fi表示if语句块的结束。 见下例:#! /bin/shif [ -f /bin/bash ] then echo /bin/bash is a file else echo /bin/bash is NOT a file fi if :; then echo always true; fi:是一个特殊的命令,称为空命令,该命令不做任何事,但Exit Status总是真。 此外,也可以执行/bin/true或/bin/false得到真或假的Exit Status。 再看一个例子:#! /bin/sh echo Is it morning? Please answer yes or no. read YES_OR_NO if [ $YES_OR_NO = yes ]; then echo Good morning! elif [ $YES_OR_NO = no ]; then echo Good afternoon! else echo Sorry, $YES_OR_NO not recognized. Enter yes or no. exit 1 fi exit 0上例中的read命令的作用是等待用户输入一行字符串,将该字符串存到一个Shell变量中。 此外,Shell还提供了&&和||语法,和C语言类似,具有Short-circuit特性,很多Shell脚本喜欢写成这样:test $(whoami) != root && (echo you are using a non-privileged account; exit 1)&&相当于逗...地,而||相当于逗if ...地。 &&和||用于连接两个命令,而上面讲的-a和-o仅用于在测试表达式中连接两个测试条件,要注意它们的区别,例如,test $VAR -gt 1 -a $VAR -lt 3和以下写法是等价的test $VAR -gt 1 && test $VAR -lt 3
Linux下如何像windows下那样制作批处理文件?就是执行一批shell命令或可执行文件
csh, bash, 不管什么shell都可以把代码写成文件再执行,比windows的批处理功能强得多, 因而叫shell脚本程序而不是批处理文件了。 你可以把shell脚本保存为文件, 第一行用#!/bin/[shell name]来说明执行所用的shell,然后以防万一用chmod +x ***来给文件可执行权限, 然后./***来执行就好了。 shell脚本编程比bat文件复杂得多,你可以参考相关书籍。
如何利用linux系统去破解软件的应用?
使用Linux操作系统,装完系统后就是装各种常用软件了。 Linux系统集成了很多软件,可是对于一些习惯了的windows文件兼容性不太好,所以还是要下一些比较全面的软件或代替或补充。 Linux下安装软件感觉很复杂,一种软件包就有一种安装方法,不象windows找到就万事大吉了,而且不少软件都要很复杂的编译、配置,感觉头很大,这几天我唯一的工作就是不停的下载、安装。 虽然开源是件很诱惑的事,可是感觉没有windows的标准化的确大大削弱了linux的市场。 把这几天用过的一些安装方法总结一下吧,以备日后。 一、rpm包 是Redhat提供的一种已经编译过的包封的安装装格式。 一般使用rpm命令直接执行安装,比较简单。 常用的格式是: rpm -ivh <文件名> (-i是安装,-v是校验,-h是显示安装进度) 卸载同样也是一条命令就完成了: rpm -e <软件名> 这里的软件名跟rpm包的文件名不一样,通常不包括软件版本号,可以通过rpm命令先查看已安装的rpm软件包,再卸载列表中的软件。 二、deb包 它是Debain Linux提供的一种已经编译过的包封的安装装格式。 安装方法跟rpm 类似。 dpkg -i dpkg -e <软件名> 三、tar包 这种安装包是Unix下tar工具的压缩包,有时经过2次会在后面加上2、等扩展名。 这种包多数都提供源代码,开放性最好(可以选择甚至修改模块,也不局限于某个发行版本)但安装和卸载也最多问题。 一般安装tar包的步骤如下: 1:解压压缩包——tar -xvzf 压缩包名 或者 tar -xvzf 压缩包名(-z是调用gzip解压,-x是解压,-v是校验,-f是显示文件结果,-y是调用bzip2解压) 2:配置安装选项——./configure,一般用prefix参数配置安装路径,其他的参数也很有用。 3:编译安装文件——make。 4:安装——make install 5:清除安装产生的临时文件——make clean 有些软件不完全遵循这个步骤,(比如luma qq解压后直接./lumaqq就能运行,有点象windows的绿色软件)如果英文过关最好是阅读压缩包里的intall文件或者readme文件。 一般来说,安装后的可执行文件会存放在/usr/local/bin目录下,但也不是唯一的,还是要仔细阅读这两个文件。 卸载tar包可以进入安装目录执行make uninstall ,如果软件不提供uninstall,就必须手动rm -rf删除了,如果文件分散地安装在系统的多个目录中,除非安装时记住了所有路径,否则就很难清除干净了。 四、安装脚本 目前有些软件提供安装和卸载的SHELL脚本,只要运行甚至可以直接从网站下载软件一并安装到本地,同时运行就卸载该软件。 一些常用软件的安装和配置方法 linux找到一个适用的、完整的应用软件版本至关重要,这点我深有体会,我要安装的东西不多,但这几天就不停的各种版本来尝试,有些还会引起软件冲突,有些安装了发现没有传说中的功能又得下插件什么的。 linux的发行版本又多,各种体会和经验都是因人而异了。
发表评论