关键词:
trade off、资源限制、人力、空间、时间
最近有幸参与到新的项目设计开发中,结合工程实践中的经验与教训发掘可从资源调配的角度来思考架构设计问题。
工程中的软件设计是什么?即在
资源有限的条件下,
控制成本并作出
资源整合效率最大化的配置的设计。
那么结合计算机系统可从以下几个关键点考虑:
1. 人力资源:现实生活中人力资源相比机器更为昂贵,比如你要付员工工资、开发维护系统需要耗费时间等等。
2. 计算资源:CPU,需分析需求中是否有大量的计算操作,以时间为衡量比如计算延迟。
3. 存储资源:内存、硬盘,分析需求的存储数据量。
思考模式一般如下:
1. 分析需求,得出几种方案
2. 分析消耗成本:
硬件资源、人力资源,一般能通过扩展机器的情况下尽可能不是耗费人力成本。在机器扩充中需从垂直扩展(替换更好的硬件)和横向扩展(增加机器节点数)两个维度思考问题,横向扩展有可能带来两方面的成本(1. 系统复杂度提升 2. 增加人力成本维护多台机器)
3. 在把成本控制在一定范围内选择最优的方案