Skip to content
This repository has been archived by the owner on Sep 27, 2019. It is now read-only.
viveksengupta edited this page Aug 14, 2015 · 47 revisions

|

  1. What Is Peloton?
  2. What Is Peloton For?
  3. What Problem Does Peloton Solve?
  4. What Design Principles Underlie Peloton?
  5. How Does Peloton Accomplish Its Goals?
|images/peloton-logo.jpg| |:-----------|-----------:| ## What Is Peloton?

Short description about Peloton.

History of Peloton

Short history

The following links provide more context around Peloton and the challenges that it attempts to address:

## What Is Peloton For?

Peloton is designed to do the following:

  • Give protection from and control over latency and failure from dependencies accessed (typically over the network) via third-party client libraries.
## What Problem Does Peloton Solve?

Small description.

Example: For example, for an application that depends on 30 services where each service has 99.99% uptime, here is what you can expect:

99.9930 = 99.7% uptime
0.3% of 1 billion requests = 3,000,000 failures
2+ hours downtime/month even if all dependencies have excellent uptime.

Reality is generally worse.


When everything is healthy the request flow can look like this:

images/soa-1-640.png

These issues are exacerbated when network access is performed through a third-party client — a “black box” where implementation details are hidden and can change at any time.

## What Design Principles Underlie Peloton?

Peloton works by:

  • Preventing any single dependency from using up all container (such as Tomcat) user threads.
## How Does Peloton Accomplish Its Goals?

Peloton does this by:

  • Wrapping all calls to external systems (or “dependencies”) in a PelotonCommand or PelotonObservableCommand object which typically executes within a separate thread (this is an example of the command pattern).

Response to make when any type of failure occurs in the dependency:

images/soa-4-isolation-640.png

Learn more about How It Works and How To Use.

Clone this wiki locally