Fission

为 Kubernetes 提供快速、简单的无服务器功能。「Fast and Simple Serverless Functions for Kubernetes」

Github stars Tracking Chart


Fission is a fast serverless framework for Kubernetes with a focus on
developer productivity and high performance.

Fission operates on just the code: Docker and Kubernetes are
abstracted away under normal operation, though you can use both to
extend Fission if you want to.

Fission is extensible to any language; the core is written in Go, and
language-specific parts are isolated in something called
environments (more below). Fission currently supports NodeJS, Python, Ruby, Go,
PHP, Bash, and any Linux executable, with more languages coming soon.

Table of Contents

Performance: 100msec cold start

Fission maintains a pool of "warm" containers that each contain a
small dynamic loader. When a function is first called,
i.e. "cold-started", a running container is chosen and the function is
loaded. This pool is what makes Fission fast: cold-start latencies
are typically about 100msec.

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 Fission deployment.

Getting Started

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

  # Create a function with a javascript one-liner that prints "hello world"
  $ fission function create --name hello --env nodejs --code https://raw.githubusercontent.com/fission/fission/master/examples/nodejs/hello.js

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

Learn More

Contributing

Check out the contributing guide.

Get Help & Community Meeting

Fission is a project by many contributors.
Reach us on slack or twitter.

A regular community meeting takes place every other Thursday at 09:00 AM PT (Pacific Time). Convert to your local timezone.

Meeting Link: https://zoom.us/j/413921817

The meeting agenda for next meeting and notes from past meetings are maintained in this document. You are welcome to join to discuss direction of project, design and implementation reviews and general questions about project etc.

Official Releases

Official releases of Fission can be found on the releases page.
Please note that it is strongly recommended that you use official releases of Fission, as unreleased versions from
the master branch are subject to changes and incompatibilities that will not be supported in the official releases.

Sponsors

The following companies, organizations, and individuals support Fission's ongoing maintenance and development. If you are using/contributing to Fission, we would be happy to list you here, please raise a Pull request.

Licensing

Fission is under the Apache 2.0 license.

Overview

Name With Ownerfission/fission
Primary LanguageGo
Program languageJavaScript (Language Count: 9)
PlatformKubernetes, Linux, Mac, Windows
License:Apache License 2.0
Release Count95
Last Release Namev1.20.1 (Posted on )
First Release Namekubecon (Posted on )
Created At2016-08-19 03:43:56
Pushed At2024-04-19 13:08:50
Last Commit At2022-08-22 14:57:00
Stargazers Count8.2k
Watchers Count154
Fork Count765
Commits Count1.7k
Has Issues Enabled
Issues Count1066
Issue Open Count226
Pull Requests Count1344
Pull Requests Open Count15
Pull Requests Close Count384
Has Wiki Enabled
Is Archived
Is Fork
Is Locked
Is Mirror
Is Private
To the top