面试题:什么是脚手架?为什么需要脚手架?常用的脚手架有哪些?

news2025/6/9 13:15:32

文章目录

  • 前言
  • 脚手架介绍
    • 什么是脚手架
  • 为什么需要脚手架
    • 不要重新造轮子
  • 常用脚手架
    • Vue框架
    • Maven
    • Netty
    • Java EE


前言

微服务本身是一种架构风格,也是指导组织构建软件的一系列最佳实践集合。然而,业务团队在拆分应用后,会产生更多细粒度服务,并面临这些服务在分布式网络环境中的复杂性。如何专心实现业务逻辑而不陷入微服务架构的技术细节,对开发者来说是一大难题。

本章将介绍脚手架的概念,并介绍JVM环境下在技术成熟度、架构完整性、生态活跃度等方面都占据优势的微服务脚手架项目:SpringBoot。


脚手架介绍

什么是脚手架

脚手架是一种用在建筑领域的辅助工具,或者说是为了保证各施工过程顺利进行而搭设的工作平台,有兴趣的读者可自行查看维基百科上的定义。

对应到软件工程领域,脚手架可以解释为帮助开发人员在开发过程中使用的开发工具、开发框架,使用脚手架你无须从头开始搭建或者编写底层软件。下面的“脚手架”定义来自Stack Overflow,更加偏向于应用服务框架使用的一种编程思想或者说编程范式(供参考)。

脚手架:是一种元编程的方法,程序员编写一份规格说明书(Specification),用来描述怎样去使用数据库,然后由编译器脚手架根据这份规格说明书生成相应的代码,进行增、删、改、查等数据库的操作,在脚手架上更高效地建造出强大的应用。

为什么需要脚手架

为什么软件开发需要脚手架呢?我们通过软件开发的一些基本原则看一下脚手架对软件工程的重要作用。

● 复用原则(Reuse Principle):现在我们推崇的是极致化的编程体验,缩短的开发时间、大量的开发任务、支持需求的变更、高频率的应用服务交付,这些都给软件开发人员带来了前所未有的压力。其中,软件复用技术被公认为解决这些问题的行之有效的方法。从计算机软件编程的发展历史来看,从面向过程的编程语言到面向对象的高级编程语言的广泛使用,是软件复用技术进步的体现。从对象的复用到更大的组件复用,再到如今的框架的复用、服务的复用,都是在利用他人的优秀成果来放大你的工作价值。当一个新手使用脚手架时,对于一个具体问题,可以套用现成的解决方案加以扩展。使用脚手架的应用,仅需通过简单的注解和配置就可以具备健康状态检查、生产环境就绪、可观测等基本服务能力。对于一个业务逻辑问题,可以复用已有的逻辑,一步步迭代,敏捷开发。

● DRY原则(Don’t Repeat Yourself):DRY原则直译过来就是“不要重复你自己”。这一原则和复用原则类似,强调尽量在项目中减少重复的代码行、重复的方法、重复的模块。其实,软件设计原则和模式最本质的思想都是“消除重复”。

我们经常提到的重用性和可维护性其实是基于减少重复这一简单而重要的思想的。DRY原则意味着系统内的每一个部件都应该是唯一的,并且是具有明确含义的(不模糊的)。我们可以通过应用职责单一、接口隔离等原则尽量拆分系统、模块、类和方法,使每一个部件都是职责明确并且可重复使用的。

● 开闭原则(Open Close Principle):开闭原则中的“开”就是指对功能的扩展是开放的,“闭”是指对于原有代码的修改是封闭的。通俗一点讲,软件系统通常是由各种模块组成的,软件系统在增加一项新的功能时,应该在不修改现有代码的基础上操作。实现开闭原则的关键就是“抽象”,从微观的角度讲,开闭原则适用于一个业务模型的类的设计,把系统内的所有可能行为抽象为一个抽象底层,在这个抽象底层中规定需要提供的方法接口,具体实现类通过集成、代理、委托的方式,扩展实现新的行为或者新的功能。从宏观的角度讲,我们说开闭原则就是将公共模块、开发约定、最佳技术实践经过共享、提炼沉淀到封闭的底层技术基座;而将变化频繁的业务模块、独特的功能逻辑通过继承、组合和集成的方式实现对扩展的开放。

不要重新造轮子

不要重新造轮子(Stop Reinventing The Wheel),这个原则可以说是软件开发里的“金科玉律”。在实际的软件工程场景中,脚手架的使用正是为了我们避免重新造轮子。如果你不借助已有框架或者工具,不仅不会提升开发效率,还会将自己陷入重新造轮子的风险中。这里举一个发生在本人参与的实际项目中的血淋淋的案例。

