nosql怎么使用

在之前的文章中,我讨论了如何通过结合使用Java Web Services , Java EE和CouchDB NoSQL数据库为产品构建SOA“实体”服务。 在本系列的最后一篇文章中,我将利用我已经创建的一些技术资产,并使用一些流行的SOA模式实现一些新的用户案例。 还要看一下第1 部分和第2部分 。

我当前的产品实体服务实现与业务流程无关,因此在消费者想要发现或存储产品信息的任何情况下都可以高度重用。 但是,按照现状,产品实体服务旨在在受信任的环境中使用。 这意味着对诸如创建,更新或删除之类的操作的访问没有任何限制。 在严格控制的公司沙箱中,这很好,但是如果我想与不信任的用户共享我的一些服务操作或产品信息怎么办?

让我们想象一下,除了内部使用产品实体服务外,我们还希望满足以下敏捷的“用户故事”……

这样一来:我发布的产品信息是准确的,并且经常可供非现场客户使用。
作为:销售总监和IT经理。
我们希望:向场外用户和系统提供我的产品信息的高可用性“只读”副本。

这种情况在商业中并不罕见,过去我已经与一些客户一起实现了类似的用户案例。 但是,关于我们用于实现实体服务的技术(Java / JAX-WS和CouchDB NoSQL)的奇妙之处在于,它们使开发此场景非常容易。

首先是建筑设计。

为了实现这个用户故事,我将针对服务体系结构调用另外两种SOA设计模式-服务数据复制和并发合同。 在第二篇文章中,我们已经讨论了“合同至上”的方法,因此除了要说它仍然适用于这里之外,我将不做任何其他详细说明。 该合同仍然是标准化和脱钩合同 。

服务数据复制是一种模式,可通过在基础结构上其他位置创建服务所需的数据的完整副本来帮助您实现高水平的服务自治性和可用性。 然后可以使用此副本代替原始副本,以平衡基础结构上的负载。

当“ [现有]服务的合同可能不适合或不适用于所有潜在服务使用者”时,将使用“ 并发合同”模式。 例如,当出于安全性,协议或可访问性的考虑,要求对特定的用户子集(例如异地用户或处理能力或带宽受限的移动设备)提供相似(但不相同)的内容。

为了实现我们的新用户故事,我们将同时使用这两种模式来提供产品实体服务的“只读”版本。 但是,通过提供产品实体服务的第二个“只读”版本,您也可以说我们正在部分实现冗余实现 SOA模式,因为我们为服务的某些关键操作提供了第二个冗余选项。

产生的架构看起来像这样(单击放大)…

服务合同。

最初的产品实体服务提供了五项操作- 获取,查找,创建,更新和删除,但是没有必要向外部人员提供所有这些功能,并且可能会遇到很多问题(在安全性,完整性等方面)。 我们当然不希望任何外部用户在未经我们许可的情况下创建或更新我们的产品信息。

因此,在新的“ 只读产品实体服务 ”的Web服务合同中,我完全删除了CreateUpdateDelete操作,仅提供了GetFind 。 所有数据类型保持相同(相同的Product.xsd描述产品实体等)。 保持数据类型相同很重要,因为我故意应用规范模式和模式集中化模式并利用标准化服务合同主体以避免转换。

Java代码。

有了这个新的只读服务,我仍然要先签订合同,因此我创建了一个新的Maven项目,在构建期间的首要任务是导入只读产品实体服务的WSDL联系人,并从中创建一组JAX。 -WS服务接口和数据对象。

从现在开始,我可以重用已经为“完整”产品实体服务开发的一些代码。 通过将以前的代码库重构为模块,我什至可以使Maven将原始代码视为该新服务的依赖项。 本质上,我感兴趣的是为GetFind操作的业务和持久性逻辑创建的EJB和DAO。

通过重用现有代码并在Amazon云上创建Glassfish服务器 ,我可以在创纪录的快速时间内站起来使用新服务,并且可以完成用户故事的一半。 我现在只需要一些可复制的产品数据即可使用…

开始数据复制。

Couch DB免费提供了出色的企业级复制系统。 这使得实现服务数据复制SOA模式非常容易。

Couch DB的内置数据复制器可以在网络或Web上可用的任何两个CouchDb实例之间复制整个文档数据库。 在这种情况下,我已经在名为IrisCouch的托管提供程序上创建了CouchDb数据库。 他们可以一口气为我提供安全的CouchDB实例或各种大小,并照顾所有必要的基础架构和备份要求。 对于小型用户,他们甚至免费这样做。

