Merge pull request #29 from francescotimperi/main

chore: preparing common 1.21.0
tree: 276a84fc7324cb1bef38f83f32695126cc3e5c10
  1. .github/
  2. docs/
  3. openwhisk/
  4. packages/
  5. runtime/
  6. tests/
  7. .env.dist
  8. .gitattributes
  9. .gitignore
  10. .licenserc.yaml
  11. customkitd.toml
  12. DISCLAIMER
  13. go.mod
  14. go.sum
  15. LICENSE
  16. NOTICE
  17. proxy.go
  18. README.md
  19. runtimes.json.tpl
  20. Taskfile.yml
README.md

Apache OpenServerless Runtimes

All the Apache Openserverless OpenWhisk runtimes in a single place using the Go proxy and ActionLoop.

Source Code

runtimes are docker images, and they all use a proxy in go and some scripts for execution.

Go Proxy code is in folder openwhisk and the main is proxy.go in top level.

You can compile it with go build -o proxy.

Tests are in openwhisk folder, test it with cd opewhisk ; go test

Runtime sources are under runtimes/<plang>/<version> (<plang> is programming languate)

Special case is runtime/common/<version> that contains the proxy itseself, it is used as base image for the others and must be build first.

How to build images

Build and push the common runtime with task build-common. Also ensure the image is public.

Then you can build a single runtime specifingh the dir:

Build a single runtime: task build-runtime RT=nodejs VER=v18

How to generate a new runtimes.json

The project contains a runtimes.json.tpl with specific placeholder for managed Apache OpenServerless runtimes. To regenerate a newer runtimes.json from the current TAG and assuming that the images have been effectively pushed to the Apache Official DockerHub repositories execute the command:

task render-runtimes

This will create a new runtimes.json that can be pushed to the official Apache OpenServerless task repo, replacing the existing file.

How to use the client/server mode

The proxy can be used in client or server mode, where the client acts as a forward proxy and the server will be the actual executor.

In client mode the runtime does not execute the action, but instead forwards the /init and /run requests to a server runtime. To activate this mode, set the environment variable OW_ACTIVATE_PROXY_CLIENT to 1. When creating actions, use the --main flag with this syntax: --main "<main>@<remote runtime address>". <main> can be empty.

The remote runtime is enabled by setting the environment variable OW_ACTIVATE_PROXY_SERVER to 1. In this mode the runtime is multi-action enabled, meaning that it can initialize and run more than one action. Many client runtimes can forward requests to the same server runtime.