我们在一个服务治理项目中需要在数据持久层实现一个通用的数据存储接入组件,初衷是降低应用接入不同数据存储引擎的复杂性,屏蔽使用者对不同持久层的感知差异,使开发者通过简单的配置就能适配不同的数据类型。另外,因为期望完全掌握对持久层的控制,以及实现深度定制化的数据转换功能,所以我们并没有使用Spring框架,而是走上了自研持久层的道路。如下图所示是自研持久层的UML框架图。

在这里插入图片描述

我们分别对接了MySQL、MongoDB、OpenTSDB、HBase等数据源。系统从架构设计到落地花费了大概两个月的时间,还不包括后期的测试、对接、调试、修复Bug至少一个月的磨合期。然而,由于人员、经验、项目周期等各种因素,最终自研持久层框架的效果并没有达到预期,后期在与业务对接的过程中还出现了各种技术和业务适配问题。

在经过一番技术调研后,我们决定逐渐使用Spring Data替代原有的自研持久层框架。经过项目的实践后,我们发现在业务的需求满足性、易用性、开发效率、业务稳定性等各个方面,Spring Data都具备压倒性的优势,它不仅可以完全满足业务和技术上的需求,而且可以简化我们的开发工作、显著提升工作效率。二者的复盘对比如下表所示。

图片

在这里插入图片描述

Spring Data项目通过使用对象的语义可以让我们更方便地操作不同类型的数据。它将应用的骨架部分通过“抽象”提取出来,形成了一套系统的开发范式和行为模式。Spring Boot脚手架也为自定义的复杂查询、修改操作提供了扩展的Repository类和自动化配置,使添加定制化的扩展方法更加轻松方便。我们只需要理解Spring为我们提供的操作API接口,就可以实现复杂的查询等业务逻辑。

Spring Data将我们的数据持久层框架进行了进一步的封装,开发者通过简单的注解,就可以实现将不同类型数据放到不同持久层集合的存储映射操作。可以说,脚手架工程可以为开发人员屏蔽繁杂的数据存储引擎底层差异和具体工作细节,提升了开发效率,降低了开发难度。除非你是这个领域的专家,或者没有现成的软件脚手架能够满足你的需求,否则请停止“愚蠢地重复造轮子”的行为。

常用脚手架

下面列举一些软件开发中经常使用的脚手架,看一下如何通过脚手架提高我们的开发效率。

Vue框架

对于前端开发人员来说,Vue无疑是一套简单的、易于使用的构建用户界面的前端脚手架。根据Vue的官网说法,Vue是一套构建用户界面的渐进式的JavaScript框架。与其他重量级框架不同的是,Vue采用自底向上的增量开发的设计,Vue的目标是通过尽可能简单的API实现响应的数据绑定和组合的视图组件。

vue-cli脚手架构建工具,可用于快速搭建大型单页应用。该工具提供“开箱即用”的构建工具配置,带来了现代化的前端开发流程。

只需几分钟即可创建并启动一个带热重载、保存时静态检查及可用于生产环境的构建配置的项目:

要创建基于Webpack模板的项目,首先我们选定目录,然后在命令行中把目录转到选定的目录即可,可以使用下面的命令:

Maven

Maven是一个跨平台的项目管理工具,是服务于Java平台的项目构建、依赖管理、项目信息管理工具。同时使用Maven可以规范项目骨架及包层次结构、命名配置文件、生成代码原型等。

Maven提供了archetype插件来帮助开发人员快速勾勒出项目的骨架,要使用本地Maven仓库中的脚手架创建新项目,直接执行如下Maven命令,根据提示依次输入groupId、version、package信息即可:

Maven自动化构建简化了开发人员手动构建工程的过程,规范了项目的构建过程。Maven自动化构建流程如下图所示。

图片

Netty

Netty是JBoss提供的一个Java开源框架。Netty提供异步的、事件驱动的网络应用程序框架和工具,用以快速开发高性能、高可用性的网络服务器和客户端程序。在Java世界中还没有Netty框架的时候,Java自带的NIO非常复杂,并且还会出现Epoll Bug(代码缺陷),这个Bug会触发Selector空轮询,导致CPU的使用率达到100%。Netty的解决方式是,在N次空轮询后自动关闭Selector,避免了原生NIO的空轮询问题。而且Netty有很好的线程模型和内存管理框架,如下图所示是Netty Reactor工作架构图。

图片

