Krustlet可让用户在K8s上简单部署WebAssembly工作负载
云端开源工具厂商Deislabs释出了一个名为Krustlet的工具,Krustlet这个字是结合Kubernetes-Rust-Kubelet创造出来的,说明Krustlet是用程式语言Rust所开发,用来提供类似Kubernetes Kubelet功能,Krustlet可简化用户在Kubernetes上,部署WebAssembly工作负载任务。
之所以要在Kubernetes中支援WebAssembly,Deislabs提到,Linux容器和WebAssembly各有优点,可以成为互补的技术。Linux容器提供了作业系统等级的虚拟沙盒,可以让用户在单个主机上执行多个隔离的Linux系统,容器直接在物理硬体上执行,不需要进行模拟,因此执行的额外成本很小;而WebAssembly则是一种新的二进位开放格式开放标準,具有记忆体安全以及可移植的特性,能以接近原生效能执行,目前Rust、C/C++与AssemblyScript都可交叉编译成WebAssembly。
一开始WebAssembly是为浏览器所发展的,但是随着发展,Mozilla开始把WebAssembly扩展到浏览器之外,建立了WASI(WebAssembly System Interface)标準,让WebAssembly的功能可以扩展到作业系统,有了这个抽象层,开发者的WebAssembly程式,就能够在任何支援WASI的地方执行,达到一次编译,随处执行的目的。
Deislabs表示,Linux容器与WebAssembly并不处于互相竞争的位置上,Linux容器目的是要提供作业系统层级的沙盒环境,由于要靠Linux核心提供沙盒环境,因此在英特尔晶片编译的程式码,就无法在ARM硬体上执行;而WebAssembly是可移植的二进位格式,无论底层硬体为何,只要是支援WASI的硬体,WebAssembly程式就能够在上面运作,不过由于WebAssembly是二进位格式,无法提供跟作业系统沙盒相同的灵活性。
因此开发者可以依据需求,将编译程式放在Linux容器上执行,或是将应用程式编译成WebAssembly,而后者就可以利用Krustlet工具来部署。Deislabs提到,Krustlet的设计类似Virtual Kubelet,可以从Kubernetes API事件串流中监听新的Pod;Virtual Kubelet是一个开源Kubelet实作,而Kubelet则是Kubernetes丛集的必要元件,丛集中每个节点都会启动Kubelet,来处理主节点派送的任务,以及管理节点上的Pod。
现在Kubernetes API也可以调度Pod到Krustlet上,并在waSCC或是WASI Runtime上执行,同一个Kubernetes丛集,可以同时拥有传统Linux容器工作负载与WebAssembly工作负载,两者也可以互相沟通。
Deislabs现在释出的是Krustlet第一个版本0.1.0,0.2.0版本将会支援卷宗挂载,并提供更多範例,及补充Krustlet文件。Krustlet专案完全开源,想抢先尝试的用户可以在GitHub上取得程式。
免责声明:本文由用户上传,如有侵权请联系删除!
猜你喜欢
最新文章
- 中国好声音如果没有你李昊瀚(山野中国好声音李昊瀚唱的那么好为什么淘汰)
- 被套的尺寸是多少(被套尺寸一般是多少简介介绍)
- 怪物x联盟复刻版攻略(怪物x联盟复刻祥云马)
- 阳历是快的还是慢得(快的和慢的哪个是阳历简介介绍)
- 英雄联盟赵信特战先锋(特战先锋德邦总管赵信)
- 凤凰传奇有一首歌叫什么(凤凰传奇有一首歌歌词有)
- 为什么腾讯视频看不了直播(腾讯lpl视频看不了怎么办)
- Blue(Da(Ba Dee) 歌词)
- 联想z475开机黑屏(联想Z475开机超慢怎么回事)
- 吴建豪舞林大会跳的舞(2011舞林大会吴建豪怎么没有看见进复赛)
- 海清结婚了吗现在怎么样了(海清结婚了吗)
- 开十字绣店到哪里进货(开十字绣店在哪里进货怎么进货呢)
- 卫庄大战六剑奴是哪一集(卫庄哪集说的六剑奴是值得一战的对手)
- 微信六年来第一次开始“变脸”为什么
- iphone怎么看已连接wifi密码(iPhone怎么越狱啊)
- 求K233次列车(15车厢的座位号)
- 能链综合能源港里的充电站为何成为香饽饽
- 鸡蛋怎么做比较有营养(鸡蛋怎么做比较好吃)
- lol手游霞怎么出装(LOL新英雄霞与洛逆羽霞如何出装霞怎么出装)
- 穿越火线什么时候上架(穿越火线什么时候能玩)
- 北比臼舅怎么读(北比臼日怎么读)
- 创世之柱任务有什么用(创世之柱任务怎么做)
- 徐磊的歌曲(写给你的歌 徐磊乐演唱作品)
- 广州市经济适用住房准购证明怎么办理(如何取得广州市经济适用住房准购证明)