在 SAP Kyma 上使用 Redis 服务

举报
汪子熙 发表于 2022/06/11 17:51:15 2022/06/11
【摘要】 链接:https://developers.sap.com/tutorials/cp-kyma-redis-function.html本地文件:C:\Code\referenceCode\SAP Kyma教程例子\redis-function包含一个 deployment 和两个 function: 函数1:cache-order定义了三个依赖:axiosredishandy-redis 环...

链接:https://developers.sap.com/tutorials/cp-kyma-redis-function.html

本地文件:C:\Code\referenceCode\SAP Kyma教程例子\redis-function

包含一个 deployment 和两个 function:

函数1:cache-order

定义了三个依赖:

  • axios
  • redis
  • handy-redis

环境变量

这些环境变量的用法,在代码里使用 process.env 加上中括号引用。

cache-order 函数的三大主要逻辑:

(1)从 Kyma 传入的 event 结构里,获得 Commerce 创建订单的 ID.

(2) 根据订单 ID,调用函数 getOrderDetails,获得订单明细。

(3) 从订单明细里获得含税的价格,调用函数 cacheOrder,将价格存储到 Redis 里:

getOrderDetails 的实现:

async function getOrderDetails(orderCode) {
  const ordersUrl = `${COMM_GATEWAY_URL}/${process.env.SITE}/orders/${orderCode}`;
  console.log("Getting ordering details via: %s", ordersUrl, " for orderCode: ", orderCode);
  const response = await axios.get(ordersUrl);
  console.log(JSON.stringify(response.data, null, 2));
  return response.data;
}

代码里的 COMM_GATEWAY_URL 环境变量,在 Kyma 控制台里能够找到:

cacheOrder 的实现,调用 redis client hmset 方法:

resources

定义了 CPU 和内存的 quota,以及源代码:

这里的意思是,一旦应用 mp-commerce-mock 的 order.created 事件触发,会调用 cache-order 这个 function:

函数2:get-order

该函数的实现文件里,还定义了一个 APIRule:

部署之后如图:

定义了一个 gateway:
gateway: kyma-gateway.kyma-system.svc.cluster.local

从 Redis 里获取数据的源代码:

const hredis = require("handy-redis");

const client = hredis.createNodeRedisClient({
  port:  process.env["REDIS_PORT"],
  host: process.env["REDIS_HOST"],
  password: process.env["REDIS_PASSWORD"]
});

module.exports = { 
  main: async function (event, context) {
    try {   
      const orderCode = event.extensions.request.query.orderCode;
      let result = await processGetRequest(orderCode);
      return result ? result : {"error": "orderCode was not found"};
    }
    catch(err) {
      console.log("an error occurred...", err);
      event.extensions.response.status(500).json({"error": err});
    }
  }
}

async function processGetRequest(orderCode){    
  if(orderCode !== undefined){
    console.log("getting order from cache: ", orderCode);
    return client.hgetall(orderCode);
  }else{
    throw "No orderCode received!"
  }
}

关于如何测试这些 function,请参考 Jerry 这篇文章

【版权声明】本文为华为云社区用户原创内容,转载时必须标注文章的来源(华为云社区)、文章链接、文章作者等基本信息, 否则作者和本社区有权追究责任。如果您发现本社区中有涉嫌抄袭的内容,欢迎发送邮件进行举报,并提供相关证据,一经查实,本社区将立刻删除涉嫌侵权内容,举报邮箱: cloudbbs@huaweicloud.com
  • 点赞
  • 收藏
  • 关注作者

评论(0

0/1000
抱歉,系统识别当前为高风险访问,暂不支持该操作

全部回复

上滑加载中

设置昵称

在此一键设置昵称,即可参与社区互动!

*长度不超过10个汉字或20个英文字符,设置后3个月内不可修改。

*长度不超过10个汉字或20个英文字符,设置后3个月内不可修改。