Skip to content

Latest commit

 

History

History
588 lines (411 loc) · 19.6 KB

GUIDE.md

File metadata and controls

588 lines (411 loc) · 19.6 KB

How to Use This Guide

These sections provide step-by-step instructions for setting up new jobs, uploading wasm and schema files, and utilizing administrative tools within the Jobico-fn platform.

Workflow Overview: Tenant Job Management

This section provides an overview of the workflow involved in managing jobs within the Jobico-fn platform.

Jobs

A job within the Jobico-fn platform is a specification that outlines the orchestration of computational tasks. It serves as a blueprint defining the following essential elements:

  • Queues: The job specification includes the definition of queues, which act as intermediary storage mechanisms for facilitating the flow of events between producers and consumers within the ecosystem.

  • Runtimes: Runtimes are Jobicolet functions programmed in any WebAssembly (WASM)-compatible language. These programs contain business logic for event processing, defining how incoming events are handled and specifying the resulting output.

  • Events: Events represent occurrences or happenings within external systems or applications that trigger the execution of Jobico-fn functions. External systems or applications trigger REST calls to Jobico-fn with information about the event. Each event specified in the job definition includes detailed information such as the event schema for validation, the designated runtime for execution, and instructions for handling the result. Events serve as the catalyst for job execution, providing the necessary context and parameters for processing tasks efficiently within the platform.

alt

Job Specification and Deployment

The job specification, detailing the queues, runtimes, and events, is written in YAML format. These specifications will be deployed to the pltaform using the Command Line Interface (CLI) tool.

Anatomy of the spec:

A Job Definition YAML file includes various attributes that define the job's characteristics:

name

  • Description: A friendly name for the job, used for identification and management.

  • Example:

name: Customer Event Processing Definitions 

id

  • Description: The "id" attribute represents the unique identifier for the job. It serves as a distinct reference to identify and manage the job within the platform.

  • Example:

    id: customer-proc-jobs

tenant

  • Description: The "tenant" attribute represents the ID of the tenant associated with the job. It ensures that the job is attributed to a specific tenant within the multi-tenancy architecture of Jobico-fn.

  • Example:

    tenant: my-tenant-1

queues

  • Description: The "queues" section describes the queues associated with the job. This section allows for future expansion where queue environments and capabilities can be defined.

    • queues.id: ID of the queue.
    • queues.name: Friendly name of the queue.
  • Example:

       queues:
         - id: default-queue
           name: Default to all events

jobs

  • Description: The "jobs" section is where the jobs and events are defined and how they will be validated and processed.

    • jobs.event: An event definition.

    • jobs.event.name: Friendly name for the event.

    • jobs.event.id: ID for the event, used by the REST API and executors to determine the schema and WASM file.

    • jobs.event.datatype: Specifies the data type of the event. "0" represents JSON.

    • jobs.event.schema: Schema file definition:

      • jobs.event.schema.id: ID of the schema file.
      • jobs.event.schema.name: Name of the schema file.
      • jobs.event.schema.schemaref: Reference used to retrieve the file from the repository.
    • jobs.event.supplierqueue: Specifies the ID of the queue where this event will be published.

    • jobs.event.runtime: ID of the runtime that will process this event.

    • jobs.event.result: Specifies how the result of the execution will be treated (Under Construction).

  • Example:

    jobs:
      - event:
          name: New customer
          id: customer-registration
          datatype: 0
          schema:
             id: customer-registration-schema
             name: Customer registration schema
             schemaref: customer-registration-schema.json
          supplierqueue: 1
          runtime: 1

runtimes

  • Description: The "runtimes" section specifies the runtimes available to process the events.

    • runtimes.id: ID of the runtime, used to reference a specific runtime.
    • runtimes.name: Friendly name.
    • runtimes.moduleref: Reference used to retrieve the file from the repository.
    • runtimes.mainfuncname: Future usage.
    • runtimes.type: "0" represents WASM as the runtime type.
  • Example:

    runtimes:
      - id: wasm-runtime-customer-ev
        name: Wasm runtime for Customer events
        moduleref: wasm-runtime-customer-ev.wasm
        mainfuncname: event
        type: 0

    In this example, a runtime named "wasm-runtime-customer-ev" is defined with the associated WASM file and runtime type.

