Skip to content

Latest commit

 

History

History
96 lines (64 loc) · 2.31 KB

README.md

File metadata and controls

96 lines (64 loc) · 2.31 KB

Basic Distributed Work System

logo

Authors

  • Ryan Showalter
  • Jack Twomey
  • Bradley Fellstrom
  • Zachary Tucker

Supervisor Description

  • Number: 1
  • Description: Handles worker registration and accepts jobs from clients. Distributes jobs amongst workers and sends results to the client.

Worker Description

  • Number: 1+
  • Description: Registers with a supervisor and accepts jobs.

Client Description

  • Number: 1
  • Description: Submits jobs to a supervisor and waits for output.

How to run

Manually

Setup

  1. cd to cmd
  2. If needed run "go clean" & "go build" in each subdir of cmd

Supervisor

  • ./supervisor {supervisor_port}

Worker(s)

  • ./worker {hostname}:{supervisor_port} {worker_port}

Client

  • ./client {optional flags} {hostname}:{supervisor_port} {path to file name}
  • {optional flags}: - -args: Command line args for file, for example "-la" when using ls - -range: A range of numbers to distribute work, for example: 1-10 - -runs: Number of times to run the file

Setup with script

  • ./simple_test.sh {optional flags}
    • -hn {hostname}: specify hostname (Default = 'http://127.0.0.1')
    • -sp {supervisor port}: specify the supervisor port (Default = 5001)
    • -wc {workers}: specify number of workers (Default = 1)
    • -p {panes}: specify number of panes per window (Default = 4)
    • -i: only use this when tmux is configured to start numbering windows at 1, instead of default 0. To find if 1 is configured, look for "set-option -g base-index 1" in local tmux.conf file.

Client setup with script

  • Same as manual use

Cleanup

For now, cleanup is done by using CTRL-C on the workers and the supervisor, then exiting all windows. For the script, you can do CTRL-B + D to detach from the current window. This will fully exit all running code.

Testing

A good way to test our program and get an idea of how the work is distributed is to use this script:

#!/usr/bin/env bash

echo $1

The optional arg is a range split amongst workers. For 1-10, the supervisor will create 10 jobs and split it amongst the workers. The output should be the numbers 1-10 printed out in no particular order.

Supported File Types

  • .java
  • .class
  • .sh
  • .py
  • portable executables (with env included in file)
  • system programs (ls, hostname, etc.)