Java EE 7的高峰–使用EclipseLink的多租户示例

水族馆是有关所有相关规范和参考实现中有关Java EE进度的灵感和最新信息的重要来源。 他们从Oracle的Shaun Smith( 博客 / twitter )获得了关于EclipseLink作为开源项目的地位和未来的演讲。 他介绍了将在EclipseLink 2.4中提供的所有新功能,这些功能将与June Eclipse Juno发行版一起提供。 详细来说,这些是REST,NoSQL和Multitenancy。 (详细信息请参阅marsjug事件的完整幻灯片(PDF) 。)

我喜欢看到EclipseLink仍然是Java持久性创新的中心,并且他们正在努力及时采用最新的动态更新。 总的来说,我为一个较为保守的行业工作,我正在寻找的主要新功能是多租户。 您可以从幻灯片中猜测,该字段中的某些内容应该已经可以与最新的EclipseLink 2.3.0一起使用。

多租户将是什么样子?
让我们开始看什么Oracle的琳达DeMichiel在过去几年的JavaOne(对比宣布博客-后 ),也让我们了解一下什么的早期草案(PDF)的JPA 2.1规范所提供的。 较容易的部分是早期草案。 在任何情况下,没有一行提到“ Multitenan [t | cy]”。 因此,对于进一步的迭代来说,这显然仍然是一件大事。 在JavaOne策略主题演讲 (幻灯片41,42)和JavaOne技术主题演讲(PDF) (幻灯片25)中可以找到更多信息。 通用Java EE 7方法将为不同租户支持同一应用程序的单独隔离实例。 映射应由容器完成,并以某种方式可供应用程序使用。 直到今天,这都是非常模糊的,幻灯片中唯一可用的具体代码示例使用两个注释@Multitenant和@TenantDiscriminatorColumn引用了一些明显的JPA相关示例。 嗯 这看起来对您不熟悉吗?

今天有什么可能?
是的! EclipseLink(从2.​​3.0版开始-Indigo)使用承租人区分符列支持共享的多承租人表,从而允许将一个应用程序重新用于多个承租人并将其所有数据放置在一起。 所有租户共享相同的架构而彼此之间不知道,并且可以照常使用非多租户实体类型。 但是请注意,这只是数据多租户的一种可能方法。 这通常称为“专用数据库”,因为所有租户的数据都进入一个单独的数据库中! 以下是基本原则: –应用程序实例处理多个租户 – JPA必须隔离每个租户的缓存 您可以在专用的EclipseLink Wiki页面上查看所有详细信息。 想要试驾吗? 开始吧。 像往常一样先决条件(NetBeans,GlassFish,MySQL,如果需要更多帮助,请比较旧文章。)。 确保具有正确的EclipseLink依赖项(至少2.3.0)! 通过向导创建一个新实体,设置数据源和persistence.xml并将其命名为“客户”。

@Entity
public class Customer implements Serializable {
//...
}

如果启动您的应用程序,则会看到EclipseLink在数据库中创建类似这样的内容。

让我们使其成为一个多租户实体。 添加以下注释:

@Entity
@Multitenant
@TenantDiscriminatorColumn(name = "companyId", contextProperty = "company-tenant.code")
public class Customer implements Serializable {
//...
}

有多种用法选项可用于如何在具有@Multitenant实体类型的应用程序中使用EclipseLink JPA持久性单元。 由于不同的租户将只能访问其行,因此必须配置持久层,以使来自不同租户的实体不会出现在同一缓存中。 如果您比较详细的方法(专用PC,每个租户PC,每个租户PU),您会发现,到今天为止,您可以通过容器管理的PC或PU注入实现两种可能的选择。 让我们首先尝试最简单的方法。

专用持久性单元
在这种用法中,每个租户都定义了一个持久性单元,应用程序/容器必须为其租户请求正确的PersistenceContext或PersistenceUnit。 只有一个持久性单元,没有共享的内容。 继续上面的示例,然后将以下属性添加到persistence.xml中:

<property name="company-tenant.code" value="TENANT1" />

试试看,比较表。

如您所见,现在您有了companyId列。 如果插入一些数据,它将始终被在persistence.xml中分配的属性值填充。 使用@PersistenceContext或@PersistenceUnit访问您的实体。 使用这种方法,您可以像平常一样为应用程序共享一个缓存。

具有共享缓存的@PersistenceContext(来源:S.Smith)

每个租户的持久性上下文
如果不想每个应用程序有一个租户,则可以决定在persistence.xml中具有一个持久性单元定义,并在应用程序中具有一个共享的持久性单元(EntityManagerFactory和缓存)。 在这种情况下,需要在运行时为每个EntityManager指定承租人上下文。 在这种情况下,您可以使用常规实体类型的共享缓存,但是@Multitenant类型必须在缓存中受到保护。 您可以通过指定一些属性来做到这一点:

@PersistenceUnit
EntityManagerFactory emf;
Map props = new HashMap();
props.put("company-tenant.code", "TENANT2");
props.put(PersistenceUnitProperties.MULTITENANT_SHARED_EMF, true);
EntityManager em = emf.createEntityManager(props);
每个租户共享@PersistenceUnit(来源:S.Smith)

