周伯通的空明拳米诺斯的星尘傀儡线SAP-Kyma的Serverless

111次阅读

共计 2245 个字符,预计需要花费 6 分钟才能阅读完成。

Jerry 一直认为,金庸的《天龙八部》里的武学建模已经有点脱离传统武侠小说的范畴了,像已经走上玄幻道路的灵鹫宫“八荒六合唯我独尊功”,以及杀伤力足够能被视为现代激光武器的鼻祖,大理段式的“六脉神剑”之类。而另一部经典的射雕三部曲里很多的武功设定则中规中矩,其中周伯通自创的七十二路空明拳,是金老独具匠心的创造之一。

周伯通被黄药师困在桃花岛,宅了十余年,从《道德经》中参悟到「以虚击实」,「以不足胜有余」的武学 (编程) 思想。《道德经》有云:「天下莫柔弱于水,而攻坚强者莫之能胜,其无以易之。弱之胜强,柔之胜刚,天下莫不知,莫能行。」

而这套拳力“若有若无”的武功,使用在生产环境最经典的一幕,就是在百花谷和杨过的“黯然销魂掌”PK 的时候:

周伯通生性好武,虽在百花谷隐居,每日仍是练功不辍,但以他如此功力,普天下哪里找对手去?这时见杨过愿意比武,自是心痒难搔,跃跃欲试,心想若再多言,只怕他忽而又不愿动手了,岂不是错过良机?当下左掌一提,喝道:“看拳!”右手一拳打了出去,使的是七十二路的“空明拳法”。

杨过左手还了一掌,猛觉得对方拳力若有若无,自己掌力使实了固然不对,使虚了也是极其危险,不禁暗暗吃惊,当下展开十余年来在狂涛怒潮中所苦练的掌法还击出去。

无独有偶,在车田正美笔下的《圣斗士星矢》里,也有很多像周伯通一样,拥有一套招式若有若无的好手。如果按照动漫里越晚出场的人物实力越强的设定,那么最强的人物无疑是 Jerry 这张卡片里秀的,冥界三巨头之首,天贵星的狮鹫米诺斯,第一域的最高主宰者。


米诺斯的绝技星尘傀儡线,能够用一根根看不见的丝线将对手的身体缠绕起来,从而使其像一具傀儡一样,只能按照自己的意志来活动,是一种非常可怕的招式。在对手眼中,这些由米诺斯小宇宙形成的丝线若有若无,根本无从防御。米诺斯最高光的战绩,就是一度全面压制在黄金圣斗士中实力位居中上游的加隆,后者尽管拥有威力“能让星星粉碎”的银河星爆,但是在米诺斯的星尘傀儡线面前,毫无反击的机会。


同样,Jerry 第一次接触 SAP Kyma 基于 Serverless 架构的 Lambda Function 时,感受同周伯通和米诺斯的对手一样有些疑惑:名字都叫 Serverless 了,没了服务器,那我的函数代码到底运行在什么地方的?

比如在最近 Jerry 写的一系列 SAP Kyma 的文章里介绍过,我在 Kyma 上创建了一个名为 zjerry-lambda 的函数,基于 nodejs8:

可以直接在 Kyma 的测试控制台里调用这个 Lambda Function:

Serverless 的字面意思,不是暗示我们没有服务器了吗?那么这段函数代码到底运行在哪里的?

米诺斯的星尘傀儡线,在冰系法师,百鸟座冰河的冻气之下,终于被冻结成肉眼可见的丝线了。同样的,因为 SAP Kyma 是基于 Kubernetes 的,因此我们还是可以通过 Kubernetes 提供的一些工具,来探索 SAP Kyma 上 Lambda Function 运行原理的一些蛛丝马迹。跟 Jerry 一起看看吧。

首先找到 zjerry-lambda 函数创建后,对应生成的 pod,把名字抄下来:zjerry-lambda-86668f75d4-pfbk6

使用 kubectl 的交互式参数 -ti,进入这个 pod 内部:

kubectl exec -ti zjerry-lambda-86668f75d4-pfbk6 -n ctu-demo — /bin/sh

进入之后,查看进程列表,发现了 node kubeless 这个进程,Jerry 顿时觉得有点眉目了:

看样子,SAP Kyma 的 Lambda Function 是通过一个 node 进程执行的。查看一下这个 pod 里都有哪些文件:

打开 kubeless.js 看看里面的内容:

如果您是一位 nodejs 开发人员,看到上面 Jerry 高亮的红色内容,一定会恍然大悟。SAP Kyma 的 Lambda Function,其实运行在对应的 Kubernetes pod 里启动的 express 应用框架上。

Express 的依赖定义在 pod 内部的 package.json 里:

而待执行的 Lambda Function 逻辑,通过环境变量 FUNC_HANDLER 进行注入,在 Jerry 这个例子里,函数体名称为 main:


在 Lambda Function 的 Serverless 框架,即 kubeless.js 运行时,会从 pod 内部的 kubeless 这个文件夹里,找到应用开发人员编写的 Lambda Function,加载并运行。

大家可以看到,Jerry 红色高亮的位于 pod 内部的 handler.js, 其内容就是 Kyma 控制台里编写的函数体。

至此,SAP Kyma 的 Lambda Function 实现,在 Jerry 眼中没有任何神秘可言了。回到 Serverless 这个术语本身,并不意味着整个场景里不再需要服务器的参与,而是服务器的这个关注点,在 Serverless 架构下,已经从应用开发人员的视角中隐藏起来罢了。

感谢阅读。

更多阅读

  • 站在巨人肩膀上的牛顿:Kubernetes 和 SAP Kyma
  • 高射炮打蚊子,杀鸡用绝世好剑:在 SAP Kyma 上运行 UI5 应用
  • 什么?在 SAP 中国研究院里还需要会 PHP 开发?
  • 第三方应用如何在 SAP Kyma 上进行服务注册
  • 基于 SAP Kyma 的订单编排增强介绍
  • WordPress,SAP Kyma 和微信三者的集成
  • 从 ABAP Netweaver 的 SICF 到 SAP Kyma 的 Lambda Function

要获取更多 Jerry 的原创文章,请关注公众号 ” 汪子熙 ”:

正文完
 0