p2p-rendering-computation

command module
v0.0.0-...-9d99875 Latest Latest
Warning

This package is not in the latest version of its module.

Go to latest
Published: Oct 24, 2021 License: GPL-2.0 Imports: 4 Imported by: 0

README


p2prc

GPLv2 license Maintenance made-with-Go GoDoc reference example

The main aim of this project was to create a custom peer to peer network. The user acting as the client has total flexibility on how to batch the tasks and the user acting as the server has complete flexibility on tracking the container's usages and killing the containers at any point of time.

Gophers talk

IMAGE ALT TEXT


Table of contents

  1. Introduction
  2. Installation
  3. Design Architecture
  4. Implementation
  5. Find out more

Introduction

This project aims to create a peer to peer (p2p) network, where a user can use the p2p network to act as a client (i.e sending tasks) or the server (i.e executing the tasks). A prototype application will be developed, which comes bundled with a p2p module and possible to execute docker containers or virtual environments across selected nodes.

Objectives

  • Background review on peer to peer network, virtual environments, decentralized rendering tools and tools to batch any sort of tasks.
  • Creating p2p network
  • Server to create a containerised environment
  • The client node to run tasks on Server containerised node

Read more on the introduction


Installation from source

  1. Ensure the Go compiler is installed
    go version
    
  2. Ensure docker is installed (Should run without sudo)
    docker ps
    
  3. Clone this repository
    git clone https://github.com/Akilan1999/p2p-rendering-computation
    
  4. Install and build the project
    make install 
    
  • If you look closely you will get outputs such as:

    // Add them to your .bashrc file      
    export P2PRC=/<path>/p2p-rendering-computation
    export PATH=/<path>/p2p-rendering-computation:${PATH}
    
  1. Test if it works
    p2prc -h 
    
    or
    ./p2prc -h 
    

Read more on the installation and usage


Design Architecture

The design architecture was inspired and based on the linux kernel design. The project is segmented into various modules. Each module is responsible for certain tasks in the project. The modules are highly dependent on each other hence the entire codebase can be considered as a huge monolithic chuck which acts as its own library

Read more on the Design Architecture


Implementation

The programming language used for this project was Golang. The reason Go lang was chosen was because it is a compiled language. The entire codebase is just a single binary file. When distributing to other linux distributing the only requirement would be the binary file to run the code. It is easy to write independant modules and be monolithic at the sametime using Go. Using Go.mod makes it very easy to handle external libraries and modularise code. The go.mod name for the project is git.sr.ht/~akilan1999/p2p-rendering-computation.

Read more on the Implementation


Find out more

As we are working on the open source project p2prc (i.e p2p network designed for computation).If you are interested in participating as a contributor or just providing feedback on new features to build or even just curious about new features added to the project. We have decided to create a discord group.
Support Server

Documentation

The Go Gopher

There is no documentation for this package.

Directories

Path Synopsis
Package generate The purpose of this package is to ensure that we can extend the use-case of P2PRC.
Package generate The purpose of this package is to ensure that we can extend the use-case of P2PRC.

Jump to

Keyboard shortcuts

? : This menu
/ : Search site
f or F : Jump to
y or Y : Canonical URL