鉴别方法
上面的示例使用单个区分符租户列。 您可以通过指定primaryKey属性,将discriminator列添加到PK,如下所示:

@TenantDiscriminatorColumn(name = "companyId", contextProperty = "company-tenant.code", primaryKey = true)

如果执行以下操作,则也可能使用多个表使用多个租户区分符列:

@Entity
@SecondaryTable(name = "TENANTS")
@Multitenant
@TenantDiscriminatorColumns({@TenantDiscriminatorColumn(name = "TENANT_ID", contextProperty = "company-tenant.id", length = 20, primaryKey = true),@TenantDiscriminatorColumn(name = "TENANT_CODE", contextProperty = "company-tenant.code", discriminatorType = DiscriminatorType.STRING, table = "TENANTS")
})

这将导致辅助租户表。

其他物品
与往常一样,您也只能在persistence.xml中进行完整的配置。 作为参考,请查看已经提到的Wiki页面。 最后一件事很有趣。 您也可以将“租户区分符”列与您的实体对应。 您只需确保未更新或插入它即可。

@Basic@Column(name = "TENANT_ID", insertable = false, updatable = false)private int tenantId;public int getTenantId() {return tenantId;}

查看调试输出,您可以了解幕后情况:

INFO:获取EntityManager
INFO:插入测试客户
FEIN:插入客户(ID,TENANT_ID)值(?,?) 绑定=> [1,2] FEIN:插入租户(ID,TENANT_CODE)的值(?,?) 绑定=> [1,TENANT2] FEIN:从客户t0,租户t1中选择t0.ID,t1.TENANT_CODE,t0.TENANT_ID,t1.ID((((t1.ID = t0.ID)和(t1.TENANT_CODE =?)))和(t0.TENANT_ID =?)) 绑定=> [TENANT2,2]

是否对更多Java EE 7和JPA 2.1好东西感兴趣? 使用EclipseLink JPA 2.1项目的开发状态Wiki页面保持更新。

参考: Java EE 7的最高峰–来自我们JCG合作伙伴的 EclipseLink的多租户示例   Markus Eisele在Enterprise Software Development with Java博客上。


翻译自: https://www.javacodegeeks.com/2012/02/sneak-peak-at-java-ee-7-multitenant.html

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/373776.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

vscode中如何拉取git代码_使用VSCode如何从github拉取项目的实现

使用VSCode如何从github拉取项目的实现最近使用vscode进行前端编程&#xff0c;遇到一些问题网上说明的不是很明显&#xff0c;故记录一下1.开vscode使用CTRL或者点击查看到集成终端打开控制终端到此这篇关于使用VSCode如何从github拉取项目的实现的文章就介绍到这了,更多相关V…

matlab求导

在matlab中求导要进行符号运算。 >>syms x; >>y x^cos(x); >>ydot diff(y, x, 1);%对x求一阶导数 ydot x^(cos(x) - 1)*cos(x) - x^cos(x)*log(x)*sin(x) >> y2dot diff(y, x, 2)%求二阶导数&#xff0c;求n阶导数同理。 y2dot cos(x)*(x…

带有Java和Axis2的JSON Web服务

我最近遇到一位客户&#xff0c;要求我使用Java Web服务重建其旧产品。 他们希望它模块化并且易于使用。 我想到的第一件事是使用宁静的方法。 但是让我烦恼的是&#xff0c;Java宁静的方法是使用XML !&#xff0c;我更喜欢一种更简单的通信方式&#xff0c;易于理解和解析的数…

Kosaraju算法 有向图的强连通分量

有向图的强连通分量即&#xff0c;在有向图G中&#xff0c;如果两个顶点间至少存在一条路径&#xff0c;称两个顶点强连通(strongly connected)。如果有向图G的每两个顶点都强连通&#xff0c;称G是一个强连通图。非强连通图有向图的极大强连通子图&#xff0c;称为强连通分量(…

监管大屏系统_工厂大屏可视化管控系统,智慧工厂平台是什么,工厂管理大屏软件 - 帆软...

智慧工厂大屏可视化管控系统&#xff0c;不但注重显示数据显示信息能力&#xff0c;还要兼具监管的作用&#xff0c;配合时代新兴的大屏技术&#xff0c;早已成为精益生产工厂的必备产品。本文权威介绍智慧工厂大屏可视化管控系统是什么&#xff0c;以及3款主流软件&#xff0c…

图像二维离散傅里叶变换、幅度谱、相位谱

clear, clc I imread(...);F fftshift(fft2(I)); % 对图像进行二维 DFT(fft2)&#xff0c;并移至中心位置 magn log(abs(F)); % 加 log 是便于显示&#xff0c;缩小值域 phase log(angle(F)*180/pi); % 转换为度数…

详解CSS选择器、优先级与匹配原理

选择器种类 严格来讲&#xff0c;选择器的种类可以分为三种&#xff1a;标签名选择器、类选择器和ID选择器。而所谓的后代选择器和群组选择器只不过是对前三种选择器的扩展应用。而在标签内写入style""的方式&#xff0c;应该是CSS的一种引入方式&#xff0c;而不是选…

