博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
JBoss 系列六十三:JBoss 7/WildFly 集群之 Java Persistence API (JPA) - II(Hibernate查询缓存和二级缓存示例)...
阅读量:6276 次
发布时间:2019-06-22

本文共 2599 字,大约阅读时间需要 8 分钟。

hot3.png

概述

中讨论了JBoss集群情况下JPA相关的基本理论,JBoss的JPA实现是Hibernate,所以JBoss集群JPA主要是Hibernate集群,在基本理论中我们说明了Hibernate的一级缓存(查询缓存)和二级缓存,本文给出一个Hibernate一级缓存(查询缓存)和二级缓存示例,示例大致架构如下图所示:

如上为两个节点的集群,Web应用提供REST接口,供外界访问来操作数据库,REST语法如下:

  • http://<IP>:<PORT>/cluster-demo-jpa/test/addUsers/{number} 用来添加用户
  • http://<IP>:<PORT>/cluster-demo-jpa/test/getUserByName/{name}用来查询用户

应用使用JPA/hibnernate操作数据库,Hibernate 二级缓存基于数据库之上。

JBoss端以及数据库端的配置

添加Oracle数据库驱动模块到JBoss

在JBOSS_HOME/modules/目录下创建com/oracle/main目录,将Oracle驱动jar(ojdbc6.jar)拷贝到此目录下,并同在此目录下创建module.xml文件,添加内容如下:

添加驱动配置到JBoss服务器配置文件

编辑JBOSS_HOME/standalone/configuration/standalone-ha.xml文件,在<subsystem xmlns="urn:jboss:domain:datasources处datasources,drivers中添加如下内容:

oracle.jdbc.xa.client.OracleXADataSource
注意,此部分配置,我们在之前的系列 中有所提及。

Oracle数据库端的配置

使用DBA用户连接到Oracle数据库控制台,创建demo_user/soong,并分配相应的权限,如下:

sqlplus / as sysdbacreate tablespace TESTSPACE datafile '/oracle/oradata/TESTSPACE.DBF' size 100Mcreate user demo_user identified by soong default tablespace TESTSPACE;grant connect,resource,dba to demo_user;

启动JBoss

以上配置完成,我们启动两个JBoss节点构成一个集群,如下:

./standalone.sh -c standalone-ha.xml -b 10.66.218.46 -bmanagement=10.66.218.46 -u 239.255.100.100 -Djboss.node.name=node1./standalone.sh -c standalone-ha.xml -b 10.66.218.47 -bmanagement=10.66.218.47 -u 239.255.100.100 -Djboss.node.name=node2

部署应用到JBoss

本示例代码位于(),使用中描述的方法下载示例代码,编译代码。在编译之前我们需要做一些修改配置。

配置DataSource

配置DataSource文件指向Oracle数据库,具体编辑jpa/src/main/webapp/WEB-INF/cluster-jpa-ds.xml文件指向Oracle数据库:

jdbc:oracle:thin:@//10.66.192.144:1521/JBOSS
oracle
demo_user
soong

配置persistence-unit

配置persistence-unit,包括Datasource相关,缓存相当,具体编辑jpa/src/main/resources/META-INF/persistence.xml,配置内容如下:

java:jboss/datasources/JBossClusterDemoJPADS
ENABLE_SELECTIVE

编译生成部署包

使用中描述的方法,执行

mvn clean install

部署应用及测试

上面步骤完成会生成jpa/target/cluster-demo-jpa.war文件,使用描述方法部署应用。

测试添加用户

部署成功后在节点1上添加用户:

添加成功后页面会返回字符串,类似:“Add 1 users to database spend 154 milliseconds

测试查询用户

使用

通过节点2查询用户name-499,将会返回字符串类似:“Get 164 users spend 614 milliseconds

理解Invalidation

本示例中集群两个节点之间通过Invalidation(失效)来确保数据连续性,失效模式是一种集群缓存,但实际上集群中各个节点之间并没有共享任何数据,而仅仅是从运行节点上在移除可能是过时的数据,详细理解参照。

转载于:https://my.oschina.net/iwuyang/blog/197190

你可能感兴趣的文章
文件查找工具之find命令详解
查看>>
linux命令 — lsof 查看进程打开那些文件 或者 查看文件给那个进程使用
查看>>
PHP+Swoole及时通讯
查看>>
centos安装图形
查看>>
SpringCloud(第 012 篇)电影微服务接入 Feign 进行客户端负载均衡,通过 FeignClient 调用远程 Http 微服务...
查看>>
mysql tomcat redis nginx 版本的查看方法
查看>>
php判断ajax请求
查看>>
C语言中函数strcpy ,strncpy ,strlcpy的用法
查看>>
RedHat Linux卸载rpm包遇到error: specifies multiple packages
查看>>
centos6.4 http dhcp nfs pxe kickstart 自动化安装系统
查看>>
漫游配置文件
查看>>
数据的存储介质-固态存储SSD
查看>>
oracle PL/SQL 流程控制
查看>>
Linux下/proc目录简介
查看>>
jenkins自动同步配置文件
查看>>
Windows系统清理 只需做到五大方面
查看>>
我的友情链接
查看>>
sql server 2005 (select查询语句用法)
查看>>
Spring整合Hibernate(1)
查看>>
3月7日作业
查看>>