These attributes collectively form a comprehensive YAML file, capturing the essential details for defining and deploying jobs within the platform.

Example

name: Customer Event Processing Definitions
id: customer-proc-jobs
tenant: my-tenant-1
queues:
  - id: queue-default
    name: Default to all events
jobs:
  - event:
      name: New customer
      id: customer-registration
      datatype: 0
      schema:
        id: customer-registration-schema
        name: Customer registration schema
        schemaref: customer-registration-schema.json
      supplierqueue: queue-default
      runtime: wasm-runtime-customer-ev
runtimes:
  - id: wasm-runtime-customer-ev
    name:  Wasm runtime for Customer events
    moduleref: wasm-runtime-customer-ev.wasm
    mainfuncname: event
    type: 0

Jobicolet

What is a Jobicolet?

A Jobicolet is a specialized WebAssembly (WASM) function designed to process an event and generate a result within the platform. It represents the executable logic that is dynamically loaded and executed by the Job Executors.

Key Characteristics:

  1. WASM Execution:

    • A Jobicolet is implemented as a WebAssembly module, allowing it to be written in any programming language that compiles to WebAssembly.
  2. Event Processing:

    • The primary function of a Jobicolet is to process events. It takes as input a JSON string with the event data, performs the specified logic defined within the WASM module, and produces a result based on the defined processing rules.
  3. Result Generation:

    • Upon processing an event, a Jobicolet generates a result. The nature of the result depends on the specific logic implemented in the WASM module. It could be a computation outcome, a transformed dataset, or any other relevant output. However, it's important to note that a Jobicolet can only return one of the following values as output:

      • A numeric return value:
        • 0 indicates successful execution .
        • Non-zero value signifies an error.
      • A string.

    These are the only values that a Jobicolet can produce as output.

Development

SDK

The SDKs, currently available for Go, Rust and Python, offers essential functionality for developing Jobicolets.

Capabilities

Logging

Levels
Level Description
0 Debug
1 Info
2 Warning
3 Error
4 Fatal Error
5 Panic
6 Disabled
Methods
Log (Level, Message)
Examples

Go

	sdk.Log(sdk.Info, "info")

Rust

	jobicolet::log(1, "info");

Jobicolet Examples: Structure Overview

Go

package main

import (
  // The SDK package must be included as part of the Jobicolet.
	"github.com/andrescosta/jobicolet-sdk-go/pkg/sdk"
)

// main is required if Tinygo is used.
func main() {}

// The _init method is executed during the initialization process.
// The OnEvent handler must be set up with the name of event handler.
func _init() {
	sdk.OnEvent = myhandler
}

// This is the event handler. It gets a string as input and returns a code and string.
func myhandler(data string) (uint64, string) {
	sdk.Log(sdk.InfoLevel, "Processing event")
	return sdk.NoError, "Hello, from a Go script!"
}

Rust

// The SDK crate must be included as part of the Jobicolet.
extern crate jobicolet;

#[cfg_attr(all(target_arch = "wasm32"), export_name = "init")]
#[no_mangle]
// The _init method is executed during the initialization process.
// The ON_EVENT handler must be set up with the name of event handler.
pub unsafe extern "C" fn _init() {
    jobicolet::ON_EVENT = Some(mytest)
}

// This is the event handler. It gets a string as input and returns a code and string.
fn mytest(data:&String)->(u64, String){
    jobicolet::log(1, "Processing event");
    return (0, ["Hello, from a rusty script!"].concat())
}

Tools

Command Line Tool

Overview:

The Command Line Tool is a management interface designed to facilitate the deployment, rollback, or redeployment of jobs within the system. It offers a range of commands for uploading WebAssembly (WASM) and schema files, as well as streaming information from the Executions Recorder.

