大多数主要的网络中断发生是由于人为错误而不是设备故障而发生的,而不是设置本身的步骤,序列中错过的步骤,取消订单的步骤等。通过脚本进行自动化不仅是为了加快网络操作活动的速度,还意味着,重要的是,通过确保一致性来减少此类错误的机会。脚本每次以相同的顺序执行相同的步骤。
当然,临时,脚本或程序化自动化并不能消除错误的可能性。它确实将错误的范围限制在程序本身上,并且在有机会投入生产之前,强大的测试应发现大多数错误。而且,如果一个错误通过并导致一堆错误的配置开关,有一个可以修复它的地方 - 脚本 - 还提供了在机器速度下纠正问题的方法。
当然,这意味着有测试,并且有一个地方可以解决错误,即脚本的单个权威版本。这些东西不是自动的。它们是故意过程选择的结果,尤其是决定正确管理管理网络的自动化的决定。
网络自动化是生产软件
为网络进行临时自动化的网络管理员以与开发面向用户的应用程序相同的重要方式成为开发人员。鉴于这一点,可以合理地决定网络自动机应遵循某些相同的良好实践,以管理其程序与应用程序开发人员所关注的程序:网络管理脚本的代码管理;用于生产环境中使用的网络脚本的更改管理;正确注释程序或脚本的工作以及如何做;以及用于命名程序,过程,配置文件,变量等的编程标准。
代码管理
至少,代码管理意味着在添加新版本时具有单一的权威代码和机制来源。它应该支持签出代码,以便每个人都知道正在开发的内容以及通过谁和签到来维护使用代码的问责制。如果发现一个错误或一个管理员很难理解另一个管理员的代码在做什么,知道谁创建或最后修改是一个巨大的优势。
更换管理层
可以通过变更管理来增强代码管理的可靠性和问责制。当对生产脚本的新版本进行测试之前,按照良好的更改管理过程以及事先宣布新脚本的部署时,企业网络将遭受脚本驱动的错误。变更管理最佳实践还包括制定计划,如果新版本未能按预期执行,则可以将其返回到代码的先前版本,再次将由于错误而导致的破坏最小化。
注解
这对某些人来说似乎很容易,但是注释是基本的良好编程实践,在整个时间和大型团队环境中的好处远非微不足道。当网络代码库深入多年或有很多人使用并为此做出贡献时,很可能会有重要的脚本在最近的记忆中仔细检查。即使是原始作者,如果仍在那里工作,也将在没有一些指导的情况下很难理解它们。将注释放入代码中以解释它应该做的事情,并在某种程度上如何做到这一点,增加了原始作者以外的其他人可以正确使用它,需要进行调试并扩展或修改的几率该程序的行为随需改变。它还增加了原始作者,如果在远离它的时间后返回代码,它将记住它的目的以及为什么它以其方式构建。
编码标准
像注释一样,编码标准使代码更具可读性,从而使代码更普遍地有用和可维护。如果变量是有意义的,并且以某种一致的格式命名,并且函数或子例程以类似一致的方式命名,则一组同事将能够更轻松,更可靠地使用和维护代码库。游戏的名称是避免创建“一次写”代码,并构建一个充满死亡和垂死的代码的存储库,如果条件或需求更改,则需要从头开始重写。取而代之的是,建立一个可能需要使用它的人很容易理解的可持续生命代码基础。
正确管理管理网络的代码是组织以自动化其网络环境的组织的关键纪律。良好的做法减少了错误的机会和错误变为主要中断的机会。