域驱动设计 – DDD / CQRS / ES使用图数据库实现聚合成员,也使用
抽象
我正在为我的应用程序建模通用授权子域.这些要求非常复杂,因为它需要处理多租户,分层组织结构,资源组,用户组,权限,用户可编辑权限等.它是RBAC(分配给角色的用户,具有权限的角色,权限可以执行命令)与基于声明的身份验证的混合体. 问题 在检查业务规则不变量时,我必须遍历权限“图”以找到用户对环境中的资源执行命令的权限.遍历深度在多个维度上是任意的. 我可以使用代码对此进行建模,但最好使用图形数据库来表示,因为此聚合上的查询/更新会更快.此外,它会降低代码本身的复杂性.但这需要图形数据库立即保持一致. 不过,我需要使用CQRS / ES,并启用分布式架构. 所以图数据库需要 >立即一致 这带来了一些缺点 >从事件存储加载事件时,我们每次都必须重建图数据库 但它有优势 >降低执行复杂查询的复杂性 为什么提出此问题呢? 在我建模的其他聚合中,我经常有一个EntityList实例或EntityHierarchy实例.它们基本上是子实体的有序/分层集合.他们的实施是任意的.它们可以支持索引,键值对,动态数组等任何内容.只要它们实现我为它们声明的接口.我经常在这些实体(列表)上使用findById()或findByName()等方法.这些方法类似于可以在数据库上执行的方法,但它们是在内存中执行的. 那么,为什么不能实现这样一个可以绑定到数据库的列表呢?例如,我没有TMemoryEntityList,而是拥有TMySQLEntityList.在目前的情况下,可能需要实现一个存在于TOrgAuthPolicy聚合内的TGraphAuthorizationScheme.只要它的行为类似于集合,并且它可以迭代并支持定义的接口. 我正在使用Node.js上的JavaScript构建我的应用程序.这个叫做LevelGraph的内存实现.也许我也可以使用它.但是让我们继续吧. 提案 我知道在DDD术语中,基础设施不应泄漏到域中.这就是我想要阻止的.这也是我提出这个问题的原因之一,就是这是我第一次遇到这样的技术需求,我要求那些习惯于应对这类问题的人提出一些建议. 该集合的接口是IAuthorizationScheme.实现必须支持深度遍历,授权查找等.这是我正在考虑通过支持图形数据库来实现的接口. 序列 : 1当用户要求执行命令时,我首先验证他.我找到他的组织,并要求OrgAuthPolicyRepository加载他的组织的相应OrgAuthPolicy. > OrgAuthPolicyRepository从EventStore加载事件. 示例: 在简历中 可以想象/希望使用外部数据库(例如图形数据库)实现实体,以便它们的实现更容易吗?如果是,是否有此类实施或指南的示例?如果没有,使用这种技术有什么缺点?
为了解决您的任务,我会考虑从上到下的以下变体:
>通过使用安全框架或身份来降低任务复杂性 关于这个问题,你应该使用引入专用的图形数据库,如果不了解你的领域,预算,所需的系统吞吐量和性能,现有的基础设施,团队知识和设置等,就无法回答.你需要使用专用的图形数据库估算解决方案的成本.没有它.我的填充是,除非权限管理是您项目的主要想法,或者您的项目已经足够成熟(按用户数量和R& D容量),专用数据库不太可能为您的任务支付费用. 要了解拥有专用图形数据库可能带来的好处,您现有的存储解决方案应该采用相反的方式.这两篇文章很好地解释了这些好处: > http://neo4j.com/developer/graph-db-vs-nosql/ (编辑:李大同) 【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容! |