`
linxizeng
  • 浏览: 104795 次
  • 性别: Icon_minigender_1
  • 来自: 上海
社区版块
存档分类
最新评论

读 软件架构的十大错误 有感

阅读更多
转自:http://www.infoq.com/cn/news/2007/10/top-ten-architecture-mistakes
  1. 不能界定项目范围。“在这种情况发生时,一个简单的出差登记系统结果变成内建了完整的花费报销管理系统,项目费用、时间跨度和质量都留下不可避免的烂摊子……除了简单的登录真的不需要安全措施了?用户登录系统后真的不能够执行任何系统操作吗?”
    自己亲身体会过,应该是需求不明确带来的困扰,最后只能修修补补,推翻重来、重构,来不及了。
    需求一定要明确?可是,敏捷呢?敏捷不是一步一步迭代的吗?
    我想还是需要及时沟通。
  2. 网撒得不够宽。“我们都曾经犯过的一个错误是,只关注系统所有利益相关者中的一两方——通常受让人(为系统出钱的人)和最终用户得到了全部的关注。
    目前比较关注项目本身,关注进度,关注质量,偶尔关注成本(毕竟我现在没有这个责任)
  3. 只关注功能。“……除非系统表现出了全面的高质量(诸如性能、安全、可维护性等等),否则不太可能成功。”
    做项目关注功能好像是首要的,毕竟是客户可以看到的成果,(性能、安全、可维护什么时候关注比较好呢?)性能,在架构时考虑,写代码时优化。安全,如何策略?可维护,接口,抽象,设计模式?
  4. 用方框和线条来描述。“[一个无所不包的]巨大的Visio图无法成为有效的架构描述,有两个原因:第一,它试图在单一表示中呈现太多信息;第二,没人真正清楚地知道你画的各种符号到底表示什么意思。”
    UML?文档?用什么来描述?我们恰恰就是用Visio/UML+Excel+Doc
  5. 忘了需要培养的过程。“在建造系统的时候常常需要小心的事物包括:开发者和测试者没法真正理解设计,他们不热衷或者没时间学习技术,以及还没有很好的工具支持的新技术,或者新技术会强迫人们以新的不熟悉的方式工作。”
    有多少公司能做到?公司是工作的地方,有多少公司愿意给你时间?有多少公司有一个培养的计划?不要加班已经不错。如果在大公司,可能一直被挤压?如果在小公司,不要陷入项目已经谢天谢地,或这有时间,大家都是茫然的各干各的。
  6. 平台定义不精确。“光用‘需要Unix和Oracle’来描述你的平台是不足够的。你需要精确地说明每一部分具体的版本和配置,才能保证得到你所需的平台。不然如果有人好心为平台的某一部分升级了一个库,就可能导致某些东西停止运作。精确定义平台你才能在部署中避免这样的情形。”
    这个目前还没有碰到过,都是定义比较明确。如果想想开发时用的版本跟在客户部署时用版本不一样,万一客户是低版本的那可就惨了。
  7. 对性能和伸缩能力想当然。“及早开始考虑性能和伸缩性,构建性能模型尝试预测关键的性能指标并定位瓶颈,在设计逐渐成型的同时投入到一些实际的验证性工作中去。这会帮助你提高对设计中不存在严重性能和伸缩性缺陷的信心。”
    做项目的...好像都是做到具体模块才去想...
    做产品...做了一个失败的产品,没有考虑这个(当时好像仅仅考虑层次)
  8. 自己发明安全技术。“多 年来许多系统所犯的一个错误是试图加入自己发明的安全技术来提高系统安全性。比如定制的加密算法,开发者自己编写的审核系统,甚至完全DIY的访问控制系 统。自家开发的安全方案基本上都是不明智的。虽然很多人都以为自己可以马上搞出一些聪明的安全技术,但通常都只是自作聪明。”
    嘿,没有那么牛...
  9. 没有灾难恢复。“要想得到资源来实现系统的灾难恢复机制,其关键在于在若干真实的场景中,具体衡量系统不可用所导致的损失。如果你还能估算这些场景发生的概率,你就可以用这两组数据去说服人们灾难恢复的重要性,并获得合理的预算去实现它。”
    想过,没实际实施过(磁盘阵列,这个算吗?)
  10. 没有撤退计划。“确保无论在系统部署或升级的过程中发生任何事,你都有一份书面的、经过审查的、一致同意的撤退计划,允许你将整个环境恢复到部署之前的状态。”
    没有,总是理所当然的不会出现问题。或出现问题再解决。
分享到:
评论
1 楼 hyhongyong 2007-10-30  
现在,做什么都要考虑代价,如果要做的事情的代价高于没做的损失,当然就是不要做了。

相关推荐

    软件架构师应该知道的97件事-读书心得分享

    在当今的软件开发行业中,软件架构师扮演着至关重要的角色。他们不仅需要具备深厚的技术实力,还需要具备沟通、管理以及对业务的深刻理解。《软件架构师应该知道的97件事》这本书,通过分享一系列心得,为软件架构师...

    软件架构师视频2018年(百度网盘)

    通过具体案例分析,可以让学员更直观地感受到软件架构设计的实际应用场景。本章节会选取多个典型项目作为研究对象,引导学员分析其架构设计的优点和不足之处,并思考改进方案。 ### 十七、系统架构设计论文 最后,...

    软件架构实践.pptx

    ### 软件架构实践知识点概述 #### 一、软件架构与软件工程 软件架构是软件工程中的一个...在实际开发过程中,合理地设计软件架构能够极大地提高开发效率,降低后期维护成本,同时也能更好地满足用户的需求和期望。

    读恩格斯共产主义原理有感.doc

    读恩格斯共产主义原理有感.doc

    读后感300字-朱熹观书有感.docx

    - **第一句**:“半亩方塘一鉴开”——通过比喻手法,将读书的心境比作清澈的水塘,形象地表达了读书给人带来的清澈明亮的感受。 - **第二句**:“天光云影共徘徊”——进一步描绘出水塘中倒映的天光云影,象征着...

    软件架构设计教程1-1

    这是一种非正式的模型,通常用于小型项目或快速原型开发,特点是先编写代码再修复错误,缺乏前期规划和设计,适用于需求不明确或变化较大的情况。 #### 增量模型(Incremental) 增量模型将项目划分为多个可独立...

    执法案件管理系统-软件架构设计.pdf

    通过这种详尽的内容呈现,可以感受到软件工程的良好实践,以及对执法案件管理系统能够有效支持执法工作、提升工作效率、确保信息安全和可靠性方面的周到考虑。 总而言之,《执法案件管理系统-软件架构设计》是一份...

    软件工程与软件系统架构设计.pptx

    ### 软件工程与软件系统架构设计 #### 第一章:软件工程与软件系统架构设计 **软件工程概述** 软件工程是一门专注于系统化、规范化及可度量化的软件开发与维护方法的学科。其核心在于管理和控制软件开发过程,以...

    分布式数据库架构及企业实践-基于Mycat中间件.pdf

    分布式数据库架构及企业实践——基于Mycat...无论是对于软件工程师、测试工程师、运维工程师、软件架构师、技术经理,还是对于资深 IT 人士来说,《分布式数据库架构及企业实践——基于Mycat中间件》都极具参考价值。

    分布式数据库架构及企业实践-基于Mycat中间件

    无论是对于软件工程师、测试工程师、运维工程师、软件架构师、技术经理,还是对于资深 IT 人士来说,《分布式数据库架构及企业实践——基于Mycat中间件》都极具参考价值。 目录 第 1 章数据库中间件与分布式数据库...

    架构之美中文文字版(_Reilly)

    美丽的架构不仅仅是技术上的完美实现,更是设计理念的体现,能够激发人们的创造力和激情,使人们在使用过程中感受到愉悦。 #### 第2章 两个系统的故事:现代软件神话 - **2.1 混乱大都市**:通过一个具体的案例,...

    读书月读后感:读《摆脱贫困》有感1000字.pdf

    读书月读后感:读《摆脱贫困》有感1000字.pdf

    读回忆鲁迅先生有感读鲁迅先生散文集有感.pdf

    读回忆鲁迅先生有感读鲁迅先生散文集有感.pdf

    读《史记·萧相国世家》有感.doc

    读《史记·萧相国世家》有感.doc

    感受挫折-读《鲁滨逊漂流记》有感作文.doc

    感受挫折-读《鲁滨逊漂流记》有感作文.doc

    读莎士比亚戏剧-《李尔王》有感.doc

    读莎士比亚戏剧-《李尔王》有感.doc

    三层架构C#编制的超市管理系统

    《基于C#的三层架构超市管理系统详解》 在IT领域,C#是一种广泛使用的编程语言,尤其在构建企业级应用程序时。本系统——"三层架构C#编制的超市管理系统",是一个采用C#语言和B/S(Browser/Server)模式开发的完整...

    信息架构:超越Web设计(第4版)(全彩)试读样章

    信息架构的设计影响到用户的整体感受和满意度。一个良好的信息架构可以简化用户在网站或应用中的任务流程,减少认知负荷,使得用户能更快地完成目标。 5. 内容策略与信息架构:内容策略涉及创建、管理和分发内容的...

    读马伶传有感作文【《马伶传》读后感】

    《马伶传》的读后感 《马伶传》这部古代文言文作品,讲述了一段传奇故事——明朝的戏曲演员马伶,为了提升自己的表演技艺,不惧艰辛,甘愿投身于权奸门下,经历了三年的磨砺,终于使自己的演技得到了质的飞跃。在这...

Global site tag (gtag.js) - Google Analytics