我最终还是决定放弃Shell,转而使用Python。这是为什么呢?来看看这篇博文,和我一起讨论吧!
作为一名职业程序员,我有多年编写Shell脚本的经验。你可能现在跟我面临着类似的情况。在Shell取得的成就,我倍感珍惜,哪怕是现在,我依然如此。但是我最终还是做出一个决定——放弃Shell,拥抱Python。
这是为什么呢?看看这篇博文,和我一起讨论吧。
真的很难拒绝Shell的诱惑,Shell是一种非常古老的语言,使用广泛,但它跟不上现代编程的步伐。它糟糕的语言错误处理、奇怪的语法、没有重用代码的包机制——这样的例子不胜枚举……
1. Unix PIPE哲学使Shell成为默认的语言。它集成各种(相对)小的工具,解决更大的问题。因此,如果你现在查看任何流行的在线教程,你可能会在某个地方看到Shell脚本。
2. 有了Shell,你可以非常容易地开始动手并取得进展。你在终端中发出的每个Shell命令都能给你相应的回馈,它让你感觉你在不断的进步。
3. 没有额外的包装层。假设你需要通过编程触发一些索引操作,你可以直接通过Shell调用索引管理应用程序接口,也可以使用索引 Python SDK。如果你选择了用Python的方式,但是脚本不能正常工作,那原因是什么呢?可能是Python SDK中的一些bug,或者是使用Python SDK的方式,导致不能正确工作。但是,毫无疑问的是,人们有时喜欢使用Shell脚本。
朋友们,不管Shell有多少的优点,我们必须向前看,继续前进。
我选择Python作为所有自动运行的无人值守脚本的默认语言。然而,Shell仍还有空间,例如,我们可以快速打包一些命令并从终端手动执行它们。
首先,我选择的这门语言,它不一定是Python。它可以是任何你熟悉的现代编程语言,比如Ruby、Golang等等。
1. 跨项目重用代码和模块。经过多年的积累,我建立了一个shell公共库(GitHub)。用这个库,我可以轻松快速地完成许多DevOps任务——例如,在部署前执行预检查、通过Jenkins运行部署和维护等等。然而,分发并升级Shell脚本是一个相当大的负担。而用Python,我可以轻松地将逻辑打包为pip包。
2. 要编写像样、可靠的Shell脚本非常困难。你以为你是贝壳忍者?能够跟你的脚本对立运行Shellcheck?如果没有错误处理对应方法,你的脚本很容易出现错误。因此,它可能会导致严重的破坏或着让故障排除变得更加困难。
3. 简单的需求可能不容易得到Shell支持。例如,当你运行脚本时,你希望同时在终端和日志文件中看到输出结果。通过一些实践,你最终确定了tee命令的解决方案。但是,你又不得不处理这这种奇怪又棘手问题。
现在,我的Python之旅开始了。你的呢?
注意:我将在GitHub中保持DevOps Python脚本的开源。
翻译自英文文章:goodbye-shell-hello-python