Skip to content

Latest commit

 

History

History
138 lines (88 loc) · 4.61 KB

README.md

File metadata and controls

138 lines (88 loc) · 4.61 KB

dockerComp

  • Youtube Video Explaining this project:

    Here's a video for DockerComp

  • Click here for Screencast for running just one script on client side.

NOTES

  • Demo link to be updated soon.

  • In case you're curious how to go about running this from client side:

    • So once the server is up and running, all one has to do is download and run install_me.sh
  • Docker Image: $ docker pull arcolife/docker_comp (will be kept updated)

GOAL

To setup a basic prototype for distributed computing in docker. If time permits, add a complex computing task.

FAQ

Refer to Wiki .. click Here!.

INTRODUCTION

For the purpose of Distributed (Scientific) Computing, scientists across the world have been mostly using pre-configured VM images to let the client volunteer in contributing towards micro-processing tasks that involve processing of raw data received in chunks over the network.

But, since the introduction of Docker, life has changed and so have the performance benchmarks. We propose an system that uses the benefits of Docker to hopefully perform far better than the currently achieved milestones through VMs. The VMs have a huge overhead of starting up, as compared to Docker containers. Moreover, we don't even need to explain the difference between running more than one VM on a HostOS compared to running multiple docker containers on that same machine! See the point? :)

References:

 - http://www.rightscale.com/blog/sites/default/files/docker-containers-vms.png 
 - http://en.wikipedia.org/wiki/Docker_%28software%29#cite_ref-3

So, just to give you a context of this whole project, take a look at this project called CernVM. This is a really awesome project, developed to help collect CERN's LHC data and perform data analysis on a volunteer's computer or even on commercial clouds. Just imagine if the whole process of using VM was dockerized!

FEATURES

  • Can be used for: - Image Processing - General Data Analysis - Scientific Computing - CrowdSourcing projects.

FUTURE GOALS

  • Make this a pluggable dockerized distributed computing tool, where you just have to include a compution task (say, map-reduce) and make it send data to clients. The app should be able to handle the rest.

  • Benchmark results and compare with existing methodologies.

STEPS

  • Server side:

    • Make sure that your 'server-side/' is up and running, either locally (for test purpose), or if its deployed elsewhere, then the hostname/IP is provided in the $SERVER_HOSTNAME in your copy of install_me.sh. (refer next major point on 'Client side' for this script)

    • To run the server-side, open up a terminal, go to dockerComp/server-side/ and run $ ./start This starts the server locally on your machine.

  • Client side:

    $ ./install_me.sh [configure your Server location in this script, in SERVER_HOSTNAME]

Cheers! :)

Note: For server side deployement (i.e., the server that basically is responsible for distributing data to clients), It has to be deployed somewhere and it's IP has to be provided in your install_me.sh. And then you may distribute the script to the clients.

TESTS

  • From client side:

    • although the default connection establishment test is included with install scripts; run $ ./client-side/test.sh $SERVER_D
  • From server side:

    • TBD
  • Workloads:

    • Currently a simple task. TBD.

WORKFLOW

  1. Server

    • Dashboard to Manage:

      • No. of Clients (and # of containers per client)
      • Resources allocated to the containers
    • Master app that manages data sent to each client and checks for integrity.

  2. Client

    • Installation of Docker
    • Starting Containers
    • Installation of Application inside the Container
    • Connection Establishment with the Server.
    • Scripts for the computation
    • Error Reporting

REFERENCES

  1. https://github.com/cernvm
  2. http://en.wikipedia.org/wiki/List_of_distributed_computing_projects
  3. http://www.rightscale.com/blog/sites/default/files/docker-containers-vms.png
  4. http://www.psc.edu/science/
  5. http://pybossa.com/
  6. https://okfn.org/press/releases/crowdcrafting-putting-citizens-control-citizen-science/
  7. http://www.mediaagility.com/2014/docker-the-next-big-thing-on-cloud/
  8. http://cernvm.cern.ch/portal/