Skip to content

Fast and Simple Serverless Functions for Kubernetes

License

Notifications You must be signed in to change notification settings

MikePresman/fission

This branch is 190 commits behind fission/fission:main.

Folders and files

NameName
Last commit message
Last commit date

Latest commit

784bd82 · Apr 13, 2023
Mar 12, 2023
Mar 31, 2023
Feb 17, 2023
Nov 21, 2022
Dec 9, 2022
Apr 13, 2023
Feb 2, 2023
Nov 21, 2022
Jan 16, 2020
May 27, 2019
Nov 25, 2022
Nov 26, 2022
Jan 30, 2023
Aug 22, 2022
Jul 6, 2022
Nov 6, 2019
Sep 28, 2021
Aug 19, 2016
Jan 11, 2023
Aug 22, 2022
Oct 6, 2021
Mar 31, 2023
Mar 31, 2023
Jul 5, 2021
Feb 2, 2023

Repository files navigation


Fission: Serverless Functions for Kubernetes

Fission Licence Fission Releases go.dev reference Go Report Card Fission contributors Commit Activity
Fission website Fission slack Fission twitter GitHub Repo stars


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/examples/master/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.

Who is using Fission?

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.

InfraCloud Srcmesh

License

Fission is licensed under the Apache License 2.0 - see the LICENSE file for details

About

Fast and Simple Serverless Functions for Kubernetes

Resources

License

Code of conduct

Security policy

Stars

Watchers

Forks

Releases

No releases published

Packages

No packages published

Languages

  • Go 88.0%
  • Shell 10.4%
  • Smarty 0.8%
  • Makefile 0.2%
  • Mustache 0.2%
  • JavaScript 0.2%
  • Other 0.2%