在开始任何自动化工作之前,要先执行一个最佳实践方法:检查现有的遗留基础架构和软件,确定是否有一些东西需要删除或整合。系统越简单,未优化和未自动化的代码中所要做的重复工作越少,自动化项目所能产生的结果就越好。
例如,我们可能会发现一些过度设计且混乱的遗留应用程序,它包含了50多种软件组件和3种不同的数据库,而其目的却仅仅只是为了记录用户的网站访问。一定不要自动化这些千丝万缕的人工操作,它们很可能只是为了维护这个系统而存在的,我们最好先将这种系统替换为个“部分符合”的系统,而不要随意堆砌适配器,因为它们本身可能以后会需要大量的自动化处理。变化的部分越多,出错的机率也越大,所以要先弄清楚现有基础架构的各个部分是如何协作的,然后再尝试添加此自动化技术。
自动化系统是那些超复杂软件、代码、系统和流程的优秀反馈机制。在尝试实现自动化软件安装、部署或配置时,经常会有工程师提出疑问“我真的需要使用它吗?”在大多数时候,这个问题的答案很可能是否定的。因此,可以将它从整个系统删除一作为一个普遍原则,减少需要维护和跟踪的东西,就可以提升性能,减少成本和错误,也可以简化工程师的工作及其所支持的网站和业务。