Architecture Review Board

What's an Architecture Review?

Architecture design is not a one-time final work under a project, but a continuous job since it has to develop from AS-IS to TO-BE architecture so it also have been called 'Building Evoluationary Architecture'. It's been impacted by many factors, e.g. environments, compliance, technology trends, client requirements, company strategy and etc.

Architecture review is the process to understand the architecture with its context and scope, identify and evaluate risks, gaps between AS-IS and TO-BE, also help to improve the design.

Architecture Deliverables

To describe an architecture blueprint, we need some architecture deliverables to make it clear to reviewer from brief to details:

  • Functional & non-functional (technical) requirements can explian the scope of the system or application we're trying to create/enhance.
  • Then architectural design principles helps reviewer what the team focus on and need to stick and implement during design, development, testing, deployment and operaiton.
  • Architectural Patterns are the most general ways to resolve main problems.
  • Capabilities which required by the requirements, this part may not required by architecture review.
  • Components

    * Data Architecture

    * Application Architecture

    * Infrastructure/Platform Architecture
  • Some other documents maybe required by some specific area like data modeling e.g. Conceptual Data Model, Logical Data Model and Physical Data Model.

Scope and Context

The architecture should evolve items under project scope and system scope. So context should also include project context and system context.

From project scope, we need to understand:

  • Stakeholders include clients, end users, and interactive systems, devices. We also need clear with business process. So we can have an end-to-end solution.

  • We need to make clear with integration points bewteen our system to others.

  • Project Boundary

  • System Boundary

Concerns

  • Business (Requirements) Concerns
  • Technical (Requirements) Concerns
  • Data Concerns
  • Compliance Concerns
  • Cost and Effort Concerns
  • Integration Concerns
  • Selection Concerns
  • Limiation Concerns

Measure

  • Sizing
  • Concurrency: Peak

Business Concerns

Acutally all technical and architectural designs are trying to implement the business requirements, so we need to have clear scope of business.

Team need to introduce brief business requirements, and also need to clarify how business growth in future. So we can estimate the sizing and understand the bottleneck may block the scalability of the system.

For business pespective, may require:

  • Business solution
  • Brief business requirements

Technical Concerns

Need to clarify technical requirements with -illities, e.g. security, performance, scalability, flexibility, operability and etc.

From technical requirements:

  • Consider if compoents created can afford live volume and future growth

Data Concern

Since most enterprise application is data-driven in the modern days, so data is the very key of some business. Data architeture is about how to get data, process data, store data, use data, and interact with data.

For some application, data architecture is very important since it needs to integrate with amount of other systems, collect and combine data with relationships. And some other data have been used in a wide ways e.g. meta data, key reference data, transactional data.

  • How data store
  • How data flow, between systems or inside the main system
  • How data filtered and processed
  • Data Modeling
    • Conceptual Data Model
    • Logical Data Model
    • Physical Data Model

Compliance Concern

If services are certified and can be used in a secured way.

If data operation is compliant

If development, deployment and operation are compliant

Cost and Effort Concerns

If cost-effective has been considered

  • Buying or from sketch
  • If there's any existing platoform can save effort and time for runtime and operation
  • If any part of the architecture may cause high cost and it's not worth

Integration Concerns

  • Integraiton type, e.g. REST API, Web Service, Messaging, File Transfer, Data or Service Bus
  • Protocol, e.g. HTTPS or HTTP
  • Authentication e.g. OAuth v2 or OpenID
  • As an I/O model for integration, we also need to understand input/output with data schema, data formats and types for each field
  • If it's a consume model, we need to understand how to handle with server errors and client errors

From security pespective

As a downstream, we need to reduce the attack face which need to close useless protocols, HTTP methods, ports and reject invalid media types. Avoid injected attacks e.g. XSS

How to return

As a upstream, we need to understand how to deal with

Selection Concerns

  • If technique, platform, language and framework have been compared with modern, existing

Limitation Concerns

  • if there's any limitation may cause issue during development, or after deployment/go-live.

