码迷,mamicode.com
首页 > 编程语言 > 详细

四种JavaEE架构简介

时间:2018-08-29 14:06:34      阅读:186      评论:0      收藏:0      [点我收藏+]

标签:反向代理服务   目的   功能   集群   模块   体系结构   mybatis   实体   bubuko   

1. 传统三层架构

配图是一个基于MVC的三层架构, 大致可以分成表现层, 业务层和持久层

表现层负责接收请求和转发请求

业务层主要负责处理请求, 值得注意的是事务管理, 日志记录等操作通常也是封装在这层中

持久层主要负责数据库与实体之间的操作

我们可以使用框架来简化各层的开发, 例如表现层使用SpringMVC或Strut2, 持久层使用Mybatis或Hibernate, 使用Spring管理三层之间的关系

技术分享图片

 

 

2. 集群架构

集群属于水平拓展.

传统三层架构中存在许多问题, 比如业务层中不同模块占用系统资源的比例相差太大, 导致占用系统资源, 可以使用集群解决这类问题.

在集群架构, 一般由这么一个重要的角色, 那就是反向代理服务器, 它的主要任务是实现负载均衡, 接收用户请求, 转发到目标服务器.

反向代理服务器可以使用nginx实现.

技术分享图片

 

3. 分布式架构

多个模块完成一个功能.

每个模块都可以搭建集群 -> 高可用

技术分享图片

 

4. 微服务架构

根据产品的业务功能模块来划分服务的种类, 这属于垂直划分.

客户端可以通过基于HTTP或RPC的方式来调用微服务, 这样做的目的是为了降低调用所产生的性能开销.

每个模块也可搭建集群 -> 高可用

技术分享图片

三种轻量级API调用服务 - 使用service gateway和service register实现客户端与微服务之间的调用(实现通信)

SOA实现两个系统之间通信的三种方式

技术分享图片

 

dubbo体系结构:

技术分享图片

 

 

一个典型的基于SOA的电商项目架构:

技术分享图片

 

四种JavaEE架构简介

标签:反向代理服务   目的   功能   集群   模块   体系结构   mybatis   实体   bubuko   

原文地址:https://www.cnblogs.com/shaohsiung/p/9552990.html

(0)
(0)
   
举报
评论 一句话评论(0
登录后才能评论!
© 2014 mamicode.com 版权所有  联系我们:gaon5@hotmail.com
迷上了代码!