Java EE

Java EE的全称是Java 2 Platform Enterprise Edition,它是在SUN公司领导下,多家公司参与共同制定的企业级分布式应用程序开发规范。

Java EE技术由一系列技术规范和技术组件组成,包括RESTfulWeb Server(JAX-RS)、Jersey Rest框架、Java Servelt、JMS、EJB等。通常可以把满足这些标准的业务应用部署在Tomcat、JBoss等Web服务器上运行。

DropwizardDropwizard只需通过简单配置就能让你的类提供RESTful服务。

Dropwizard是一个微服务框架,是各项技术的一个集成封装,它包含以下组件:

● 嵌入式Jetty:一个应用程序被打包成一个jar文件,并使用自己嵌入的Jetty容器。除此之外,无任何其他war文件和外部Servlet容器。

● JAX-RS:Jersey,用来写基于REST的Web服务。

● JSON:REST服务数据传递处理全部用JSON,使用Jackson库。

● 日志:使用Logback和SLF4。

● 数据库:使用Hibernate集成ORM框架。

● 指标:使用Metrics作为指标度量工具,在Java代码中嵌入Metrics代码,可以方便地对业务代码的各个指标进行监控,同时Metrics能够很好地跟Ganlia、Graphite结合,方便地提供图形化接口。

在微服务架构领域,Dropwizard可以说是早期脚手架的一个代表,然而Spring Boot青出于蓝而胜于蓝,在Spring强大和成熟的技术生态下,Spring Boot展现出来的特性更加优雅,也更加契合当前微服务架构的理念,下一节我们将正式开始Spring Boot之旅。

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.coloradmin.cn/o/1330751.html

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

KingbaseV8R6单实例定时全量备份步骤

此场景为单机数据库节点内部备份,方便部署和操作,但备份REPO与数据库实例处于同一个物理主机,冗余度较低。 前期准备 配置ksql免密登录(必须) 在Kingbase数据库运行维护中,经常用到ksql工具登录数据库,本地免密登录…

@z-utils组 重构和自动化实现

highlight: monokai theme: github 包简介 z-utils组 是一个可以在vue/react/pure js 中使用的工具包,它包含三个子类,分别为 z-utils/base, z-utils/react, z-utils/vue 三个分别在不同区域使用。 他是原 zzy-javascript-devtools 的重构版本&#xf…

2016年第五届数学建模国际赛小美赛A题臭氧消耗预测解题全过程文档及程序

