OpenFaaS 简介
OpenFaaS ® - Serverless Functions Made Simple
下载 Kubernetes 的 OpenFaaS 驱动程序 faas-netes:
1 | git clone https://github.com/openfaas/faas-netes && cd faas-netes |
OpenFaaS (Functions as a Service) is a framework for building serverless functions with Docker and Kubernetes.
简言之,OpenFaaS 是一个使用 Docker 构建 Serverless 功能的框架,它拥有对指标的一级支持。任何流程都可以打包为一个函数,使你能够使用一系列 web 事件,而无需重复的样板化编码。
Helm
在安装使用 OpenFaaS 之前,我们需要安装 Helm 3 (不需要再使用 tiller 了)。
结合之前的文章 Kubernetes 学习笔记,启动 minikube:
1 | minikube start --image-mirror-country cn |
安装 Helm:
1 | brew install kubernetes-helm |
部署 OpenFaaS
在 minikube 环境下先创建两个命名空间 namespaces:
1 | kubectl apply -f https://raw.githubusercontent.com/openfaas/faas-netes/master/namespaces.yml |
增加 OpenFaaS helm chart:
1 | helm repo add openfaas https://openfaas.github.io/faas-netes/ |
好了,我们先简单发布试试:
1 | helm repo update \ |
按照提示获取 password:
1 | echo $(kubectl -n openfaas get secret basic-auth -o jsonpath="{.data.basic-auth-password}" | base64 --decode) |
默认的提供 31112 端口,我们通命令 $(minikube ip)
获取内部 ip,通过 ip:31112 访问,输入账号和上面提供的密码:
Hello Function
下面开始写我们的第一个 serverless function。
安装 faas-cli
如上图推荐的,我们可以安装 faas-cli 来创建和发布一个 Function。
1 | $ curl -sL cli.openfaas.com | sudo sh |
我用的 mac,所以也可以直接利用 brew 来安装:
1 | brew install faas-cli |
创建一个 NodeJS 函数
1 | faas-cli new hellofaas --lang node |
整个项目结构如下:
1 | . |
如需要查看以下完整内容,可以查看此处: