Giter VIP home page Giter VIP logo

job-processor's Introduction

Technical Assessment

Requirements

Docker.

Running application

docker-compose up

Starts a PHP and MySQL container on localhost (127.0.0.1) at ports 80 and 3306 respectively. Some basic test data is loaded automatically.

The entire system can be refreshed using:

docker-compose down

And then starting it back up again.

API Endpoints

All data is returned as JSON. The endpoints are implemented in src/index.php.

  • GET / Returns a listing of all jobs
  • GET /job Returns the highest priority job, the next job to be processed
  • GET /job/$id Returns the job with the specified ID
  • GET /process Processes the highest priority job
  • GET /process/$id Processes (or re-processes) the job with the specified ID
  • GET /users Lists all users
  • GET /user/$id Returns the specified user and all their jobs
  • POST /job Adds a new job (params: cmd, priority, user_id)
  • POST /register Registers a new user (params: name)

Scalability

The attached System Diagram illustrates a basic scalable distributed system.

System Diagram

This design can be further scaled by:

  • Separating the API servers into read/write servers
  • Adding load balancers in front of the API servers
  • Implementing some form of key:value memory caching for read accesses with a least recently used eviction policy

job-processor's People

Contributors

afeique avatar

Watchers

 avatar

Recommend Projects

  • React photo React

    A declarative, efficient, and flexible JavaScript library for building user interfaces.

  • Vue.js photo Vue.js

    ๐Ÿ–– Vue.js is a progressive, incrementally-adoptable JavaScript framework for building UI on the web.

  • Typescript photo Typescript

    TypeScript is a superset of JavaScript that compiles to clean JavaScript output.

  • TensorFlow photo TensorFlow

    An Open Source Machine Learning Framework for Everyone

  • Django photo Django

    The Web framework for perfectionists with deadlines.

  • D3 photo D3

    Bring data to life with SVG, Canvas and HTML. ๐Ÿ“Š๐Ÿ“ˆ๐ŸŽ‰

Recommend Topics

  • javascript

    JavaScript (JS) is a lightweight interpreted programming language with first-class functions.

  • web

    Some thing interesting about web. New door for the world.

  • server

    A server is a program made to process requests and deliver data to clients.

  • Machine learning

    Machine learning is a way of modeling and interpreting data that allows a piece of software to respond intelligently.

  • Game

    Some thing interesting about game, make everyone happy.

Recommend Org

  • Facebook photo Facebook

    We are working to build community through open source technology. NB: members must have two-factor auth.

  • Microsoft photo Microsoft

    Open source projects and samples from Microsoft.

  • Google photo Google

    Google โค๏ธ Open Source for everyone.

  • D3 photo D3

    Data-Driven Documents codes.