JPA + EclipseLink + 云平台 = 运行在云端的数据库应用
data:image/s3,"s3://crabby-images/daf93/daf93a94fef6c76be6071f0e04c1407ebc42cd68" alt="JPA + EclipseLink + 云平台 = 运行在云端的数据库应用"
JPA(Java Persistence API)的实现 Provider 有 Hibernate,OpenJPA 和 EclipseLink 等等。
本文介绍如何通过 JPA + Eclipse 连接 SAP 云平台上的 HANA 数据库实例。
1. 登陆 SAP 云平台 Cockpit,创建一个新的 HANA DB 实例:
data:image/s3,"s3://crabby-images/b4363/b4363b71dabf2fcfda184b44d2a8030aab2bad8b" alt=""
设置数据库 ID 和 System user 的密码。
data:image/s3,"s3://crabby-images/b1c8b/b1c8bca127b05309da670a399c230adb5871bcc3" alt=""
创建成功后,HANA DB 实例状态为 CREATING:
data:image/s3,"s3://crabby-images/0510c/0510c8a455d63b90454c417748fd68abeeb2fb85" alt=""
data:image/s3,"s3://crabby-images/4d35b/4d35b6a87dd359f4fea42d3175bba5129bde69b0" alt=""
稍等片刻后,状态变为 STARTED,可用。
data:image/s3,"s3://crabby-images/ece6d/ece6da9e274bc25b84268827caa16a8b9005672c" alt=""
2. 接下来就可以开发 Java 应用通过 JPA 操作这个云端的数据库实例了。
data:image/s3,"s3://crabby-images/d811e/d811efdf4d7a86faed0d023ab2d8eefba715f0ae" alt=""
SAP 云平台 neo 环境的 SDK 下自带了一个 JPA 的 hello world 应用,位于文件夹 samples 下面,名称为 persistence-with-jpa:
data:image/s3,"s3://crabby-images/7b949/7b949ba78ee828e0f9ecc7be9c1172ca4063e2d6" alt=""
直接 import 到 Eclipse 里,targeted Runtimes 选择为 Java Web Tomcat 8:
data:image/s3,"s3://crabby-images/6c2f9/6c2f9f24038dc14d49b79770fd76bb325be995db" alt=""
再将该应用从 Eclipse 部署到 SAP 云平台上:
data:image/s3,"s3://crabby-images/815f0/815f00865f8ec8d02d28564e580fc22b3bfacdcf" alt=""
data:image/s3,"s3://crabby-images/1c849/1c8490b127ee9c0a52384c3a65c680d9ace910a4" alt=""
部署成功后,在 SAP 云平台 Cockpit 里得到该应用的访问 url:
data:image/s3,"s3://crabby-images/5b8c9/5b8c95e543b045ee2e46773c935b7348c134935f" alt=""
3. 将部署完成的 Java 应用与第一步创建的 HANA DB 实例进行绑定:
data:image/s3,"s3://crabby-images/cb63f/cb63f2afa11625587ea178f7d3c42de9999abc8f" alt=""
data:image/s3,"s3://crabby-images/4fdd8/4fdd85062d2b94c58534ea16d98915c6b20a8c8d" alt=""
绑定成功,这样该 Java 应用就能使用云端的 HANA DB 实例了。
data:image/s3,"s3://crabby-images/afe13/afe1338fd596136422dc46940d3abe8a5e2c9a48" alt=""
在 PC 浏览器里测试。这个 hello world 的 JPA 应用只设计了一张表,包含 First Name 和 Last Name 两列。
data:image/s3,"s3://crabby-images/0cdfd/0cdfd1319fbf72885a003d2aa6d92064dff632ec" alt=""
data:image/s3,"s3://crabby-images/697e4/697e42bb1ebce9d1fc607d0529302117f159d666" alt=""
data:image/s3,"s3://crabby-images/d2bac/d2bacc3ce17e096dd7481f9862d47e29f6f89dfa" alt=""
在手机端的访问:
data:image/s3,"s3://crabby-images/0e77e/0e77eb33fc3123091d35b95a590ace3455256d9e" alt=""
SAP 云平台以微服务的方式提供了 Document 的 CRUD(增删改查)操作。该微服务基于标准的 CMIS 协议(Content Management Interoperability Service)。
data:image/s3,"s3://crabby-images/a8988/a89886d2bb7971123bcd950b4ffe2a99342d7d33" alt=""
data:image/s3,"s3://crabby-images/5f917/5f9173d6fc5b01120545b9058367b76a920799a8" alt=""
同标准的 CMIS 相比,SAP 云平台的 Document Service 增添了一些功能的支持:
data:image/s3,"s3://crabby-images/5b3da/5b3da034b7ccc277d57ddc45ac721fcb1884665a" alt=""
通过一个 Hello World 应用来了解如何在 Java 程序里消费 SAP 云平台的 Document Service。
通过这个链接下载例子程序。
点击该超链接下载 Java Web Tomcat 8 SDK。
data:image/s3,"s3://crabby-images/96d54/96d54ea4a5b289f846e1c82e45e8125bf1c32c4f" alt=""
例子程序位于该 SDK 的 samples 文件夹下。
data:image/s3,"s3://crabby-images/3aca0/3aca032ed9de8c57219c02fb7c22d1d0dec0befb" alt=""
将该应用部署到 SAP 云平台之后,访问该应用看到如下提示信息:
data:image/s3,"s3://crabby-images/0e82a/0e82a1e5d01c79888fd852a6293b1b8bae390917" alt=""
该提示信息是由应用的 DocumentStoreServlet 的 goGet 方法输出:
data:image/s3,"s3://crabby-images/5e999/5e999fd20a71989e6accb13cc5bd4090f90920c5" alt=""
一旦点击 Connect 超链接之后:
data:image/s3,"s3://crabby-images/be092/be09283534ec6ed58037bcece1773b6d0a7c41ef" alt=""
调用另一个 Servlet DocumentStoreConnectServlet 的 doGet 方法,执行三个逻辑:
data:image/s3,"s3://crabby-images/ebc00/ebc0083254890273e0f7ad35d9d400ea966c335b" alt=""
Step 1 的 Ecm 即 Enterprise Content Management,指 SAP 云平台上的 Document Service。
该 Document Service 的实例句柄通过 JNDI 获得:
data:image/s3,"s3://crabby-images/c30c6/c30c6813dda430724945127fc2ff67fbd50519c8" alt=""
在 web.xml 里进行配置:
data:image/s3,"s3://crabby-images/8949f/8949f2d563f6227515ea0bf2c4ca63e851d8ebb5" alt=""
第一次点击 Connect 时,会执行下图 catch 分支的代码,用硬编码的密匙创建一个新的 repository。第二次执行即进入第 85 行逻辑,因此此时 repository 已经存在。
data:image/s3,"s3://crabby-images/340ec/340ec3620136b83c50a88fab3f467d7af1313503" alt=""
第一次点击 Connect 的输出:
data:image/s3,"s3://crabby-images/06d11/06d11931f860e8b3c47233bd9fe549605279da80" alt=""
第二次的输出:
data:image/s3,"s3://crabby-images/44b48/44b48bfd7ff9fdbb600e91f99573214ae79d6850" alt=""
在 SAP 云平台的 Cockpit 里能够看到成功创建的 repository:
data:image/s3,"s3://crabby-images/057dc/057dc31818edf1f82672561b7facf0bd57ae8b26" alt=""
如果需要删除该 repository,需提供创建时硬编码的密匙 abcdef0123456789。
data:image/s3,"s3://crabby-images/86d62/86d62ec5287298836eb78d922c7796842f198a88" alt=""
版权声明: 本文为 InfoQ 作者【Jerry Wang】的原创文章。
原文链接:【http://xie.infoq.cn/article/8eab7f698ca93680523a0d15f】。文章转载请联系作者。
评论