2016年第五届数学建模国际赛小美赛 A题 臭氧消耗预测 原题再现: 臭氧消耗包括自1970年代后期以来观察到的若干现象:地球平流层(臭氧层)臭氧总量稳步下降,以及地球极地附近平流层臭氧(称为臭氧空洞&#x…

HarmonyOS 多态样式

还记得我们css中有 按压 失去焦点 点击后 正常状态 的各种样式设置 那么作为前端开发 TS JS的改版 harmonyos自然也有 这里 我们编写代码如下 Entry Component struct Index {build() {Row() {Column() {TextInput()TextInput().stateStyles({//正常状态normal: {.background…

WEB渗透—PHP反序列化(八)

Web渗透—PHP反序列化 课程学习分享(课程非本人制作,仅提供学习分享) 靶场下载地址:GitHub - mcc0624/php_ser_Class: php反序列化靶场课程,基于课程制作的靶场 课程地址:PHP反序列化漏洞学习_哔哩…

20231223使用Rockchip原厂的Android11调通Firefly的AIO-3399J开发板上的AP6356S

20231223使用Rockchip原厂的Android11调通Firefly的AIO-3399J开发板上的AP6356S 2023/12/23 14:14 开发板:Firefly的AIO-3399J【RK3399】 SDK:rk3399-android-11-r20211216.tar.xz【Android11】 Android11.0.tar.bz2.aa【ToyBrick】 Android11.0.tar.bz2…

Unity3D移动端实现摇一摇功能

手机摇一摇功能在平时项目开发中是很常见的需求,利用Unity的重力感应可以很方便的实现该功能。 Unity简化了重力感应的开发, 通过访问Input.acceleration属性,取回加速度传感器的值。首先我们看一下重力传感器的方向问题。Unity3D中重量的取…

MFC使用高速绘图控件high-speed Charting Control绘制柱形图

1. 创建MFC单文档工程BarChartDemo。 2. 在工程文件夹下新建文件夹ChartCtrl,将ChartCtrl源码放入,如下图所示。在工程中添加这些项,项目——添加——现有项,全部添加。 3. 添加一个对话框,ID为IDD_DLG_BAR,类名为CBarDlg。 4. 在对话框中添加Custom Control控件,将控…

机场信息集成系统系列介绍(7):机场航班信息显示系统FIDS

目录 一、简介 二、架构及相关功能 1、实时更新和显示航班信息 2、多屏显示与查询 3、提供登机口导航信息 4、发布机场公告 5、集成机场的其他延伸服务 6、支持多语言显示 7、监控与故障处理 8、数据分析与优化 9、与航空公司、地面代理的信息交互 10、安全保障与应…

Python数据科学视频讲解:嵌入法(随机森林、提升法、Logistic等)

4.5 嵌入法(随机森林、提升法、Logistic等) 视频为《Python数据科学应用从入门到精通》张甜 杨维忠 清华大学出版社一书的随书赠送视频讲解4.5节内容。本书已正式出版上市,当当、京东、淘宝等平台热销中,搜索书名即可。内容涵盖数…

【Hive_04】分区分桶表以及文件格式

1、分区表1.1 分区表基本语法(1)创建分区表(2)分区表读写数据(3)分区表基本操作 1.2 二级分区1.3 动态分区 2、分桶表2.1 分桶表的基本语法2.2 分桶排序表 3、文件格式与压缩3.1 Hadoop压缩概述3.2 Hive文件…

安捷伦Agilent 8720ES网络分析仪

Agilent安捷伦8720ES S-参数矢量网络分析仪 50MHz至20GHz 100 dB 的动态范围 优异的测量精度 2个测量通道 4个显示通道 频率和功率扫描 快扫描和数据传输速度 通过/失败测试,强大的标记功能 电校准(ECal) 内部使用测试序列的自动化 可选时域…

芯片到底是怎么访问外设

微型计算机的组成:CPURAM硬盘等 什么是FLASH? FLASH存储器又称闪存,它结合了ROM和RAM的长处,不仅具备电子可擦除可编程(EEPROM)的性能,还不会断电丢失数据同时可以快速读取数据(NV…

matlab时间转换

采集的GNSS数据是10hz的。 data(选取其中一部分)如下: (1)char类型 formatOut yyyy-mm-dd HH:MM:SS; str datestr(data,formatOut); str如下: (2)double类型 DateVector dat…

Ai基本视图操作和快捷键设置

这个抓手可以用来拖动,左右的滑块可以用来实现上下左右的移动。 对于放大缩小图片有ctrl与ctrl-(Alt滚轮)如果要回到原来的大小则使ctrl1 Ai还具有像ppt一样的放映功能(可以将工具栏或者其他栏的根据进行替换)

使用html+css+js+three.js写圣诞树

实现效果&#xff1a; <head><meta charset"UTF-8"><title>Musical Christmas Lights</title><link rel"stylesheet" href"https://cdnjs.cloudflare.com/ajax/libs/normalize/5.0.0/normalize.min.css"><sty…

盲盒小程序搭建:开启互联网盲盒时代

盲盒目前是一个非常火爆的商业模式。随着科技的发展&#xff0c;盲盒市场也开始采用线上盲盒进行拓客&#xff0c;吸引盲盒爱好者。当下在互联网电商影响下&#xff0c;盲盒小程序逐渐受到了商家的青睐。 线上盲盒市场 盲盒消费主要是根据自身的未知性吸引消费者&#xff0c;消…

小白实战教学:开发同城外卖跑腿APP

本文将以"小白实战教学"为主题&#xff0c;向大家介绍如何从零开始&#xff0c;开发一款简单而实用的同城外卖跑腿APP。 一、准备工作 在开始之前&#xff0c;我们需要做一些准备工作。首先&#xff0c;确保你已经安装好了开发环境&#xff0c;包括合适的集成开发环…

09.list 容器

9、list 容器 功能&#xff1a; 将数据进行链式存储 链表&#xff08;list&#xff09;是一种物理存储单元上非连续的存储结构&#xff0c;数据元素的逻辑顺序是通过链表中的指针链接实现的 链表的组成&#xff1a; 链表由一系列结点组成 结点的组成&#xff1a; 一个是存…

携手河南恩坤德,共创养殖新篇章

在这个充满机遇与挑战的时代&#xff0c;养殖业正在经历一场前所未有的变革。作为养殖户&#xff0c;您需要一个能够与您共同应对变革、共创未来的合作伙伴。河南恩坤德农业正是这样一个值得信赖的伙伴&#xff0c;我们携手共创养殖新篇章。 河南恩坤德农业以客户需求为导向&am…