为了设置复制,我只需要使用CURL命令行工具通过HTTP向本地CouchDB实例发出特定指令即可。 这些说明告诉我的本地CouchDB服务通过Web将我的产品数据与IrisCouch上的远程CouchDB数据库进行复制 。

数据库复制指令是一个JSON文档,看起来像这样……

{'source':'products','target':'https://username:password@instance.iriscouch.com:6984/products','create_target':true,'continuous':true}

本质上,此JSON指令说“ 永远将本地产品数据库文档复制到远程Iriscouch实例 ”。 发出命令后,CouchDB立即开始工作,并开始将本地数据复制到远程数据库实例。 这包括更新和删除以及产品数据库中存储的所有“设计文档”。 然后,该产品副本可立即用于托管在Amazon EC2云中的我的只读产品实体服务。

从此以后,使用此服务的Get或Find操作的服务使用者将看到内部使用的数据的副本。 复制将使信息保持最新。

最后是用户验收测试。

那么,我们对新用户故事的要求做得如何?

通过将只读版本的产品实体服务托管在Amazon云上,我们创建了高度可用的非现场Web服务。 它提供的数据是我们在现场使用的数据的精确副本,在正常情况下两个副本之间的延迟只有最小的量。

如果我的现场网络出现故障,无论如何都将继续运行基于只读云的产品实体服务版本,并且由于我们使用的是Amazon云基础架构,因此如有必要,它可以受益于几乎无限的运行时资源。 可用性永远不会成为问题。 我们可以随时添加更多计算机,并提供负载平衡,并在必要时将计算机分布在多个大洲。

我的猜测是,销售总监会很高兴我们的客户总是可以看到我们产品目录中的信息,并且客户自己应该对他们现在所获得的全面而可靠的服务感到非常满意。 最后,IT经理会很高兴网络安全性保持不变,而且新的异地托管服务几乎不需要花钱就能运行,而且非常可靠。

剩下的就是向我们的客户宣传只读产品实体服务端点,并支持他们使用它。 总而言之,在办公室度过了非常成功的一天。

您想自己尝试只读产品服务吗?

端点详细信息可以在SOA Growers 简单服务存储库中找到 。 点击“服务资料库”链接,然后查找“ R20121231”? 释放。 在此处,您可以找到指向该服务的WSDL,WS-I证书的链接,以及指向一个托管在AWS微实例上的实时演示Web服务终端节点的链接。

体验现场演示的最佳方法是下载SOAP-UI测试套件。 该测试套件需要SOAP-UI v4(可以免费下载)。 测试套件包含对服务上所有可用操作的简单测试。

在线上了解整个博客系列…

这可能是本系列中有关使用Java和CouchDB构建实体服务的最后一部分。 如果您错过了本系列中的任何较早的博客文章,并且想赶上来,下面列出了其他条目…

  • 使用NoSQL实现实体服务–第1部分:概述
  • 使用NoSQL实现实体服务–第2部分:合同优先
  • 使用NoSQL实现实体服务–第3部分:CouchDB
  • 使用NoSQL实现实体服务–第4部分:JavaEE
别忘了分享!

参考: 使用NoSQL实施实体服务–第5部分:来自我们的JCG合作伙伴 Ben Wilcock的SOA,BPM,Agile和Java博客中的Cloud , 提高了自治性 。

翻译自: https://www.javacodegeeks.com/2012/09/implementing-entity-services-using.html

nosql怎么使用