Commands:

  1. Deployment:

    • Deploy:

      • The deploy command is employed to add a job definition to the system.If the -update flag is provided and the job has already been deployed, the command will redeploy it.
      cli deploy [-update] my-job-definition.yaml
    • Rollback:

      • The rollback command allows for the rollback of a deployed job to a previous state. It's a useful feature for reverting to a stable configuration in case of issues.
      cli rollback my-job-definition.yaml
  2. File Upload:

    • Upload WASM:

      • The upload wasm command enables the upload of a WebAssembly file to the Job Repository. A WASM file uploaded using the tool will be referenced in the Job definition specification as the file that contains the logic for processing the event.
      cli upload wasm <tenant id> <file id> <my-job-logic.wasm>
    • Upload Schema:

      • The upload json command allows the upload of JSON schema files to the Job Repository. These files define the structure of events processed by the platform. It will be referenced by the Job definition specification as the artifact used to validate the event upon its arrival to the platform.
      cli upload json <tenant id> <file id> <my-job-logic.json>
  3. Streaming Information:

    • Stream from Recorder:

      • The recorder command allows users to stream information from the Executions Recorder. This feature is valuable for real-time monitoring of the job executions. Using the '-lines ' flag outputs the last NM lines produced by the Jobs for the latest executions.
      cli recorder [-lines NM]
  4. Information:

    • Deployments

      • The show deploy command prints information about a Job Definition deployed previously. It offers details on the configuration, queues, runtimes, and associated schema of a deployed job.
      cli show deploy <tenant id> <definition id>
    • Environment(experimental)

      • The show env command prints information about the nodes that composed a Jobico-fn's cluster. This information provided is currently not used by the platform at this moment.
      cli show env

Dashboard - Terminal GUI

Overview:

The Dashboard is a terminal-based graphical user interface (GUI) designed to offer an interactive and visual representation of the system. This GUI allows users to seamlessly visualize deployed jobs, explore files in the repository, and stream real-time results produced by executed jobs, all within the convenience of the terminal.

Functionality:

  1. Visualizing Deployed Jobs:

    • The Dashboard GUI presents a visual overview of deployed jobs, displaying relevant details such as job names, configurations, and status indicators. Users can easily navigate and interact with job-related information.
  2. Browsing Repository Files:

    • Users can explore files stored in the Job Repository through an intuitive graphical interface. This includes the ability to inspect WebAssembly (WASM) files, JSON schema definitions, and other artifacts crucial for job execution.
  3. Streaming Job Results:

    • The Dashboard supports real-time streaming of results produced by executed jobs. The GUI provides a dynamic display of outcomes, offering users immediate visibility into the status and performance of their jobs.

Launching the Dashboard:

dashboard [-debug] [-sync]

Executing this command launches the Dashboard GUI, initiating an interactive environment for users to visually explore deployed jobs and related information.

Screenshots

  1. Job definitions

alt

  1. Schema

alt

  1. Recorder output

alt

Getting Started: Deployment, Coding, and Event Processing

Deployment

Prerequisites:

  1. Ensure Docker are installed on your local machine.

Steps:

  1. Clone the jobicolet-examples repository from GitHub using the following command:

    git clone https://github.com/andrescosta/jobico
  2. Run Docker Compose:

    de jobico
    make dckr_up

    This command will start the Docker Compose stack based on the configuration defined in the compose/compose.yml file.

  3. Verify Listener on Port 8080:

    Once the Docker Compose stack is up and running, you can verify that the Listener is running on port 8080 by making a request. You can use a tool like curl or a web browser.

    • Using curl:

      curl http://localhost:8080
    • If using a web browser, navigate to http://localhost:8080 in your browser.

  4. Stop and Cleanup:

    When you are done testing, you can stop the Docker Compose stack using:

    make dckr_down
    #make dckr_stop 'for just stop it

    This will stop and remove the containers defined in the compose/compose.yml file.

Open Telemetry

A Docker Compose file with the OpenTelemetry stack enabled is provided. You can initiate it by executing the following command:

make dckr_upobs

The Prometheus console is reachable at: http://localhost:9090/, while the Jaeger console can be accessed at: http://localhost:16686/

