/gwasm-runner

Command line tool for running gWasm compatible apps locally, via Golem Unlimited or via Brass Golem.

Primary LanguageRustGNU General Public License v3.0GPL-3.0

gwasm-runner Build Status

Command line tool for running gWasm compatible apps locally, via Golem Unlimited or via Brass Golem.

It introduces minimalistic gwasm dispatcher API that resembles map-reduce paradigm. This API with only three operations:

  1. split - divide the problem into subproblems.
  2. execute - performs computation for all subproblems independently.
  3. merge - collect all computation results and formulate final result.

enables developers to easily implement applications and run them on top of the Golem Unlimited and also on Brass Golem 0.21 and later.

building from sources

Having below prereqs just invoke

cargo build --release

prerequisites

You need to have C compiler, Python 2, AutoConf 2.13 and yasm

on Ubuntu (16.04+)

sudo apt-get install clang-6.0 autoconf2.13 yasm

on macOS

xcode-select --install

Use Homebrew to install Python 2, AutoConf 2.13 and Yasm:

brew install python@2 autoconf@2.13 yasm
# remove newer version of autoconf
brew unlink autoconf
# and use 2.13 instead
ac=`which autoconf213` && sudo ln -s "$ac" "${ac%213}"

Running a WASM binary

The first step here is obtaining a WASM binary compatible with the runner. This means that the binary must conform to the runner's split-execute-merge API. A list of compatible binaries can be found in the wasm-store repository. Of course, you can also create your own program. As our example we're going to use mandelbrot, a Mandelbrot fractal visualiser.

Running on the Golem network

Using gwasm-runner, you can execute the WASM binary in the Golem network, taking advantage of parallelism by splitting the work between multiple providers.

To create a task you will need to have an instance of Golem (version 0.21+) running locally on your machine. This instance will act as a requestor within the Golem network. Assuming that we want to run the mandelbrot example, issue the below command:

./gwasm-runner /path/to/mandelbrot.wasm --backend=Brass -- 1000 1000 4

Let's take a closer look at that command:

  • The first argument to the runner is the path to the WASM binary. Please note that the runner expects the corresponding .js file to be present in the same directory as the WASM binary.
  • Brass stands for Brass Golem, the name for the current iteration of the Golem project.
  • The parameters after -- are passed directly to the WASM program, therefore they are app-specific. In the case of the mandelbrot example, the first two numbers (1000 1000) are the width and height of the output image. The last number (4) is the subtask count, which determines the number subtasks we want to split our work into.

Should you need to change the default configuration for the runner (e.g. whether to use Ethereum's mainnet or testnet), there is an option to use a JSON configuration file. By default, the following values are used when creating a Golem task:

{
    "data_dir": "/home/user/.local/share/golem/default",
    "address": "127.0.0.1:61000",
    "budget": 1.0,
    "name": "gwasm-task",
    "net": "testnet",
    "subtask_timeout": "00:10:00",
    "task_timeout": "00:30:00"
}

To override the default values you will need to create your own, local configuration file. The path to this file depends on your operating system, here are examples for each platform:

  • Linux: $HOME/.config/g-wasm-runner/brass/config.json
  • MacOS: $HOME/Library/Application Support/g-wasm-runner/brass/config.json
  • Windows: C:\Users\<USER_NAME>\AppData\Roaming\Golem Factory\g-wasm-runner\brass\config.json

As for the contents, you can copy the JSON object shown above and modify its fields as required. The runner will print its currently used configuration upon start-up.