在社区系统的DDD实践过程中,将遇到一些问题和产生的想法记录下来,共讨论。

本文为【DDD】系列文章中的其中一篇,其他内容可参考:使用领域驱动设计思想实现业务系统

1、dto、model和entity之间的互相转化

user interface层的dto、domian层的model、infrastructure层的entity之间的互相转换,比较繁琐,硬编码容易出错。

如果命名较为规范,则可以考虑交给一个公共服务完成自动转换,约定俗成:dto和model为驼峰式命名,entity和数据库表保持一致,使用小写字母+下划线形式,可以考虑编写一个工具服务完成自动映射;

现实情况下,社区系统是一个遗留系统,代码规范不佳,因此通用工具服务不可行。

2、repository的实现

针对不同的存储介质建议有不同的repository impl,比如rdb使用mybatis实现的dao,mongo有自己的dao;这些dao均需要实现domain层的Repository接口;

对于redis,通常用做缓存,它会搭配主存(rdb、mongo)使用,这时候,可以有一个RepositoryImpl实现类来包装 缓存/主存之间的增删改查逻辑。

例如:

com.eco.domain.repository.IUserRepository

public interface IUserRepository {

	public UserInfo queryUserInfoByUserId(long userId);

}

  

@Repository
public class UserRepository implements IUserRepository {
@Autowired
private JedisCluster jedisCluster; @Autowired
private UserMapper userMapper; @Autowired
private UserRespostoryTranslator userRespostoryTranslator; @Override
public UserInfo queryUserInfoByUserId(long userId) {
UserRedisBean userRedisBean = this.queryUserRedisBeanByUserId(userId);
return this.userRespostoryTranslator.translateFromUserRedisBean(userRedisBean);
} private UserRedisBean queryUserRedisBeanByUserId(long userId) {
UserRedisBean userRedisBean = null;
// 获取缓存key
String userIdKey = RedisKeyUtil.getRedisKey(RedisTypeEnum.UserInfoByUserId, StringUtil.toString(userId));
String value = jedisCluster.get(userIdKey); // redis中不存在,则从db中获取用户相关信息
if (StringUtil.isEmpty(value)) { // 根据userid及用户社交对象从oracle查询用户信息
userRedisBean = getUserRedisBeanFromOracle(userId); if (userRedisBean != null) {
// 用户信息写入redis
JedisClusterUtil.set(jedisCluster, userIdKey, JsonUtil.toJSONString(userRedisBean),ConfigurationConst.userRedisSeconds);
}
} else {
// 如果redis中存在,则从redis获取用户相关信息,并设置有效期
userRedisBean = JsonUtil.parseObject(value, UserRedisBean.class);
}
return userRedisBean;
} /**
* 根据userid从oracle查询用户信息
*
* @param userId
* @return UserRedisBean 欲存入redis中的用户信息bean
*/
private UserRedisBean getUserRedisBeanFromOracle(long userId) { UserRedisBean userRedisBean = null; // 根据userid查询用户信息
UserInfo userInfo = this.queryUserInfoByUserIdFromOracle(userId); //ignore transfer UserInfo to UserRedisBean.
return userRedisBean;
}
}

3、查询式和命令式接口使用的domain需要分离

查询式接口domain应当简化,甚至于去掉。通常查询接口的实现逻辑为:入参校验、鉴权、从Repository中获取数据、拼凑不同的数据、数据转换、返回数据。理论上,不应当存在过多的业务逻辑。所以可以淡化domain层。如果仍然按照:entity --> model -->dto的转换路径,实际model的作用没有,反而带来了代码复杂度,不值得。

命令式接口,除去查询式接口的逻辑,还有部分业务相关的,比如“关注”这一业务逻辑,较为复杂,需要收口到domain。

因此,建议如下处理方式:

  查询式和命令式接口使用的domain需要分离设计,查询式接口使用的domain可以淡化。