Jobicolet Development

Rust

Prerequisites:

  1. Install Rust:

  2. Install wasm-pack:

    • After installing Rust, install wasm-pack by running the following command:

      cargo install wasm-pack
  3. Clone the Examples Repository:

    • Clone the jobicolet-examples repository from GitHub using the following command:

      git clone https://github.com/andrescosta/jobicolet-examples.git

Build the Rust Example:

  1. Navigate to the Rust Example Directory:

    • Change your working directory to the location of the Rust example in the jobicolet-examples repository:

      cd jobicolet-examples/rust/greet
  2. Compile the Example using Cargo:

    • Use the following command to compile the Rust program (greet.rs) using Cargo:

      cargo build --release --target wasm32-unknown-unknown

    This command instructs Cargo to build the Rust program in release mode (--release) for the WebAssembly target (--target wasm32-unknown-unknown).

  3. Verify the Output:

    • After a successful build, you should find the compiled WebAssembly module in the target/wasm32-unknown-unknown/release/ directory. The file will be named greet.wasm.
  4. Upload the WASM file to Jobico-fn:

    • Following the compilation of the file, it is imperative to upload it to Jobico-fn by executing the following command:
     cli upload wasm demorust greet-wasm-rust.wasm target\wasm32-unknown-unknown\release\greet.wasm
  5. Upload the schema file to Jobico-fn:

    • Executing this command will upload the schema file, facilitating the validation of the associated event:
     cli upload json demorust  greet-schema-rust.json schema.json
  6. Deploy the job:

    • Executing this command will initiate the deployment of the Job:
     cli deploy job-rust-greet.yml
  7. Start streaming results:

    • Executing this command will initiate the streaming of results from the Recorder component:
     cli recorder
  8. Send an event:

    • Executing this command will dispatch an event to Jobico-fn:
          curl --request POST \ 
          --url http://localhost:8080/events/demogo/evgo \  
          --header 'content-type: application/json' \
          --data '{"data": [{"firstName": "Rust","lastName": "WASM"}]}'
    • Return to the terminal where the results are currently being streamed and review the log.

Tinygo

Prerequisites:

  1. Install TinyGo:

  2. Clone the Examples Repository:

    • Clone the jobicolet-examples repository from GitHub using the following command:

      git clone https://github.com/andrescosta/jobicolet-examples.git
  3. ** The Jobico-fn platform is up and running **

    • The Docker section taches you how to start Jobico-fn

Build the Go Example:

  1. Navigate to the Go Example Directory:

    • Change your working directory to the location of the Go example in the jobicolet-examples repository:

      cd jobicolet-examples/go/greet
  2. Compile the Example using TinyGo:

    • Use the following command to compile the greet.go example using TinyGo:

      tinygo build -scheduler=none --no-debug -target=wasi greet.go

    This command instructs TinyGo to build the Go program (greet.go) for the WebAssembly System Interface (WASI) target.

  3. Verify the Output:

    • After a successful build, you should see an executable file named greet.wasm in the same directory.
  4. Upload the WASM file to Jobico-fn:

    • Following the compilation of the file, it is imperative to upload it to Jobico-fn by executing the following command:
     cli upload wasm demogo greet-wasm-go.wasm greet.wasm
  5. Upload the schema file to Jobico-fn:

    • Executing this command will upload the schema file, facilitating the validation of the associated event:
     cli upload json demogo greet-schema-go.json schema.json
  6. Deploy the job:

    • Executing this command will initiate the deployment of the Job:
     cli deploy job-go-greet.yml
  7. Start streaming results:

    • Executing this command will initiate the streaming of results from the Recorder component:
     cli recorder
  8. Send an event:

    • Executing this command will dispatch an event to Jobico-fn:
          curl --request POST \ 
          --url http://localhost:8080/events/demogo/evgo \  
          --header 'content-type: application/json' \
          --data '{"data": [{"firstName": "Tinygo","lastName": "Wasm"}]}'
    • Return to the terminal where the results are currently being streamed and review the log.