关于299$的企业开发者账号的申请流程

299$的企业开发者账号 Apple Developer Enterprise Program•一年1988人民币 - 企业 (Apple Developer Enterprise Program)- 公司应在邓白氏注册并拥有有效的 DUNS 号码。&#xff0d;此计划使开发者能够开发针对 Apple 设备的应用程式&#xff0c;并对其员工进行发布&#xf…

keras 多层lstm_tensorflow-如何在keras中堆叠多个lstm?

DanielAdiwardana的答案的详细说明。我们需要为除最后一层之外的所有LSTM层添加return_sequences True。将此标志设置为True可让Keras知道LSTM输出应包含所有历史生成的输出以及时间戳(3D)。 因此&#xff0c;下一个LSTM层可以进一步处理数据。如果此标志为假&#xff0c;则LS…

Java堆空间– JRockit和IBM VM

本文将为您提供JRockit Java堆空间与HotSpot VM的概述。 它还将为您提供有关JRockit和HotSpot的Oracle未来计划的一些背景知识。 Oracle JRockit VM Java堆&#xff1a;2个不同的内存空间 -Java堆&#xff08;YoungGen和OldGen&#xff09; -本机内存空间&#xff08;类池&am…

如何搭建lamp(CentOS7+Apache+MySQL+PHP)环境 [转]

在网上搜资料,自己在本地虚拟机上尝试搭建,弄了整整一天一夜,终于弄好了.网上的资料,虽然很多,但大多都是重复的,拿去试了之后,又很多都不能得到正确的结果.最终找到了适合我的linux环境的搭建方式;在这里贴出来:Install Apache, PHP And MySQL On CentOS 7 (LAMP)度娘真不给力…

为什么要用!DOCTYPE声明

实例&#xff1a; 我们经常会看到类似这样的代码&#xff1a; <!DOCTYPE html> <html> <head> <title>文档的标题</title> </head> <body> 文档的内容...... </body> </html>注解&#xff1a;可以看到最上面有一行关于“…

java 线程的开始、暂停、继续

Android项目中的一个需求&#xff1a;通过线程读取文件内容&#xff0c;并且可以控制线程的开始、暂停、继续&#xff0c;来控制读文件。在此记录下。 直接在主线程中&#xff0c;通过wait、notify、notifyAll去控制读文件的线程&#xff08;子线程&#xff09;&#xff0c;报错…

为什么要在Java中使用Unchecked异常而不是Checked异常

关于检查与未检查的异常的争论可以追溯到过去。 有人说这是Java包含的最佳功能之一。 其他人则说这是他们最大的错误之一[ 1 ]。 辩论似乎结束了。 在这篇文章中&#xff0c;我将尝试包含指向该主题的文章和书籍的链接。 我不是专家&#xff0c;但是我会尽力向您解释为什么我得…

batchplot插件用法_Batchplot批量打印怎么用?Batchplot批量打印教程

很多从事CAD设计工作的用户都碰到过这种情况&#xff1a;在一个单DWG格式的图纸文件中包含有大量图纸&#xff0c;如果一张一张选取打印不但费时费力&#xff0c;而且容易遗漏某张图纸&#xff0c;这时候就需要用到Batchplot插件&#xff0c;这是专门针对单DWG多图纸的批量打印…

选择排序和冒泡排序以及折半查找

1.选择排序 2.冒泡排序 3.折半查找 方式一&#xff1a;开发使用的方法 方式二&#xff1a;普通的折半 转载于:https://www.cnblogs.com/juncaoit/p/5935068.html

JSP中Request属性范围

JSP属性范围&#xff0c;通过以下几个测试代码来学习request属性的范围 测试一(JSP动态指令方式传参)&#xff1a; 测试内容&#xff1a; <jsp:param .../>添加参数,通过<jsp:forward page"...">来实现服务器端跳转,以此来测试request属性的范围&#…

Spring MVC – Flash属性

最新的Spring Framework版本&#xff08;3.1&#xff09;带来了有趣的功能&#xff0c;称为Flash属性。 这是对我很久以前在我的一篇文章中提到的问题的补救措施&#xff1a; Spring MVC –会话属性处理。 这个问题可以用几句话来形容&#xff1a;如果我们想通过两个控制器之间…

000 快速排序算法

一&#xff1a;概述 快速排序是东尼.霍尔所发展的一种快速排序算法。 对于n个项目的排序&#xff0c;平均O&#xff08;n*logn&#xff09;次比较&#xff0c;在比较糟糕的情况下是O&#xff08;n2&#xff09;次比较。 采用分治策略把一个串行分为两个子串行。 二&#xff1a;…

nginx post请求超时_nginx记录分析网站响应慢的请求(ngx_http_log_request_speed)

nginx模块ngx_http_log_request_speed可以用来找出网站哪些请求很慢&#xff0c;针对站点很多&#xff0c;文件以及请求很多想找出哪些请求比较慢的话&#xff0c;这个插件非常有效.作者的初衷是写给自己用的&#xff0c;用来找出站点中处理时间较长的请求, 这些请求是造成服务…