All Projects β†’ metrue β†’ Fx

metrue / Fx

Licence: mit
A Function as a Service tool makes a function as a container-based service in seconds.

Programming Languages

go
31211 projects - #10 most used programming language
d
599 projects
shell
77523 projects
Dockerfile
14818 projects
Makefile
30231 projects
rust
11053 projects

Projects that are alternatives of or similar to Fx

Midway Faas
πŸ”± A simple and lightweight serverless framework
Stars: ✭ 363 (-78.38%)
Mutual labels:  microservice, serverless, aws-lambda, faas
Faas
OpenFaaS - Serverless Functions Made Simple
Stars: ✭ 20,820 (+1140.02%)
Mutual labels:  serverless, faas, k8s
Aegis
Serverless Golang deploy tool and framework for AWS Lambda
Stars: ✭ 277 (-83.5%)
Mutual labels:  microservice, serverless, aws-lambda
Kubeless
Kubernetes Native Serverless Framework
Stars: ✭ 6,849 (+307.92%)
Mutual labels:  serverless, faas, function-as-a-service
Serverless
⚑ Serverless Framework – Build web, mobile and IoT applications with serverless architectures using AWS Lambda, Azure Functions, Google CloudFunctions & more! –
Stars: ✭ 41,584 (+2376.71%)
Mutual labels:  microservice, serverless, aws-lambda
hyperform
⚑ Lightweight serverless framework for NodeJS
Stars: ✭ 156 (-90.71%)
Mutual labels:  aws-lambda, faas, function-as-a-service
Webiny Js
Enterprise open-source serverless CMS. Includes a headless CMS, page builder, form builder and file manager. Easy to customize and expand. Deploys to AWS.
Stars: ✭ 4,869 (+189.99%)
Mutual labels:  microservice, serverless, aws-lambda
Components
The Serverless Framework's new infrastructure provisioning technology β€” Build, compose, & deploy serverless apps in seconds...
Stars: ✭ 2,259 (+34.54%)
Mutual labels:  serverless, aws-lambda, faas
K8s On Raspbian
Kubernetes on Raspbian (Raspberry Pi)
Stars: ✭ 839 (-50.03%)
Mutual labels:  serverless, faas, k8s
Microless
Using docker and nodejs to build Microservice
Stars: ✭ 14 (-99.17%)
Mutual labels:  microservice, serverless, faas
Alagarr
🦍 Alagarr is a request-response helper library that removes the boilerplate from your Node.js (AWS Lambda) serverless functions and helps make your code portable.
Stars: ✭ 58 (-96.55%)
Mutual labels:  serverless, aws-lambda, faas
Malagu
Malagu is a Serverless First, component-based, platform-independent, progressive application framework based on TypeScript.
Stars: ✭ 184 (-89.04%)
Mutual labels:  microservice, serverless, faas
Jazz
Platform to develop and manage serverless applications at an enterprise scale!
Stars: ✭ 254 (-84.87%)
Mutual labels:  serverless, aws-lambda, faas
Bref
Serverless PHP on AWS Lambda
Stars: ✭ 2,382 (+41.87%)
Mutual labels:  serverless, aws-lambda, faas
Up
Up focuses on deploying "vanilla" HTTP servers so there's nothing new to learn, just develop with your favorite existing frameworks such as Express, Koa, Django, Golang net/http or others.
Stars: ✭ 8,439 (+402.62%)
Mutual labels:  microservice, serverless, aws-lambda
Lib
Autocode CLI and standard library tooling
Stars: ✭ 3,773 (+124.72%)
Mutual labels:  serverless, aws-lambda, faas
Knctl
Knative CLI
Stars: ✭ 163 (-90.29%)
Mutual labels:  serverless, faas, k8s
Laravel Bridge
Package to use Laravel on AWS Lambda with Bref
Stars: ✭ 168 (-89.99%)
Mutual labels:  serverless, aws-lambda, faas
Lambdalogs
A CLI tool to trace AWS Lambda calls over multiple CloudWatch log groups.
Stars: ✭ 18 (-98.93%)
Mutual labels:  serverless, aws-lambda, faas
Apex
Old apex/apex
Stars: ✭ 20 (-98.81%)
Mutual labels:  serverless, aws-lambda, faas

fx

Poor man's function as a service.
CI GitHub contributors CodeCov Go Report Card Go Doc visitors liscense Release

Table of Contents

Introduction

fx is a tool to help you do Function as a Service on your own server, fx can make your stateless function a service in seconds, both Docker host and Kubernetes cluster supported. The most exciting thing is that you can write your functions with most programming languages.

Feel free hacking fx to support the languages not listed. Welcome to tweet me @_metrue on Twitter, @metrue on Weibo.

Language Status Contributor Example
Go Supported fx /examples/Golang
Rust Supported @FrontMage /examples/Rust
Node Supported fx /examples/JavaScript
Python Supported fx /examples/Python
Ruby Supported fx /examples/Ruby
Java Supported fx /examples/Java
PHP Supported @chlins /examples/PHP
Julia Supported @matbesancon /examples/Julia
D Supported @andre2007 /examples/D
Perl Supported fx /examples/Perl
Crystal Supported @mvrilo /examples/Crystal
R Working on need your help

Installation