nosql怎么使用_使用NoSQL实施实体服务–第5部分:使用云提高自治性相关推荐

  1. 使用NoSQL实施实体服务–第5部分:使用云提高自治性

    在先前的文章中,我讨论了如何通过结合使用Java Web Services , Java EE和CouchDB NoSQL数据库为产品构建SOA"实体"服务. 在本系列的最后一篇文 ...

  2. python给视频加水印_视频水印_Python SDK_服务端SDK_视频点播 - 阿里云

    初始化客户端 使用前请先初始化客户端,请参见 添加水印 调用AddWatermark接口,完成添加水印功能. 接口参数和返回字段请参见 说明水印文件OSS上传详细参数请参见from aliyunsdk ...

  3. nosql的数据服务_使用NoSQL实现实体服务–第3部分:CouchDB

    nosql的数据服务 在本系列的第2部分中 ,我使用SOA的"合同优先"技术创建和部署了产品实体服务,现在,我将致力于服务实现的NoSQL数据库方面. 正如我在第1部分中已经提到的 ...

  4. nosql的数据服务_使用NoSQL实现实体服务–第2部分:合同优先

    nosql的数据服务 现在该开始使用NoSQL项目对SOA实体服务进行编码了,并且正如我所承诺的,我将从Web服务的合同开始. 看一下本系列的第1部分 . 这种从Web服务合同定义开始的技术是面向服务 ...

  5. java nosql_使用NoSQL实现实体服务–第4部分:Java EE

    java nosql 现在,我已经准备好了一个框架式的合同优先型Web服务,并使用Ektorp和CouchDB创建了一个数据访问层 ,是时候将它们连接到一个可以正常工作的实体服务中了 . 为此,我将使 ...

  6. 使用NoSQL实现实体服务–第4部分:Java EE

    现在,我已经准备好了框架式的合同优先型Web服务,并使用Ektorp和CouchDB创建了数据访问层 ,是时候将它们连接到一个可以正常工作的实体服务中了 . 为此,我将使用Java EE和Glassf ...

  7. 使用NoSQL实现实体服务–第2部分:合同优先

    现在该开始使用NoSQL项目对SOA实体服务进行编码了,并且正如我所承诺的,我将从Web服务的合同开始. 看一下本系列的第1部分 . 这种从Web服务合同定义开始的技术是面向服务的体系结构实现的&qu ...

  8. 使用NoSQL实现实体服务–第3部分:CouchDB

    在本系列的第2部分中 ,我使用SOA的"合同优先"技术创建和部署了产品实体服务,现在,我将致力于服务实现的NoSQL数据库方面. 正如我在第1部分中已经提到的那样,我已经选择Cou ...

  9. 实体服务是一种反模式

    在微服务架构中,最重要的是要保持服务间的隔离.实体服务(Entity Service)是被广泛应用于微服务架构上的一种模式,但其实它是一种反模式,因为它背离了服务隔离的原则.Michael Nygar ...

最新文章

  1. centos 6是否已安装mysql_Centos6安装mysql
  2. python扫描目录下文件_Python扫描目录读取文件,不考虑子目录
  3. 数据结构趣题——顺序表就地逆置
  4. Liferay激活Navigation和Breadcrumb
  5. Python 编码规范 PEP 8
  6. python 人气高的项目_给大家推荐:五个Python小项目,Github上的人气很高的!
  7. python的使用说明_Python 的基本使用说明
  8. 苹果cmsV10仿哈哩哈哩动漫自适应模板
  9. JAVA 使用Jacob调用windows的Sapi实现文本转语音文件
  10. 机器学习算法中的F值(F-Measure)、准确率(Precision)、召回率(Recall)
  11. left join on 左边为主
  12. 用web查看hadoop运行状态
  13. 一周之内连过5人,HCIE-RS新版实验这么好考?
  14. Flash builder 4.6 下载 破解 序列号【你懂的】
  15. 苹果屏幕上的小圆点_原来苹果手机内置录屏功能,简单设置就打开,好多人没发现!...
  16. 车载BlueTooth通话机制原理及开发
  17. 用nodejs爬数据
  18. Cesium for Unreal 数据加载 场景漫游 粒子效果 视频监控 VR预览
  19. 36氪专访融云CEO董晗:8年企服,6年出海,现计划成为「沙特最大科技企业」
  20. Franka Emika Panda 机械臂环境配置

热门文章

  1. Java NIO总结
  2. Spring中的Bean配置、属性配置、装配内容详细叙述
  3. 263. 丑数---LeetCode---JAVA
  4. 计算机二级c语言考试模拟试题,计算机二级C语言考前模拟试题及答案2016
  5. python开发工具下所有软件都打不开_Python 开发工具链全解
  6. hashmap应用场景_工作中常用到的Java集合有哪些?应用场景是什么?
  7. springmvc新建拦截器
  8. spring(7)spring mvc 的高级技术
  9. gradle junit5_JUnit 5和Selenium –使用Gradle,JUnit 5和Jupiter Selenium设置项目
  10. xml json 比较_JSON和XML:它们如何比较?