加入收藏 | 设为首页 | 会员中心 | 我要投稿 吉安站长网 (https://www.0796zz.com.cn/)- 科技、图像处理、媒体智能、办公协同、操作系统!
当前位置: 首页 > 站长资讯 > 传媒 > 正文

2020大数据行业十大新闻

发布时间:2021-01-30 19:17:17 所属栏目:传媒 来源:互联网
导读:图片MVC模式中M是指业务模型,V是指用户界面,C则是控制器,使用MVC的目的是将 M 和 V 的实现代码分离,开发中一般将应用程序分为 Controller、Model、View 三层,Controller 接收客户端请求,调用 Model 生成业务数据,传递给 View,View最终展示前端结果。

图片MVC模式中M是指业务模型,V是指用户界面,C则是控制器,使用MVC的目的是将 M 和 V 的实现代码分离,开发中一般将应用程序分为 Controller、Model、View 三层,Controller 接收客户端请求,调用 Model 生成业务数据,传递给 View,View最终展示前端结果。

Spring MVC 就是对上述这套流程的封装,屏蔽了很多底层代码,开放出接口,让开发者可以更加轻松、便捷地完成基于 MVC 模式的 Web 开发。

10.2 Spring 跟 Spring MVC关系

最开始只有Spring,只提供IOC跟AOP核心功能,后来出了乱七八糟的比如MVC、Security、Boot 等。原来的Spring 就变成了现在的Spring Core,MVC指的是Web的MVC框架。

Spring MVC 就是一个MVC框架,其实大范围上来说属于Spring,Spring MVC是一个类似于Struts的MVC模式的WEB开发框架,Spring MVC是基于 Spring 功能之上添加的 Web 框架,Spring 跟 SpringMVC可以理解为父子容器的关系,想用 Spring MVC 必须先依赖Spring。

Spring MVC 是控制层,用来接收前台传值,调用service层和持久层,返回数据再通过 Spring MVC把数据返回前台

10.3 Spring MVC 的核心组件

DispatcherServlet:前置控制器,是整个流程控制的核心,控制其他组件的执行,进行统一调度,降低组件之间的耦合性,相当于总指挥。

Handler:处理器,完成具体的业务逻辑,相当于 Servlet 或 Action。

HandlerMapping:DispatcherServlet 接收到请求之后,通过 HandlerMapping 将不同的请求映射到不同的 Handler。

HandlerInterceptor:处理器拦截器,是一个接口,如果需要完成一些拦截处理,可以实现该接口。

HandlerExecutionChain:处理器执行链,包括两部分内容:Handler 和 HandlerInterceptor(系统会有一个默认的 HandlerInterceptor,如果需要额外设置拦截,可以添加拦截器)。

HandlerAdapter:处理器适配器,Handler 执行业务方法之前,需要进行一系列的操作,包括表单数据的验证、数据类型的转换、将表单数据封装到 JavaBean 等,这些操作都是由 HandlerApater 来完成,开发者只需将注意力集中业务逻辑的处理上,DispatcherServlet 通过 HandlerAdapter 执行不同的 Handler。

ModelAndView:装载了模型数据和视图信息,作为 Handler 的处理结果,返回给 DispatcherServlet。

ViewResolver:视图解析器,DispatcheServlet 通过它将逻辑视图解析为物理视图,最终将渲染结果响应给客户端。

10.4 Spring MVC 的工作流程
 

7.总结与展望

从产品设计、技术调研、架构设计到最后研发上线,历时半年左右。最终功夫不负有心人,项目顺利上线,通过前台产品的简单交互与审核,就能秒级快速创建DTS任务。

目前已经支持数十个DTS任务(包括数据订阅、数据迁移、数据同步),落地了多云数据库镜像、ES索引构建、数据实时同步、业务数据订阅等多个业务场景。

未来,还需要做进一步的技术迭代,包括:

1)扩展数据传输引擎

目前已经在尝试接入Redis-shake做Redis的迁移与同步。

后面还会继续尝试HBase-replication的接入,做HBase相关的任务迁移与同步。

这些都可以通过复用 通用服务能力 和 模版流程,实现快速接入。

2)增加调度模块

后续还需要增加任务调度模块,主要实现两方面的能力:

根据实例负载进行任务的调度,保证资源的合理使用

根据业务特性、重要程度做任务调度,保证资源隔离

3)完成云原生化改造

目前只有otter引擎实现了k8s部署,后面还需要对canal-server、Datax实现k8s部署,满足快速扩缩容,提高资源使用率。

(编辑:吉安站长网)

【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容!

    推荐文章
      热点阅读