Architecture Review Board的更多相关文章

  1. 自动提交Git branch代码评审到Review Board系统

    背景 敏捷软件开发中,越小的反馈环,意味着软件质量越容易得到保证. 作为组件团队,我们的开发任务中,往往存在一些特性涉及到几十个功能点,开发周期持续数周或数月的情况.如何在开发过程中保证软件质量,是个 ...

  2. Review Board——在线代码审查工具

    代码审查(Code Review)不但可以提高质量,而且还是一个知识共享和指导的极好的手段.不幸的是,准备工作的辛苦和工具支持的缺乏让代码审查很容易被延至“稍后再议”.Review Board的目标便 ...

  3. Review Board的使用

    代码审核工具.先在命令行界面,进入到工程的Main目录下,然后使用命令 svn diff>yus.diff  这样就将Main里面的所有内容生成了,然后在浏览器里进入到自己的Review Boa ...

  4. 转: codereview工具之 review board 选型与实践

    转:ReviewBoard代码评审实践总结 http://my.oschina.net/donhui/blog/350074 svn与review board 结合实践 http://my.oschi ...

  5. 开源软件Review Board

    开源软件, Review Board 代码审查的. https://www.reviewboard.org/

  6. ubuntu上搭建review board代码评审站点

    Reviewboard是一个开源个人可以免费使用的代码评审框架,貌似现在有越来越多的公司也开始使用reviewboard作为公司的代码评审工具. 今天早上试了一下,搭建过程非常方便简单,按照网页提示即 ...

  7. 搭建 Review Board - SVN 审核工具

    一.安装环境 CentOS-6.7,ReviewBoard-2.5.1.1 二.安装环境的配置 1.确认当前系统中有如下包,若没有,使用yum安装 httpd-2.2.15:httpd 指的是apac ...

  8. [翻译]opengl扩展教程1

    [翻译]opengl扩展教程1 原文地址https://www.opengl.org/sdk/docs/tutorials/ClockworkCoders/extensions.php [翻译]ope ...

  9. openMP的一点使用经验【非原创】

    按照百科上说的,针对于openmp的编程,最简单的就是在开头加个#include<omp.h>,然后在后面的for上加一行#pragma omp parallel for即可,下面的是较为 ...

随机推荐

  1. shell脚本练习案例

    转至:https://www.cnblogs.com/tui463/archive/2004/01/13/12663024.html shell脚本练习案例 案例一:通过位置变量创建系统账户及密码 分 ...

  2. 多个n维向量围成的n维体积的大小

    前言 上周我们数学老师给了我们一道题,大意就是两个向量a和b,一个点M=$x*a+y*b$,x,y有范围,然后所有M组成的面积是一个定值,求x+y的最小值.当然这是道小水题,但我在想,如果把两个向量变 ...

  3. Tableau绘图一热图、日历图、人口金字塔、标靶图、凹凸图、帕累托图

    Tableau绘图一热图.日历图.人口金字塔.标靶图.凹凸图.帕累托图 本文首发于博客冰山一树Sankey,去博客浏览效果更好.直接右上角搜索该标题即可 一.热图 例子:示例超市 可以通过更改颜色来改 ...

  4. Azure KeyVault(四)另类在 .NET Core 上操作 Secrets 的类库方法-----Azure.Security.KeyVault.Secrets

    一,引言 上一篇文章我们在 .Net Core Web 项目中添加了 "Microsoft.Azure.KeyVault" 的 Nuget 包操作 Azure KeyVault 的 ...

  5. 【图文并茂】 做开发这么久了,还不会搭建服务器Maven私有仓库?这也太Low了吧

    大家好,我是冰河~~ 最近不少小伙伴想在自己公司的内网搭建一套Maven私服环境,可自己搭建的过程中,或多过少的总会出现一些问题,问我可不可以出一篇如何搭建Maven私服的文章.这不,就有了这篇文章嘛 ...

  6. CF698C题解

    为什么 \(n,k \leq 20\)? 我还以为是什么 \(n,k \leq 10^6\) 的厉害题/qd 看到这个队列操作很迷惑,但是仔细看看要操作 \(10^{100}\) 遍,所以我们可以直接 ...

  7. Android12 新特性及适配指南

    Android 12(API 31)于2021年10月4日正式发布,正式版源代码也于当日被推送到AOSP Android开源项目.截止到笔者撰写这篇文章时,国内各终端厂商的在售Android设备,已经 ...

  8. 合并两个以单链表形式表示的关于x的多项式(基于c语言)

    只写函数内部的,不懂得可以看前面一篇文章对链表的实现: pLinklist addBothLinklist(Linklist* first,Linklist* second){ Linklist *n ...

  9. 040_Eureka 服务注册与发现

    目录 什么是Eureka 原理讲解 Eureka的基本架构 三大角色 盘点目前工程状况 创建Eureka服务端子模块 springcloud-eureka-7001 导入依赖 pom.xml 配置文件 ...

  10. java对配置文件properties的操作

    1.读取配置文件的键值对,转为Properties对象:将Properties(键值对)对象写入到指定文件. package com.ricoh.rapp.ezcx.admintoolweb.util ...