Binaries are available for Windows, MacOS and Linux/Unix on x86. For other architectures and platforms, follow instructions to build fx from source.

  • MacOS
brew tap metrue/homebrew-fx
brew install metrue/fx/fx
  • Linux/Unix

via cURL

# Install to local directory
curl -o- https://raw.githubusercontent.com/metrue/fx/master/scripts/install.sh | bash

# Install to /usr/local/bin/
curl -o- https://raw.githubusercontent.com/metrue/fx/master/scripts/install.sh | sudo bash

fx will be installed into /usr/local/bin, sometimes you may need source ~/.zshrc or source ~/.bashrc to make fx available in $PATH.

  • Windows

You can go the release page to download fx manually;

Usage

NAME:
   fx - makes function as a service

USAGE:
   fx [global options] command [command options] [arguments...]

COMMANDS:
   up        deploy a function
   down      destroy a service
   list, ls  list deployed services
   image     manage image of service
   help, h   Shows a list of commands or help for one command

GLOBAL OPTIONS:
   --help, -h     show help
   --version, -v  print the version

Deploy function

Local Docker environment

By default, function will be deployed on localhost, make sure Docker installed and running on your server first. then type fx -h on your terminal to check out basic help.

$ fx up --name hello ./examples/functions/JavaScript/func.js

+------------------------------------------------------------------+-----------+---------------+
|                                ID                                |   NAME    |   ENDPOINT    |
+------------------------------------------------------------------+-----------+---------------+
| 5b24d36608ee392c937a61a530805f74551ddec304aea3aca2ffa0fabcf98cf3 | /hello    | 0.0.0.0:58328 |
+------------------------------------------------------------------+-----------+---------------+

Remote host

Use --host to specify the target host for your function, or you can just set it to FX_HOST environment variable.

$ fx up --host roo@<your host> --name hello ./examples/functions/JavaScript/func.js

+------------------------------------------------------------------+-----------+---------------+
|                                ID                                |   NAME    |   ENDPOINT    |
+------------------------------------------------------------------+-----------+---------------+
| 5b24d36608ee392c937a61a530805f74551ddec304aea3aca2ffa0fabcf98cf3 | /hello    | 0.0.0.0:58345 |
+------------------------------------------------------------------+-----------+---------------+

Kubernetes

$ FX_KUBECONF=~/.kube/config fx up examples/functions/JavaScript/func.js --name hello

+-------------------------------+------+----------------+
| ID                     | NAME        |    ENDPOINT    |
+----+--------------------------+-----------------------+
|  5b24d36608ee392c937a  | hello-fx    | 10.0.242.75:80 |
+------------------------+-------------+----------------+

Test service

then you can test your service:

$ curl -v 0.0.0.0:58328


GET / HTTP/1.1
Accept: */*
Accept-Encoding: gzip, deflate
Connection: keep-alive
Host: 0.0.0.0:10001
User-Agent: HTTPie/1.0.2



HTTP/1.1 200 OK
Connection: keep-alive
Content-Length: 11
Content-Type: text/plain; charset=utf-8
Date: Sat, 10 Aug 2019 05:28:03 GMT

hello world

Use Public Cloud Kubernetes Service as infrastructure to run your functions

  • Azure Kubernetes Service (AKS)

You should create a Kubernetes cluster if you don't have one on AKS, detail document can found here.

$ az group create --name <myResourceGroup> --location eastus
$ az aks create --resource-group <myResourceGroup> --name myAKSCluster --node-count <count>
$ az aks get-credentials --resource-group <myResourceGroup> --name <myAKSCluster>

Then you can verify it with kubectl,

$ kubectl get nodes

NAME                       STATUS   ROLES   AGE     VERSION
aks-nodepool1-31718369-0   Ready    agent   6m44s   v1.12.8

Since AKS's config will be merged into ~/.kube/config and set to be current context after you run az aks get-credentials command, so you can just set KUBECONFIG to default config also,

$ export FX_KUBECONF=~/.kube/config  # then fx will take the config to deloy function

But we would suggest you run kubectl config current-context to check if the current context is what you want.

  • Amazon Elastic Kubernetes Service (EKS) TODO

  • Google Kubernetes Engine (GKE)

First you should create a Kubernetes cluster in your GKE, then make sure your KUBECONFIG is ready in ~/.kube/config, if not, you can run following commands,

$ gcloud auth login
$ gcloud container clusters get-credentials <your cluster> --zone <zone> --project <project>

Then make sure you current context is GKE cluster, you can check it with command,

$ kubectl config current-context

Then you can deploy your function onto GKE cluster with,

$ FX_KUBECONF=~/.kube/config fx up examples/functions/JavaScript/func.js --name hellojs
  • Setup your own Kubernetes cluster
fx infra create --type k3s --name fx-cluster-1 --master [email protected] --agents '[email protected],[email protected]'

Contributors

Thank you to all the people who already contributed to fx!

metrue muka pplam mbesancon chlins xwjdsh DaidoujiChen avelino andre2007 polyrabbit johnlunney tbrand andre2007 border-radius Russtopia FrontMage DropNib
Note that the project description data, including the texts, logos, images, and/or trademarks, for each open source project belongs to its rightful owner. If you wish to add or remove any projects, please contact us at [email protected].