首页
/ Apache OpenWhisk Cloudant数据库套餐使用详解

Apache OpenWhisk Cloudant数据库套餐使用详解

2024-12-23 04:38:29作者:晏闻田Solitary

1. 安装指南

在Bluemix上设置Cloudant数据库

  1. 在Bluemix控制台中创建一个Cloudant服务实例。

  2. 确保创建服务实例后,生成了一个凭证密钥。

  3. 刷新命名空间中的包,以自动为每个定义了凭证密钥的Cloudant服务实例创建包绑定。

    wsk package refresh
    
  4. 检查创建的包绑定是否已配置了与你的Cloudant服务实例对应的托管主机和凭证。

    wsk package get /<yourBluemixOrg>_<yourBluemixSpace>/Bluemix_<yourCloudantServiceInstance>_Credentials-1 parameters
    

在Bluemix之外设置Cloudant数据库

如果你不是在Bluemix上使用OpenWhisk和Cloudant,或者你希望在Bluemix之外设置你的Cloudant数据库,你需要手动为你的Cloudant账户创建包绑定。

  1. 使用以下命令创建一个配置了你的Cloudant账户的用户名、密码和主机名的包绑定。

    wsk package bind /whisk.system/cloudant <yourPackageName> -p username <yourCloudantUsername> -p password <yourCloudantPassword> -p host <yourCloudantAccount>.cloudant.com
    
  2. 确认包绑定已创建。

    wsk package list
    

2. 项目的使用说明

本项目提供的/whisk.system/cloudant包允许你与Cloudant数据库进行交互,其中包括以下操作和馈送:

  • /whisk.system/cloudant:用于操作Cloudant数据库的包。
  • /whisk.system/cloudant/read:从数据库中读取文档的动作。
  • /whisk.system/cloudant/write:向数据库中写入文档的动作。
  • /whisk.system/cloudant/changes:数据库变化时触发事件的馈送。

3. 项目API使用文档

监听Cloudant数据库的变化

你可以定义一个过滤函数,以避免不必要的变更事件触发你的触发器。

创建一个名为design_doc.json的JSON文档文件,包含以下过滤函数:

{
  "doc": {
    "_id": "_design/mailbox",
    "filters": {
      "by_status": "function(doc, req){if (doc.status != req.query.status){return false;} return true;}"
    }
  }
}

在你的数据库中创建一个新的设计文档,包含过滤函数:

wsk action invoke /_/myCloudant/write -p dbname testdb -p overwrite true -P design_doc.json -r

使用changes馈送配置服务,以便在Cloudant数据库的每次变更时触发一个触发器。参数如下:

  • dbname:Cloudant数据库名称(必填)。
  • maxTriggers:达到此限制时停止触发(可选,默认为无限)。
  • filter:在设计文档上定义的过滤函数(可选)。
  • query_params:过滤函数的额外查询参数(可选)。

向Cloudant数据库写入数据

使用write动作将文档存储到名为testdb的Cloudant数据库中。确保该数据库存在于你的Cloudant账户中。

wsk action invoke /_/myCloudant/write --blocking --result --param dbname testdb --param doc "{\"_id\":\"heisenberg\",\"name\":\"Walter White\"}"

从Cloudant数据库读取数据

使用read动作从名为testdb的Cloudant数据库中获取文档。确保该数据库存在于你的Cloudant账户中。

wsk action invoke /_/myCloudant/read --blocking --result --param dbname testdb --param id heisenberg

4. 项目安装方式

请参照上述的“安装指南”部分,根据你使用的环境是在Bluemix上还是Bluemix之外,按照相应的步骤进行安装。

登录后查看全文
热门项目推荐

热门内容推荐

最新内容推荐

项目优选

收起
ohos_react_nativeohos_react_native
React Native鸿蒙化仓库
C++
178
263
RuoYi-Vue3RuoYi-Vue3
🎉 (RuoYi)官方仓库 基于SpringBoot,Spring Security,JWT,Vue3 & Vite、Element Plus 的前后端分离权限管理系统
Vue
868
514
openGauss-serveropenGauss-server
openGauss kernel ~ openGauss is an open source relational database management system
C++
130
183
openHiTLSopenHiTLS
旨在打造算法先进、性能卓越、高效敏捷、安全可靠的密码套件,通过轻量级、可剪裁的软件技术架构满足各行业不同场景的多样化要求,让密码技术应用更简单,同时探索后量子等先进算法创新实践,构建密码前沿技术底座!
C
288
323
HarmonyOS-ExamplesHarmonyOS-Examples
本仓将收集和展示仓颉鸿蒙应用示例代码,欢迎大家投稿,在仓颉鸿蒙社区展现你的妙趣设计!
Cangjie
398
373
CangjieCommunityCangjieCommunity
为仓颉编程语言开发者打造活跃、开放、高质量的社区环境
Markdown
1.07 K
0
ShopXO开源商城ShopXO开源商城
🔥🔥🔥ShopXO企业级免费开源商城系统,可视化DIY拖拽装修、包含PC、H5、多端小程序(微信+支付宝+百度+头条&抖音+QQ+快手)、APP、多仓库、多商户、多门店、IM客服、进销存,遵循MIT开源协议发布、基于ThinkPHP8框架研发
JavaScript
93
15
note-gennote-gen
一款跨平台的 Markdown AI 笔记软件,致力于使用 AI 建立记录和写作的桥梁。
TSX
83
4
cherry-studiocherry-studio
🍒 Cherry Studio 是一款支持多个 LLM 提供商的桌面客户端
TypeScript
600
58
GitNextGitNext
基于可以运行在OpenHarmony的git,提供git客户端操作能力
ArkTS
10
3