kubefaas

module
v1.8.1 Latest Latest
Warning

This package is not in the latest version of its module.

Go to latest
Published: Mar 10, 2020 License: Apache-2.0

README

Kubefaas: Serverless Functions for Kubernetes

Kubefaas is a Function-as-a-Service framework for Kubernetes based on Fission.

Kubefaas abstracts away the complexity of Kubernetes which allows you to focus on your daily routines.

Kubefaas currently supports most of the popular programming languages like NodeJS, Python, Ruby, Go, PHP, and any Linux executable. Want a custom runtime environment? No problem, you can also create a custom runtime environment and use it for your function.

Kubernetes is the right place for Serverless

We're built on Kubernetes because we think any non-trivial app will use a combination of serverless functions and more conventional microservices, and Kubernetes is a great framework to bring these together seamlessly.

Building on Kubernetes also means that anything you do for operations on your Kubernetes cluster — such as monitoring or log aggregation — also helps with ops on your Kubefaas deployment.

Getting started and documentation

Documentations

You can learn more about Kubefaas and get started from documentation.

Usage

  # Add the stock NodeJS env to your Kubefaas deployment
  $ kubefaas env create --name nodejs --image kubefaas/node-env

  # A javascript one-liner that prints "hello world"
  $ curl https://raw.githubusercontent.com/srcmesh/kubefaas/master/examples/nodejs/hello.js > hello.js

  # Upload your function code to kubefaas
  $ kubefaas function create --name hello --env nodejs --code hello.js

  # Map GET /hello to your new function
  $ kubefaas route create --method GET --url /hello --function hello

  # Run the function.  This takes about 100msec the first time.
  $ kubefaas function test --name hello
  Hello, world!

Official Releases

Official releases of Kubefaas can be found on the releases page. Please note that it is strongly recommended that you use official releases of Kubefaas, as unreleased versions from the master branch are subject to changes and incompatibilities that will not be supported in the official releases. Builds from the master branch can have functionality changed and even removed at any time without compatibility support and without prior notice.

Licensing

Kubefaas is an open core project maintained by Srcmesh and released under the Apache 2.0 license.

Directories

Path Synopsis
cmd
cli
environments
go
examples
go
pkg
apis/core/v1
+k8s:deepcopy-gen=package +k8s:defaulter-gen=TypeMeta +groupName=fission.io +groupGoName=core In order not to break the backward compatibility, keep coreV1 types stay at "fission.io" group instead of moving them to "core.fission.io".
+k8s:deepcopy-gen=package +k8s:defaulter-gen=TypeMeta +groupName=fission.io +groupGoName=core In order not to break the backward compatibility, keep coreV1 types stay at "fission.io" group instead of moving them to "core.fission.io".
apis/genclient/clientset/versioned
This package has the automatically generated clientset.
This package has the automatically generated clientset.
apis/genclient/clientset/versioned/fake
This package has the automatically generated fake clientset.
This package has the automatically generated fake clientset.
apis/genclient/clientset/versioned/scheme
This package contains the scheme of the automatically generated clientset.
This package contains the scheme of the automatically generated clientset.
apis/genclient/clientset/versioned/typed/core/v1
This package has the automatically generated typed clients.
This package has the automatically generated typed clients.
apis/genclient/clientset/versioned/typed/core/v1/fake
Package fake has the automatically generated clients.
Package fake has the automatically generated clients.
cli/cliwrapper
Package cliwrapper is a wrapper that allowing functions to access flag value in an identical way no matter what underlying CLI package used.
Package cliwrapper is a wrapper that allowing functions to access flag value in an identical way no matter what underlying CLI package used.
crd
generator
Package generator is a generator that helps to convert a resource object into target encoding format like JSON, YAML ...etc.
Package generator is a generator that helps to convert a resource object into target encoding format like JSON, YAML ...etc.
plugin
Package plugins provides support for creating extensible CLIs
Package plugins provides support for creating extensible CLIs
test

Jump to

Keyboard shortcuts

? : This menu
/ : Search site
f or F : Jump to
y or Y : Canonical URL