网站首页 > 技术文章 正文
快速搭建 Kubeless 平台
Kubeless 简介
Kubeless 是基于 Kubernetes 的原生无服务器框架。其允许用户部署少量的代码(函数),而无须担心底层架构。它被部署在 Kubernetes 集群之上,并充分利用 Kubernetes 的特性及资源类型,可以克隆 AWS Lambda、Azure Functions、Google Cloud Functions 上的内容。
Kubeless 主要特点可以总结为以下几个方面。
- 支持 Python、Node.js、Ruby、PHP、Go、.NET、Ballerina 语言编写和自定义运行时。
- Kubeless CLI 符合 AWS Lambda CLI。
- 事件触发器使用 Kafka 消息系统和 HTTP 触发器。
- Prometheus 默认监视函数的调用和延时。
- 支持 Serverless 框架插件。
由于 Kubeless 的功能特性是建立在 Kubernetes 之上的,因此对于熟悉 Kubernetes 的人来说非常容易部署 Kubeless。其主要实现是将用户编写的函数在 Kubernetes 中转变为 CRD(Custom Resource Definition,自定义资源),并以容器的方式运行在集群中。
Kubeless 部署
在已有的 Kubernetes 集群上进行 Kubeless 服务的创建:
export RELEASE=$(curl -s https://api.github.com/repos/kubeless/kubeless/releases/
latest | grep tag_name | cut -d '"' -f 4)
kubectl create ns kubeless
kubectl create -f https://github.com/kubeless/kubeless/releases/download/$RELEASE/
kubeless-$RELEASE.yaml
创建成功后如图所示
查看基本信息:
kubectl get pods -n kubeless
相关 Pod 信息如图所示
查看 Deployment 信息:
kubectl get deployment -n kubeless
其相关信息如图所示
查看 customresourcedefinition 信息:
kubectl get customresourcedefinition
其相关信息如图所示
下载命令行工具
下载 Kubeless 工具,并解压:
export OS=$(uname -s| tr '[:upper:]' '[:lower:]')
curl -OL https://github.com/kubeless/kubeless/releases/download/$RELEASE/kubeless_
$OS-amd64.zip
unzip kubeless_$OS-amd64.zip
解压之后查看:
./bundles/kubeless_linux-amd64/kubeless
具体如图所示
体验测试
创建测试代码 helloworld.py :
def hello(event, context):
print(event)
return event['data']
部署项目:
./bundles/kubeless_linux-amd64/kubeless function deploy hello-world --runtime
python3.6 --from-file helloworld.py --handler helloworld.hello
部署成功之后,查看项目信息:
kubectl get functions
函数列表如图所示
查看实例函数:
./bundles/kubeless_linux-amd64/kubeless function ls
函数状态如图所示
触发函数:
./bundles/kubeless_linux-amd64/kubeless function call hello-world --data 'Hello
world!'
触发完成之后,看到输出结果:
查看实例中输出的日志,如图所示
至此,我们在 Kubernetes 集群上成功地创建了 Kubeless 服务,并顺利地体验了 Kubeless 版的 Hello World 实现。
猜你喜欢
- 2025-06-10 开发程序不写代码,而是靠拼图?(制作拼图小游戏的c语言代码)
- 2025-06-10 moodle 开源的在线学习管理系统(LMS)部署
- 2025-06-10 用WordPress建站哪些插件会拖慢速度影响排名?
- 2025-06-10 3分钟短文:一看就是干货!Laravel迁移数据库
- 2025-06-10 如何让WordPress博客的投稿者也可以上传图片的方法
- 2025-06-10 腾讯云云函数部署laravel项目(github腾讯云函数部署)
- 2025-06-10 如何搭建内网服务器:详细教程(建立内网服务器)
- 2025-06-10 浅谈几种常见的分布式ID(分布式id生成算法)
- 2025-06-10 Wordpress建站教程:上传图片重命名,避免中文名影响SEO优化
- 2025-06-10 如何自定义样式营销qq在线咨询代码
- 08-06中等生如何学好初二数学函数篇
- 08-06C#构造函数
- 08-06初中数学:一次函数学习要点和方法
- 08-06仓颉编程语言基础-数据类型—结构类型
- 08-06C++实现委托机制
- 08-06初中VS高中三角函数:从"固定镜头"到"360°全景",数学视野升级
- 08-06一文讲透PLC中Static和Temp变量的区别
- 08-06类三剑客:一招修改所有对象!类方法与静态方法的核心区别!
- 最近发表
- 标签列表
-
- cmd/c (90)
- c++中::是什么意思 (84)
- 标签用于 (71)
- 主键只能有一个吗 (77)
- c#console.writeline不显示 (95)
- pythoncase语句 (88)
- es6includes (74)
- sqlset (76)
- windowsscripthost (69)
- apt-getinstall-y (100)
- node_modules怎么生成 (87)
- chromepost (71)
- flexdirection (73)
- c++int转char (80)
- mysqlany_value (79)
- static函数和普通函数 (84)
- el-date-picker开始日期早于结束日期 (70)
- asynccallback (71)
- localstorage.removeitem (74)
- vector线程安全吗 (70)
- java (73)
- js数组插入 (83)
- mac安装java (72)
- 查看mysql是否启动 (70)
- 无效的列索引 (74)