如何在 SAP BTP 平台上重用另一个已经开发好的 service
data:image/s3,"s3://crabby-images/f7cb5/f7cb51efac945a2ac60104349d2a1c629dec619a" alt="如何在 SAP BTP 平台上重用另一个已经开发好的 service"
假设我们的 SAP Business Technology Platform 平台上已经开发好了一个 products-service
项目:
data:image/s3,"s3://crabby-images/a85dd/a85ddd7adb3f66e79d4ef0329e3fa226d093594b" alt=""
我们希望在另一个 bookstore 项目里,重用 products-service
项目。
打开 products-service
项目,在 package.json 里找到其 name
的值:@sap/capire-products
data:image/s3,"s3://crabby-images/60083/600834c29e68d62a9edc32b0e4e3788084dad690" alt=""
创建一个 bookstore 项目:
mvn -B archetype:generate -DarchetypeArtifactId=cds-services-archetype -DarchetypeGroupId=com.sap.cds
-DarchetypeVersion=1.17.0
-DgroupId=com.sap.cap -DartifactId=bookstore
使用 open workspace 的功能打开这个项目:
data:image/s3,"s3://crabby-images/5653a/5653a6015ee114c8033f117c28872bb52fd5fc53" alt=""
执行如下命令行,安装指向 products-service
项目的依赖:
npm install $(npm pack ../products-service -s)
成功安装完毕,现在在 bookstore
项目里,就能看到其依赖 products-service
的实现了:
data:image/s3,"s3://crabby-images/6a783/6a7830a06a0e2c0034a267479ea95d8826347aba" alt=""
npm pack 从 products-service 创建一个 tarball,然后直接将其用作书店应用程序中的依赖项。 有关 npm 包的更多信息:https://docs.npmjs.com/cli-commands/pack.html。
data:image/s3,"s3://crabby-images/103cf/103cffd1dc54a8ae23a0a3ea77124167b6b6b204" alt=""
使用下面的命令行安装依赖:
npm install && npm dedupe
现在 bookstore
项目的 package.json 里,就能看到 products-service
项目的依赖了。
data:image/s3,"s3://crabby-images/b4609/b46094eb161213949c6ac0b9d5d9ede81018c363" alt=""
在 db 文件夹下新建一个 schema.cds
文件,维护 domain model:
data:image/s3,"s3://crabby-images/9d92d/9d92d83c84a89d65e1a82a11e61a1b5ba6204aeb" alt=""
在 srv 文件夹下创建一个 services.cds
文件:
data:image/s3,"s3://crabby-images/3239f/3239f44d80b669d02c0d3eff8c311c4ec44d7491" alt=""
在 db 文件夹下新建一个 data 文件夹,然后把 4 个 sample data 的 csv 文件放置进去。
使用命令行部署 domain model 到 sqlite:
cds deploy --to sqlite
自动生成了一个 sqlite.db
文件,该文件名维护在 package.json 文件里,文件位于项目根目录下:
data:image/s3,"s3://crabby-images/8ab95/8ab95d6006f84ca6fd96b2d80334fbb0fefc0ee5" alt=""
修改项目里的 Application.yaml 文件,将数据库的位置指向刚刚运行的命令行 cds deploy --to sqlite
生成的 sqlite.db
文件。
data:image/s3,"s3://crabby-images/9fb81/9fb81bf41b820d26b868396d63de14157347abae" alt=""
第 11 行设置成 never 的原因是因为我们已经用命令行 cds deploy --to sqlite
对数据库进行了初始化操作。
修改 Business Application Studio 的 settings.json
文件,添加如下内容:
选择 SQLTools
:
data:image/s3,"s3://crabby-images/669e1/669e18a6f1caadb7fd0f6166d39fd8e98f549ae3" alt=""
可以看到刚才通过 csv 文件插入的数据:
data:image/s3,"s3://crabby-images/d41fe/d41fed4e80ecafaa8a55c09f83b1107724e867c6" alt=""
使用如下 url:
https://workspaces-ws-pdwk4-app1.us10.trial.applicationstudio.cloud.sap/odata/v4/BooksService/Books
就能访问到之前通过 sap.capire.bookstore-Books.csv
插入到 SQLite 里的数据了:
data:image/s3,"s3://crabby-images/2a72f/2a72f476133bda8ce7dff1c9f4eec397c9e90f85" alt=""
data:image/s3,"s3://crabby-images/0f485/0f4851e45b18f6f7aa2c4c8355fb79fc6cff0981" alt=""
版权声明: 本文为 InfoQ 作者【Jerry Wang】的原创文章。
原文链接:【http://xie.infoq.cn/article/3e08ef11ae5dcbc12e69d669a】。文章转载请联系作者。
评论