【DDD】领域驱动设计实践 —— 一些问题及想法的更多相关文章

  1. DDD领域驱动设计和实践(转载)

    -->目录导航 一. DDD领域驱动设计介绍 1. 什么是领域驱动设计(DDD) 2. 领域驱动设计的特点 3. 如果不使用DDD? 4. 领域驱动设计的分层架构和构成要素 5. 事务脚本和领域 ...

  2. DDD 领域驱动设计-谈谈 Repository、IUnitOfWork 和 IDbContext 的实践(3)

    上一篇:<DDD 领域驱动设计-谈谈 Repository.IUnitOfWork 和 IDbContext 的实践(2)> 这篇文章主要是对 DDD.Sample 框架增加 Transa ...

  3. DDD 领域驱动设计-谈谈 Repository、IUnitOfWork 和 IDbContext 的实践(2)

    上一篇:<DDD 领域驱动设计-谈谈 Repository.IUnitOfWork 和 IDbContext 的实践(1)> 阅读目录: 抽离 IRepository 并改造 Reposi ...

  4. DDD 领域驱动设计-谈谈 Repository、IUnitOfWork 和 IDbContext 的实践(1)

    好久没写 DDD 领域驱动设计相关的文章了,嘎嘎!!! 这几天在开发一个新的项目,虽然不是基于领域驱动设计的,但我想把 DDD 架构设计的一些东西运用在上面,但发现了很多问题,这些在之前的短消息项目中 ...

  5. DDD 领域驱动设计-谈谈 Repository、IUnitOfWork 和 IDbContext 的实践(转)

    http://www.cnblogs.com/xishuai/p/ddd-repository-iunitofwork-and-idbcontext.html 好久没写 DDD 领域驱动设计相关的文章 ...

  6. 【DDD】领域驱动设计实践 —— UI层实现

    前面几篇blog主要介绍了DDD落地架构及业务建模战术,后续几篇blog会在此基础上,讲解具体的架构实现,通过完整代码demo的形式,更好地将DDD的落地方案呈现出来.本文是架构实现讲解的第一篇,主要 ...

  7. DDD领域驱动设计落地实践(十分钟看完,半小时落地)

    一.引子 不知今年吹了什么风,忽然DDD领域驱动设计进入大家视野.该思想源于2003年 Eric Evans编写的"Domain-Driven Design领域驱动设计"简称DDD ...

  8. 浅谈我对DDD领域驱动设计的理解

    从遇到问题开始 当人们要做一个软件系统时,一般总是因为遇到了什么问题,然后希望通过一个软件系统来解决. 比如,我是一家企业,然后我觉得我现在线下销售自己的产品还不够,我希望能够在线上也能销售自己的产品 ...

  9. DDD领域驱动设计之领域服务

    1.DDD领域驱动设计实践篇之如何提取模型 2.DDD领域驱动设计之聚合.实体.值对象 3.DDD领域驱动设计之领域基础设施层 什么是领域服务,DDD书中是说,有些类或者方法,放实体A也不好,放实体B ...

随机推荐

  1. 4个强大的Linux服务器监控工具[转]

    本文介绍了一些可以用来监控网络使用情况的Linux命令行工具.这些工具可以监控通过网络接口传输的数据,并测量目前哪些数据所传输的速度.入站流量和出站流量分开来显示. 一些命令可以显示单个进程所使用的带 ...

  2. 异常检测算法:Isolation Forest

    iForest (Isolation Forest)是由Liu et al. [1] 提出来的基于二叉树的ensemble异常检测算法,具有效果好.训练快(线性复杂度)等特点. 1. 前言 iFore ...

  3. c#控制WPF程序自动登录(Automation方式实现)

    说明:winForm窗体,可以通过win32接口dll的findWindow之类的函数来实现查找winform窗口,mfc窗口等. 但是wpf却是不实用这些,可以靠automation方式来进行操作. ...

  4. Jquery DataTable控制显示列,导出EXCEL

    1.初始化 var table = $('#table').DataTable({ "data": data[0].DATA, "columns": data[ ...

  5. XBIM 基于 WexBIM 文件在 WebGL 浏览和加载

    目录 xBIM 应用与学习 (一) xBIM 应用与学习 (二) xBIM 基本的模型操作 xBIM 日志操作 XBIM 3D 墙壁案例 xBIM 格式之间转换 xBIM 使用Linq 来优化查询 x ...

  6. xBIM IFC 输出 Excel 报表

    目录 xBIM 应用与学习 (一) xBIM 应用与学习 (二) xBIM 基本的模型操作 xBIM 日志操作 XBIM 3D 墙壁案例 xBIM 格式之间转换 xBIM 使用Linq 来优化查询 x ...

  7. HBase Filter及对应Shell--转

    http://www.cnblogs.com/skyl/p/4807793.html 比较运算符 CompareFilter.CompareOp比较运算符用于定义比较关系,可以有以下几类值供选择: E ...

  8. 测试人员如何使用Git部署测试环境

    Git是分布式的版本控制系统. 作为一名Git的小白使用者,一开始接触很懵逼,因为总担心自己一不小心误操作影响代码仓库的代码,网络上关于Git的使用多从开发的角度,很少有人从测试的角度来介绍Git的使 ...

  9. 【项目记录】-路灯监测 gmap.net

    需求 2016年5月,客户要求在地图上显示路灯及数据,分析数据生成报表,以便查看分析路灯情况. 选型 国外项目就不考虑国内的地图了,开始想使用google的web地图,考虑到地图上标记物过多影响性能及 ...

  10. iOS中蓝牙的使用

    Core Bluetooth的使用 1,建立中心设备 2,扫描外设(Discover Peripheral) 3,连接外设(Connect Peripheral) 4,扫描外设中的服务和特征(Disc ...