PRF&PUB:20170519 10 Useful Tips for Writing Effective Bash Scripts in Linux.md

@ch-cn
This commit is contained in:
wxy 2017-06-17 19:23:08 +08:00
parent c728ecb6bd
commit f375d33bc5

View File

@ -1,66 +1,71 @@
Linux 中编写有效的 Bash 脚本的 10 个有用技巧
Linux 中高效编写 Bash 脚本的 10 个技巧
============================================================
[Shell 脚本编程][4] 是你在 Linux 下学习或练习编程的最简单的方式。尤其对 [系统管理员要处理着自动化任务][5],且要开发新的简单的实用程序或工具等(这里只是仅举几例)更是必备技能。
本文中,我们将分享 10 个写出高效可靠的 bash 脚本的实用技巧,它们包括:
### 1\. 脚本中常用注释
### 1、 脚本中多写注释
这是不仅可应用于 shell 脚本程序中也可用在其他所有类型的编程中的一种推荐做法。在脚本中作注释能帮你或别人翻阅你的脚本了解脚本的不同部分所做的工作。
这是不仅可应用于 shell 脚本程序中也可用在其他所有类型的编程中的一种推荐做法。在脚本中作注释能帮你或别人翻阅你的脚本了解脚本的不同部分所做的工作。
对于刚入门的人来说,注释用 `#` 号来定义。
```
#TecMint 是浏览各类 Linux 文章的最佳站点
# TecMint 是浏览各类 Linux 文章的最佳站点
```
### 2\. 当运行失败时使脚本退出
### 2 当运行失败时使脚本退出
有时即使某些命令运行失败bash 可能继续去执行脚本,这样就影响到脚本的其余部分(会最终导致逻辑错误)。用下面的行的方式在遇到命令失败时来退出脚本执行:
```
#如果命令运行失败让脚本退出执行
# 如果命令运行失败让脚本退出执行
set -o errexit
#
set -e
```
### 3\. 当 Bash 用未声明变量时使脚本退出
### 3 当 Bash 用未声明变量时使脚本退出
Bash 也会尝试用会引起逻辑错误的未声明的脚本。因此用下面行的方式去通知 bash 当它尝试去用一个未声明变量时就退出脚本执行:
Bash 也可能会使用能导致起逻辑错误的未声明的变量。因此用下面行的方式去通知 bash 当它尝试去用一个未声明变量时就退出脚本执行:
```
#若有用未设置的变量即让脚本退出执行
# 若有用未设置的变量即让脚本退出执行
set -o nounset
#
set -u
```
### 4\. 使用双引号来引用变量
### 4 使用双引号来引用变量
当引用时(使用一个变量的值)用双引号有助于防止单词分割开(由于空白)和不必要的匹配(识别和扩展通配符)
当引用时(使用一个变量的值)用双引号有助于防止由于空格导致单词分割开和由于识别和扩展了通配符而导致的不必要匹配。
看看下面的例子:
```
#!/bin/bash
#若命令失败让脚本退出
# 若命令失败让脚本退出
set -o errexit
#若未设置的变量被使用让脚本退出
# 若未设置的变量被使用让脚本退出
set -o nounset
echo "Names without double quotes"
echo
names="Tecmint FOSSMint Linusay"
for name in $names; do
echo "$name"
echo "$name"
done
echo
echo "Names with double quotes"
echo
for name in "$names"; do
echo "$name"
echo "$name"
done
exit 0
```
@ -69,11 +74,12 @@ exit 0
```
$ ./names.sh
```
[![Use Double Quotes in Scripts](https://www.tecmint.com/wp-content/uploads/2017/05/Use-Double-Quotes-in-Scripts.png)][6]
在脚本中用双引号
[![Use Double Quotes in Scripts](https://www.tecmint.com/wp-content/uploads/2017/05/Use-Double-Quotes-in-Scripts.png)][6]
### 5\. 在脚本中使用函数
*在脚本中用双引号*
### 5、 在脚本中使用函数
除了非常小的脚本(只有几行代码),总是记得用函数来使代码模块化且使得脚本更可读和可重用。
@ -81,23 +87,23 @@ $ ./names.sh
```
function check_root(){
command1;
command2;
command1;
command2;
}
#
check_root(){
command1;
command2;
command1;
command2;
}
```
写成单行代码,每个命令后要用终止符号:
写成单行代码,每个命令后要用终止符号:
```
check_root(){ command1; command2; }
```
### 6\. 字符串比较时用 = 替换 ==
### 6、 字符串比较时用 `=` 而不是 `==`
注意 `==` 是 `=` 的同义词,因此仅用个单 `=` 来做字符串比较,例如:
@ -107,9 +113,9 @@ value2=”fossmint.com”
if [ "$value1" = "$value2" ]
```
### 7\. 用 $(command) 替换老旧的 command 来做代用
### 7、 用 `$(command)` 而不是老旧的 \`command` 来做代换
[Command substitution命令代换][7] 是用这个命令的输出结果取代命令本身。用 `$(command)` 而不是引号 ``command`` 来做命令代换。
[命令代换][7] 是用这个命令的输出结果取代命令本身。用 `$(command)` 而不是引号 \`command` 来做命令代换。
这种做法也是 [shellcheck tool][8] (可针对 shell 脚本显示警告和建议)所建议的。例如:
@ -118,7 +124,7 @@ user=`echo “$UID”`
user=$(echo “$UID”)
```
### 8\. 用 Read-only 来声明静态变量
### 8、 用 `readonly` 来声明静态变量
静态变量不会改变;它的值一旦在脚本中定义后不能被修改:
@ -127,25 +133,23 @@ readonly passwd_file=”/etc/passwd”
readonly group_file=”/etc/group”
```
### 9\. 环境变量用大写字母命名且自定义变量用小写
### 9、 环境变量用大写字母命名,而自定义变量用小写
所有的 bash 环境变量用大写字母去命名,因此用小写字母来命名你的自定义变量以避免变量名冲突:
```
#定义自定义变量用小写且环境变量用大写
# 定义自定义变量用小写,而环境变量用大写
nikto_file=”$HOME/Downloads/nikto-master/program/nikto.pl”
perl “$nikto_file” -h “$1”
```
### 10\. 总是对长脚本进行调试
### 10 总是对长脚本进行调试
如果你在写有数千行代码的 bash 脚本,排错可能变成噩梦。为了在脚本执行前易于修正一些错误,要进行一些调试。通过阅读下面给出的指南来掌握此技巧:
1. [如何在 Linux 中启用 Shell 脚本调试模式][1]
2. [如何在 Shell 脚本中执行语法检查调试模式][2]
3. [如何在 Shell 脚本中用 Shell Tracing 来跟踪命令的执行情况][3]
3. [如何在 Shell 脚本中跟踪调试命令的执行][3]
本文到这就结束了,你是否有一些其他更好的 bash 脚本编程经验想要分享?若是的话,在下面评论框分享出来吧。
@ -160,16 +164,16 @@ Aaron Kili 是一个 Linux 和 F.O.S.SFree and Open-Source Software自由
via: https://www.tecmint.com/useful-tips-for-writing-bash-scripts-in-linux/
作者:[ Aaron Kili][a]
作者:[Aaron Kili][a]
译者:[ch-cn](https://github.com/ch-cn)
校对:[校对者ID](https://github.com/校对者ID)
校对:[wxy](https://github.com/wxy)
本文由 [LCTT](https://github.com/LCTT/TranslateProject) 原创编译,[Linux中国](https://linux.cn/) 荣誉推出
[a]:https://www.tecmint.com/author/aaronkili/
[1]:https://www.tecmint.com/enable-shell-debug-mode-linux/
[2]:https://www.tecmint.com/check-syntax-in-shell-script/
[3]:https://www.tecmint.com/trace-shell-script-execution-in-linux/
[1]:https://linux.cn/article-8028-1.html
[2]:https://linux.cn/article-8045-1.html
[3]:https://linux.cn/article-8120-1.html
[4]:https://www.tecmint.com/category/bash-shell/
[5]:https://www.tecmint.com/using-shell-script-to-automate-linux-system-maintenance-tasks/
[6]:https://www.tecmint.com/wp-content/uploads/2017/05/Use-Double-Quotes-in-Scripts.png