Giter Site home page Giter Site logo

kurt-russell / rdsn Goto Github PK

View Code? Open in Web Editor NEW

This project forked from microsoft/rdsn

0.0 1.0 0.0 83.04 MB

Robust Distributed System Nucleus (rDSN) is an open framework for quickly building and managing high performance and robust distributed systems.

License: MIT License

CMake 1.13% Shell 1.26% Batchfile 0.66% C++ 59.97% PHP 2.74% Python 0.74% Dockerfile 0.02% C 3.78% C# 2.93% Thrift 0.08% JavaScript 24.33% CSS 0.42% HTML 1.95%

rdsn's Introduction

Build Status Build status

Robust Distributed System Nucleus (rDSN) is a framework for quickly building robust distributed systems. It has a microkernel for pluggable components, including applications, distributed frameworks, devops tools, and local runtime/resource providers, enabling their independent development and seamless integration. The project was originally developed for Microsoft Bing, and now has been adopted in production both inside and outside Microsoft.

The core of rDSN is a service kernel with which we can develop (via Service API and Tool API) and plugin lots of different application, framework, tool, and local runtime modules, so that they can seamlessly benefit each other. Here is an incomplete list of the pluggable modules.

Pluggable modules Description Release
dsn.core rDSN service kernel 1.0.0
dsn.dist.service.stateless scale-out and fail-over for stateless services (e.g., micro services) 1.0.0
dsn.dist.service.stateful.type1 scale-out, replicate, and fail-over for stateful services (e.g., storage) 1.0.0
dsn.dist.service.meta_server membership, load balance, and machine pool management for the above service frameworks 1.0.0
dsn.dist.uri.resolver a client-side helper module that resolves service URL to target machine 1.0.0
dsn.dist.traffic.router fine-grain RPC request routing/splitting/forking to multiple services (e.g., A/B test) todo
dsn.tools.common deployment runtime (e.g., network, aio, lock, timer, perf counters, loggers) for both Windows and Linux; simple toollets, such as tracer, profiler, and fault-injector 1.0.0
dsn.tools.nfs an implementation of remote file copy based on rpc and aio 1.0.0
dsn.tools.emulator an emulation runtime for whole distributed system emulation with auto-test, replay, global state checking, etc. 1.0.0
dsn.tools.hpc high performance counterparts for the modules as implemented in tools.common todo
dsn.tools.explorer extracts task-level dependencies automatically 1.0.0
dsn.tools.log.monitor collect critical logs (e.g., log-level >= WARNING) in cluster 1.0.0
dsn.app.simple_kv an example application module 1.0.0

rDSN provides flexible configuration so that developers can combine and configure the modules differently to enable different scenarios. All modules are loaded by dsn.svchost, a common process runner in rDSN, with the given configuration file. The following table lists some examples (note dsn.core is always required therefore omitted in Modules column).

Scenarios Modules Config Demo
logic correctness development dsn.app.simple_kv + dsn.tools.emulator + dsn.tools.common config todo
logic correctness with failure dsn.app.simple_kv + dsn.tools.emulator + dsn.tools.common config todo
performance tuning dsn.app.simple_kv + dsn.tools.common config todo
progressive performance tuning dsn.app.simple_kv + dsn.tools.common + dsn.tools.emulator config todo
Paxos enabled stateful service dsn.app.simple_kv + dsn.tools.common + dsn.tools.emulator + dsn.dist.uri.resolver + dsn.dist.serivce.meta_server + dsn.dist.service.stateful.type1 config todo

There are a lot more possibilities. rDSN provides a web portal to enable quick deployment of these scenarios in a cluster, and allow easy operations through simple clicks as well as rich visualization. Deployment scenarios are defined here, and developers can add more on demand.

  • reduced system complexity via microkernel architecture: applications, frameworks (e.g., replication, scale-out, fail-over), local runtime libraries (e.g., network libraries, locks), and tools are all pluggable modules into a microkernel to enable independent development and seamless integration (therefore modules are reusable and transparently benefit each other)

rDSN Architecture

  • flexible configuration with global deploy-time view: tailor the module instances and their connections on demand with configurable system complexity and resource allocation (e.g., run all nodes in one simulator for testing, allocate CPU resources appropriately for avoiding resource contention, debug with progressively added system complexity)

rDSN Configuration

  • transparent tooling support: dedicated tool API for tool development; built-in plugged tools for understanding, testing, debugging, and monitoring the upper applications and frameworks

rDSN Architecture

  • auto-handled distributed system challenges: built-in frameworks to achieve scalability, reliability, availability, and consistency etc. for the applications

rDSN service model

rDSN borrows the idea in many research work, from both our own and the others, and tries to make them real in production in a coherent way; we greatly appreciate the researchers who did these work.

License and Support

rDSN is provided on Windows and Linux, with the MIT open source license. You can use the "issues" tab in GitHub to report bugs.

rdsn's People

Contributors

imzhenyu avatar 0xfdi avatar qinzuoyan avatar shengofsun avatar mcfatealan avatar ykwd avatar glglwty avatar goksyli avatar xiaotz avatar zjc95 avatar lishenglong avatar linmajia avatar capfei avatar 0xdeadbeef-dot-com avatar

Watchers

James Cloos 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.