• 闲聊下架构、框架,以及架构师...


    闲聊下架构、框架,以及架构师...

    我们先来本人对下面这两个名词的个人见解:

    • 软件架构:

    几乎每个软件系统的架构都是不同的,因为软件架构的第一步就是根据当前项目的重要需求及约束来制定一个个技术决策。

    • 软件框架:

    可以分成行业框架和通用框架。

      1. 通用框架是对大多数软件项目常用的模块(底层+高层)进行封装(同时暴露热点)的一个集合,能提高开发速度以及质量
      2. 行业框架是针对某特定领域,把类似领域逻辑提取出来进行封装(同时暴露热点)的一个集合,能提高开发速度以及质量
      3. 行业框架可以是基于通用框架之上的。

    站在架构师的角度,针对架构的开发,会慢慢演变为针对框架的开发(由于需要考虑复用以及对开发人员友好API特性)

    • 伸缩性:一般是指机器级别的横向扩展,如:web服务器的横向扩展、数据库的读写分离、中间件的横向扩展
    • 扩展性:是指当需求变更时,系统能否很容易的进行修改、扩展。
    • 简洁性:直接的观念是AOP,因为AOP能让开发人员集中注意力于业务逻辑上,而不需要过多考虑非业务逻辑代码(比如日志、权限、参数
    • 的基本验证等)
    • 性能:与伸缩性、算法优化、充分利用CPU能力有关


    由于每个项目都是不同的,因此架构也大多数不同,但是由于人的精力有限,不可能样样都精通,因此当架构初始化之后,针对不熟悉的 
    架构还需要进行架构验证(如同测试人员的BVT)。因此对架构师而言,个人的学习能力、学习速度以及实践能力都非常重要。那么如何进行架 
    构验证呢?
    1. 找几个开发人员评审评审框架提供的API,看看反馈,需要修改则修改,或者通过技术培训解决
    2. 使用AOP技术插入必要的日志、性能计数器、内存占用数(当然也可以用其他技术,并非只有AOP技术)
    3. 自己进行性能测试、性能分析;或者找技术性测试人员来做

    最后别忘了当项目进行之前先进行技术培训,讲解框架的实现原理以及如何使用。

    综上所述,框架与架构质量的好坏会严重影响使用者的效率,如:开发人员的开发效率,架构师责任重大啊。

    自省推动进步,视野决定未来。
    心怀远大理想。
    为了家庭幸福而努力。
     
  • 相关阅读:
    把信贷风险管理浓缩为50个要点(赶紧收藏吧)!
    AjaxControlToolkit没有通过WebResource.axd加载css导致ajaxToolkit:TabPanel无法显示正确的样式
    启动vmware中的虚拟机的时候,提示Failed to lock the file
    linq to xml There are multiple root elements.
    How to create a List of ValueTuple?
    SET IDENTITY_INSERT 和 DBCC CHECKIDENT
    NOT IN clause and NULL values
    ASP.NET Session and Forms Authentication and Session Fixation
    asp.net下的cookieName
    flywaydb and sql server
  • 原文地址:https://www.cnblogs.com/Leo_wl/p/3102759.html
Copyright © 2020-2023  润新知