Coding01

Coding 点滴

0%

Kubernetes 学习笔记 (3) --- 使用 Heml 安装和使用 OpenFaaS

OpenFaaS 简介

OpenFaaS ® - Serverless Functions Made Simple

下载 Kubernetes 的 OpenFaaS 驱动程序 faas-netes:

1
2
3
4
5
git clone https://github.com/openfaas/faas-netes && cd faas-netes

or 国内码云镜像:

git clone https://gitee.com/mirrors/faas-netes.git && 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
2
3
minikube start --image-mirror-country cn

eval $(minikube docker-env)

安装 Helm:

1
brew install kubernetes-helm

使用Helm管理kubernetes应用

部署 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
2
3
4
5
helm repo update \
&& helm upgrade openfaas --install openfaas/openfaas \
--namespace openfaas \
--set functionNamespace=openfaas-fn \
--set generateBasicAuth=true

按照提示获取 password:

1
2
3
4
echo $(kubectl -n openfaas get secret basic-auth -o jsonpath="{.data.basic-auth-password}" | base64 --decode)

// password
LnMqQfE5PVva

默认的提供 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
2
3
.
├── handler.js
└── package.json

如需要查看以下完整内容,可以查看此处:

https://mp.weixin.qq.com/s/lOJmUEH7QcewHngcLJbssw

Welcome to my other publishing channels