服务器自动化管理脚本语言选择, Python or Shell

2022-07-26 20:42:20 +08:00
 Weiney

运维小弟入职了新公司, 目前运维的相关业务都是在蓝鲸运维平台开展, 不可避免的要开发脚本来实现运维的相关业务, 这方面还比较生疏, 有些疑惑抛出来大家一起探讨下.

蓝鲸的作业平台是同时支持 shell 和 Python, 但是到底用什么来输出业务脚本着实让本人很纠结.

Shell 的优势不可超越, 轻量、原生、无运行环境要求, 但是个人而言 Shell 的熟练度确实不如 Python. 并且在输出应用于生产环境的脚本时, 往往需要进行繁琐的参数校验, Shell 进行这方面的工作着实比较费力, 并且在某些场景如果入参类型出错, 脚本的流程判断可能就 GG, 导致流程异常. 平时使用下来发现有些东西确实很鬼扯.

Python 的脚本有运行环境的限制, Python 版本限制, 并且有些操作还是需要调用 shell, 不原生且不优雅, 但是个人觉得语法更加规范, 不容易藏坑, 且相关逻辑实现能更加优雅, 即便是只调用系统包就能能满足日常使用.

就我而言, 目前用到的所有机器都默认安装了 Python, 所以不考虑容器环境没有 Python 的情况, 是不是就能使用 Python 替代 Shell 完成工作脚本的输出?

欢迎大家补充讨论, 同时让我知道在类似场景大家公司是如何选择的, 谢谢

1976 次点击
所在节点    程序员
13 条回复
flexbug
2022-07-26 21:12:42 +08:00
我选择用 ansible ,jenkins ,spug 等等
eason1874
2022-07-26 21:13:49 +08:00
python 最初的开发动机之一就是替代难用的 unix shell 来完成系统管理,二选一毫无疑问是 python 啊

你又不需要面对不确定的机器,你使用的系统全部支持 python 的话,没什么需要犹豫的
adekyou06
2022-07-26 21:15:40 +08:00
babashka
RangerWolf
2022-07-26 21:16:46 +08:00
python ,但是 shell 最好也会,因为有时候 awk 之类的工具真是太香了
adekyou06
2022-07-26 21:16:51 +08:00
懂点 clj ,把 bb 文件放 /usr/local/bin 就行了
billzhuang
2022-07-26 22:11:20 +08:00
ansible+ terraform
zlowly
2022-07-27 11:30:14 +08:00
两者应该都掌握。如果一个工作不能几行 shell 就搞定,那就上 python 。
如果你 shell 熟练,会发现很多事情 python 写一大段代码,也就是 shell 里跑几个命令用管道连接就搞定了。
yyttrr
2022-07-27 16:24:31 +08:00
shell + go
ciki
2022-07-27 17:01:43 +08:00
混合用的
461da73c
2022-07-27 17:45:01 +08:00
shell + go ,python 还是算了,容易写出屎山。
Weiney
2022-07-27 19:23:55 +08:00
@zlowly 这个不能更赞同了
Weiney
2022-07-27 19:32:01 +08:00
@461da73c shell + go, 用 Go 执行二进制确实也挺方便, 之前有用过

今天试了下用 Python 写脚本, 感觉确实是 shell + python, 整的有点苦恼, 还要担心引用的系统包版本问题, 最后还是用 shell 实现了, 后面应该不考虑 Python 了, 用 shell 或者用 Go 来实现了
Alliot
2022-07-27 21:23:40 +08:00
小孩子才做选择, 成年人: 我都要。

这是一个专为移动设备优化的页面(即为了让你能够在 Google 搜索结果里秒开这个页面),如果你希望参与 V2EX 社区的讨论,你可以继续到 V2EX 上打开本讨论主题的完整版本。

https://www.v2ex.com/t/868884

V2EX 是创意工作者们的社区,是一个分享自己正在做的有趣事物、交流想法,可以遇见新朋友甚至新机会的地方。

V2EX is a community of developers, designers and creative people.

© 2021 V2EX