共计 3281 个字符,预计需要花费 9 分钟才能阅读完成。
今天小编要跟大家分享的文章是关于 Linux 运维 人员应该知道的 Bash 实践经验。每个职业都有最常用的工具。对于许多系统管理员来说,shell 可能是比较熟悉的。在大多数 Linux 和其他类 Unix 系统上,默认的 shell 是 Bash。Linux 入门 新手和正在 Linux 学习 的小伙伴快来看一看吧,希望能够对大家有所帮助!
Bash 是一个相当古老的程序,它起源于 20 世纪 80 年代后期。但它建立在更多,更老的 shell 上,比如 C shell(csh)。我们来看看一些基础知识。
相信你在某些时候,曾无意中以 root 身份运行命令并导致某种问题? 这里有一些非常简单的技巧可以防止你遇到这样的问题。
1、使用别名
首先,为 mv 和 rm 等命令设置别名,指向 mv - I 和 rm -I。这将确保运行 rm -f/boot 至少要求你确认。在红帽企业版 Linux 中,如果你使用 root 帐户,则默认设置这些别名。
如果你还要为普通用户帐户设置这些别名,只需将这两行放入主目录中名为.bashrc 的文件中(这些也适用于 sudo):
alias mv=’mv -i’
alias rm=’rm -i’
2、你的根提示符
你可以采取的另一项措施是防止意外发生,确保你在使用 root 帐户时知道。我通常这样做是为了让我的正常日常工作中使用的提示能够很好地突出根提示符。
如果将以下内容放入 root 的主目录中的.bashrc 文件中,你将看到一个黑色的红色根提示符,清楚地表明你 (或其他任何人) 应该谨慎操作。
export PS1=”\[$(tput bold)$(tput setab 0)$(tput setaf 1)\]\u@\h:\w # \[$(tput sgr0)\]”
实际上,你应该尽可能避免以 root 用户身份登录,而是通过 sudo 运行大多数系统管理命令,但这是另一回事。
实施了一些小技巧来帮助防止使用 root 帐户的“无意的副作用”,让我们看看 Bash 可以给你你在日常工作中带来怎样的帮助?
控制 history 文件你可能知道,当在 Bash 中按向上箭头键时,你可以查看并重复使用以前的所有命令。这是因为这些命令已保存到主目录中名为.bash_history 的文件中。该历史文件附带了一组非常有用的设置和命令。
首先,你可以通过键入历史记录来查看整个最近的命令历史记录,或者你可以通过键入历史记录,或将其限制为最近 30 个命令。你可以更好地控制 Bash 保存的内容以及保存方式。
例如,如果将以下内容添加到.bashrc,则任何以空格开头的命令都不会保存到历史记录列表中:
HISTCONTROL=ignorespace
如果你需要用命令写入明文形式的密码。(是的,这太可怕了,但它仍然会发生。)
如果你不希望在历史记录中显示经常执行的命令,请使用:
HISTCONTROL=ignorespace:erasedups
这样,每次使用命令时,都会从历史记录文件中删除之前发生的所有事件,并且只将最后一次调用保存到历史记录列表中。
我特别喜欢的历史记录设置是 HISTTIMEFORMAT 设置。这将在历史记录文件中添加时间戳前的所有条目。例如,我使用:
HISTTIMEFORMAT=”%F %T“
当我输入五条历史记录时,我得到了很好的完整信息,如下所示:
1009 2018-06-11 22:34:38 cat /etc/hosts
1010 2018-06-11 22:34:40 echo $foo
1011 2018-06-11 22:34:42 echo $bar
1012 2018-06-11 22:34:44 ssh myhost
1013 2018-06-11 22:34:55 vim .bashrc
这使我更容易浏览我的命令历史记录,并找到我两天前用来建立到家中的 SSH 隧道。
最好的 Bash 实践
在编写 Bash 脚本时,我将用最好的 11 个用法列出来(我是这样认为的)。
1、Bash 脚本可能变得复杂,添加注释没那么复杂。因为如果你在周末之后回到工作中,不得不花时间搞清楚你上周五想要做什么的话,别忘了添加注释。
2、用花括号括起所有变量名,比如 {variable} _suffix 成为可能,并提高整个脚本的一致性。
3、评估表达式时不要使用反引号; 请改用 $()语法。可以使用:
for file in $(ls); do
反之:
for file in `ls`; do
前一个选项是可嵌套的,更易于阅读,并使一般的系统管理员感到满意。不要使用反引号。
4、一致性很好。选择一种风格并在整个脚本中坚持下去。显然,我更喜欢人们在反引号中选择 () 语法。可以使用:¨G6G 反之:¨G7G 前一个选项是可嵌套的,更易于阅读,并使一般的系统管理员感到满意。不要使用反引号。8. 一致性很好。选择一种风格并在整个脚本中坚持下去。显然,我更喜欢人们在反引号中选择 () 语法, 并将其变量放在在花括号中。
5、使用适当的 shebang 作为 Bash 脚本。因为我正在编写 Bash 脚本,只打算用 Bash 执行它们,所以我经常使用 #!/ usr / bin / bash 作为我的 shebang。不要使用 #!/ bin / sh 或 #!/ usr / bin / sh。你的脚本将执行,但它将以兼容模式运行。可能会产生许多意外的副作用。(当然,除非你想要兼容模式。)
6、比较字符串时,在 if 语句中引用变量是个好主意,因为如果你的变量是空的,Bash 会为这样的行抛出一个错误:
if [${myvar} ==“foo”]; then
echo“bar”
fi
对于这样的行,将评估为 false:
if [“${myvar}”==“foo”]; then
echo“bar”
fi
此外,如果你不确定变量的内容(例如,在解析用户输入时),请引用变量以防止解释某些特殊字符,并确保该变量被视为单个词,即使它包含空格。
7、更喜欢使用双等号(==),即使比较 Bash 中的字符串。这是一致性的问题,尽管,对于字符串比较,只有一个等号会起作用,我的考虑立即变为“单个等于是一个赋值运算符!”
8、使用适当的退出代码。确保如果你的脚本无法执行某些操作,则会向用户显示已写入的失败消息 (最好通过解决问题的方法) 并发送非零退出代码:
# we have failed
echo“Process has failed to complete, you need to manually restart the whatchamacallit”
exit 1
这样可以更容易地以编程方式从另一个脚本调用脚本并验证其成功完成。
9、使用 Bash 的内置机制为变量提供合理的默认值,或者如果未定义你希望定义的变量,则抛出错误:
# this sets the value of $myvar to redhat, and prints‘redhat’
echo ${myvar:=redhat}
# this throws an error reading‘The variable myvar is undefined, dear reader’if $myvar is undefined
${myvar:?The variable myvar is undefined, dear reader}
10、特别是如果你正在编写大型脚本,特别是如果你与其他脚本一起处理该大型脚本,请考虑在函数内部定义变量时使用 local 关键字。local 关键字将创建一个局部变量,该变量只在该函数中可见。这限制了冲突变量的可能性。
11、每个系统管理员有时必须这样做:在控制台上调试一些东西,可以是数据中心的真实服务器,也可以是虚拟化平台的虚拟服务器。如果你必须以这种方式调试脚本,你会感谢你自己记住这个:不要让你的脚本中的行太长!
在许多系统上,控制台的默认宽度仍为 80 个字符。如果你需要在控制台上调试脚本并且该脚本有很长的行,那么将是一个悲剧。此外,具有较短行的脚本,默认值仍为 80 个字符,在普通编辑器中也更容易阅读和理解!
以上就是小编今天为大家分享的关于 Linux 运维人员应该知道的 Bash 实践经验的文章,希望本篇文章能够对正在从事 Linux 相关工作的小伙伴们有所帮助。想要了解更多 Linux 相关知识记得关注 马哥教育 官网。
声明:文章来源于网络,侵删!