当前位置:首页 > 技术知识 > 正文内容

你竟然不知道大型网站架构技术细节:后端架构规整化自研框架Once

maynowei8个月前 (08-18)技术知识85

自研框架Once

实现了以上的规整化内容后,后端应用程序的开发过程将会被约束,软件质量也会得到保证。但是,只保证软件质量是不够的,架构应该考虑软件的开发效率。就后端应用程序而言,代码是否可以只写一次,如果不能,是不是可以用代码生成器生成。另外,对于使用相同框架的两个项目,A项目积累下来的模块代码,是否可以在B项目中直接使用。

说明:为了实现上述愿望,笔者做了一个框架,叫Once(一次),有兴趣的朋友可以在
https://github.com/YiiGaa/Once
上下载。这个框架是一个顶层框架(只约束了规则),其基础框架还是Spring Boot。在使用这个框架的几个项目里,其效率提升是明显的,一个后端工程师可以一天产出十几二十个接口(测试通过)。

关于顶层框架的说明,可参考10.1.2小节的介绍。

从宏观上讲,后端应用程序是多个请求的集合。而对单个请求来讲,是多个步骤的集合,以一个审核博客的接口为例,可以将其理解为:第一步“用户鉴权”,第二步“检查必要参数”,第三步“填充默认参数”,第四步“数据库操作”。

在4.3.2小节中,强调后端应用程序应该抽离公共模块。其实,后端应用程序是可以分成两层的,一是业务代码,二是模块代码,如图4.64所示。

·业务代码:指定该业务请求的步骤,且指定每一步调用的模块,例如,第一步调用“用户鉴权”模块,第二步调用“数据库操作”模块,第三步调用xx(其他)模块。

·模块代码:实现某种具体功能的代码块,例如用户鉴权模块、检查必要参数模块等。模块代码与业务功能无关,只关心被使用的场景。

这样的话,模块代码是可以只写一次的(所有接口都可以使用),而且可以直接用在其他项目当中。但是,业务代码部分仍然需要编写大量的代码,而这些代码其实是高度重复的。此时,如果加入“数据池”的话,则可以进一步简化业务代码。

业务代码每次调用模块时,都把“数据池”和模块参数传入模块中,模块代码根据模块参数实现逻辑,模块代码可直接对“数据池”进行处理(可以从“数据池”中获取或更新数据)。当模块发生错误时,错误码会被存放到数据池中。模块处理完后,把数据池返回业务代码,业务代码判断是否需要截断下一步逻辑(数据池中是否有错误码)。

具体工作原理如图6.65所示。


经过以上规范化后,业务代码可以简化为JSON的表达形式,如代码4.42所示。简化业务代码后,即可通过代码生成器把业务代码还原成Java代码。这样,便减少了重复代码的编写,又让业务代码更加清晰明了。

代码4.42 业务代码简化为JSON的表达"接口列表":

{

"接口一": {

"接口路径": "/xx/xx" ,

"请求方式": "POST" ,

"调用模块": [

{

"模块名":"检查必要参数",

"模块参数":{ //模块代码会自动识别数据池中是否有以下字段

"abc":"abs", //abc字段为必填

"bcd":"opt" //bcd字段为选填

}

},

{

"模块名":"数据库操作",

"模块参数":{

"control":"update", //更新操作

"query":"UPDATE t_blog SET state='pass' WHERE

id='@id@'" //SQL语句,其中@id@会替换成数据池中的id的值

}

],

},

"接口二":{

...

}

}

本文给大家讲解的内容是大型网站架构的技术细节:后端架构规整化自研框架Once

  1. 下篇文章给大家讲解的内容是大型网站架构的技术细节:后端架构数据库对比及工作原理
  2. 感谢大家的支持!

相关文章

出售闲置原型素材来赚钱,上传作品,即可收上万元收入

出售闲置原型素材来赚钱。产品经理每年设计出大量的原型作品和组件、元件库、交互原型模板等作品,如果项目结束,你的原型就失去了作用,而有需求的人却找不到这样的作品。现在我们发现这样一家元件库、原型模板、素...

伪装成抖音国际版Tiktok的短信蠕虫

概述近期监测到一款仿冒Tiktok的短信蠕虫,该短信蠕虫最明显的特点就是针对Android系统版本高于6.0以上的设备,由于Android版本的更新迭代,现在大部分设备已经更新到较高的版本,通过不完全...

Android监听滚动视图(监听页面滚动)

Android UI Libs之Android-ObservableScrollView1. 说明Android-ObservableScrollView,顾名思义,Android上观察滚动的视图,可...

Android之自定义ListView(一)(android 自定义view绘制流程)

PS:自定义View是Android中高手进阶的路线.因此我也打算一步一步的学习.看了鸿洋和郭霖这两位大牛的博客,决定一步一步的学习,循序渐进.学习内容:1.自定义View实现ListView的Ite...

Win10桌面/手机版最深层次开发功能挖掘

IT之家讯 Win10开发者预览版为我们提供了一个Win10大框架的早期概览,使开发者与热心用户都可以提前感受Win10带来的新特性,尝试新工具,而作为开发者,最关心的莫过于Windows多平台通用应...

C# 中的多线程同步机制:lock、Monitor 和 Mutex 用法详解

在多线程编程中,线程同步是确保多个线程安全地访问共享资源的关键技术。C# 提供了几种常用的同步机制,其中 lock、Monitor 和 Mutex 是最常用的同步工具。本文将全面介绍这三种同步机制的用...