精华帖 (0) :: 良好帖 (0) :: 新手帖 (6) :: 隐藏帖 (0)
|
|
---|---|
作者 | 正文 |
发表时间:2010-03-24
最后修改:2010-03-24
最近在对之前做过的一个项目进行二期修改。鉴于之前典型的贫血结构,以及Controller--->Service--->DAO模式让代码压力都集中在service层的情况。在参考了网上几篇对象职责和Domain Event的文章后,我也试着捣鼓了一下新的分层模式。贴出来和大家讨论,欢迎拍砖!
【5】疑惑与担忧
目前还有几个问题一直困扰着我
④缓存与对象构建放在仓储中是否合适?
声明:ITeye文章版权属于作者,受法律保护。没有作者书面许可不得转载。
推荐链接
|
|
返回顶楼 | |
发表时间:2010-03-24
发表下我的看法:
1.这种分层显得更清晰。尤其是业务层和服务层分开。服务器层更加应该侧重实体对象的服务功能,比如添加一个订单;业务层则更面向表现层的需求。比如用户可以同时添加1个或者多个订单。展示的方式不同,添加订单的业务操作就可能不一样。 2.我自己现在都是用一个查询service来完成所有查询操作的。 3.应该放在业务层。就像我上面说的,一次添加多个订单,可能是要求保证数据完整性的。一个业务可能需要好几个服务来完成。 4.缓存肯定是放在仓储中的。至于对象的创建,和你有点不太一样。我现在是在表现层通过dto的方式,将数据传给service,在service中完成实体对象的创建,再将dto中的数据赋值给实体对象。我感觉这样有一个最大的好处就是对表现层简单了,他只用管理dto对象,不用关心实体对象,也屏蔽了实体对象的实现方式。比如你要修改一个订单,如果用在表现层操作实体对象,那么表现层这时就必须去服务层先load这个实体对象,然后修改值,再传给服务器层update。这实际上load实体对象是没有必要的。如果我用dto,那么就在表现层直接new一个dto对象,设置好值以后传给服务层,这时候服务器再来update实体对象。而且服务层针对dto进行服务,感觉有点别扭。如果加上一个业务层,就更好了,业务层针对dto对象提供业务服务,服务层针对实体对象提供服务。当然这样多引入一层,编码上就变得更麻烦了。呵呵 |
|
返回顶楼 | |
发表时间:2010-03-24
强烈支持业务层和服务层分开的想法,业务层和服务层应该分别针对业务逻辑和实现逻辑,彼此独立,千万不要彼此交叉。而且service的力度最好能稍微小一点,方便业务层组合多个service来实现新的业务逻辑。
|
|
返回顶楼 | |
发表时间:2010-03-24
①控制层:数据映射、控制转向、业务调用
②业务层:从用户角度出发,看到的系统可以提供的功能接口 ③实体层:包含了数据与行为的实体对象 ④服务层:从程序内部角度出发,为了完成业务而划分出来的细粒度功能模块 ⑤仓储层:对象的构建、缓存、持久化 这里的实体层买有看明白,你说的应该是一些和实体相关的value object或者说javabean吧?这个应该不算是层吧? |
|
返回顶楼 | |
发表时间:2010-03-25
层是分了好多,服务是无状态的,它不涉及业务回逻辑,是为了分担领域对象的职责而出现的.因为这些职责不是实体,也不是值对象应该拥有的.
这三个领域对象是模型的核心. 实体作为了聚合根是一次性装载全部属性(包括聚合的其它值对象或实体),这个通过工厂处理,而到存储里找到相应的对象. 添加,删除这肯定是要和数据库关联的.之前看到一些是将查询和添加分开.添加不经过存储添加,而是添加后再放到存储里.而查询所有都经过它. 书里说对数据库或其它存储介质的访问都通过Repository来处理 .不过事务确实比较麻烦.如果 在这里实现事务处理,当外界服务调用时可能跨越了多个实体的改变,应该如何处理呢? 也许是OO思想还差远了,我还不能处理. |
|
返回顶楼 | |
发表时间:2010-03-25
看不太明白。。能否上个代码看看,是什么样写的
|
|
返回顶楼 | |
发表时间:2010-03-25
中间层细分为业务层和服务层,实际应用的时候怎么有效区分呢?会不会导致这两层混乱?
|
|
返回顶楼 | |
发表时间:2010-03-25
实用就好了,没有必要生搬硬套。
|
|
返回顶楼 | |
发表时间:2010-10-19
难不成楼主的二次维护就是要把一期工程的工作全部推倒重来?不要为了DDD而DDD
|
|
返回顶楼 | |
发表时间:2010-11-22
层次分的很清楚,不过楼主这样分的目的是什么,如果是为了分担service层,那可能就要考虑部署的问题,将业务层和service层进行分开部署吗?是实际上业务层与service层的主要区别就是是否可公用。但并不能分担服务器的压力,因为往往业务层与服务层部署在同一台服务器上,很难分开部署。该种分层的结构是合理的,事物处理一定要放在业务层,控制层不可直接调用服务层,服务层的目的是为了给业务层提供服务。实体层的设计可以详细一些。
|
|
返回顶楼 | |