Giter Club home page Giter Club logo

gokit's Introduction

gokit Circle CI Drone.io Travis CI GoDoc

Gokit is a distributed programming toolkit for microservices in the modern enterprise.

Motivation

See the motivating blog post and the video of the talk.

Goals

  • Operate in a heterogeneous SOA — expect to interact with mostly non-gokit services
  • RPC as the messaging pattern
  • Pluggable serialization and transport — not just JSON over HTTP
  • Zipkin-compatible request tracing

Non-goals

  • Supporting messaging patterns other than RPC — pub/sub, CQRS, etc.
  • Having opinions on deployment, orchestration, process supervision, etc.
  • Having opinions on configuration passing, i.e. flags, env vars, files, etc.

Component status

Contributing

At this stage, we're still developing the initial drafts of all of the packages, using an RFC workflow. Before submitting major changes, please write to the mailing list to register your interest, and check the open issues and pull requests for existing discussions.

Dependency management

Users who import gokit into their package main are responsible to organize and maintain all of their dependencies to ensure code compatibility and build reproducibility. Gokit makes no direct use of dependency management tools like Godep.

We will use a variety of continuous integration providers to find and fix compatibility problems as soon as they occur.

API stability policy

The gokit project depends on code maintained by others. This includes the Go standard library and sub-repositories and other external libraries. The Go language and standard library provide stability guarantees, but the other external libraries typically do not. The API Stability RFC proposes a standard policy for package authors to advertise API stability. The go-kit project prefers to depend on code that abides the API stability policy.

Related projects

Projects with a ★ have had particular influence on gokit's design.

Service frameworks

  • go-micro, a microservices client/server library ★
  • gocircuit, dynamic cloud orchestration
  • gotalk, async peer communication protocol & library
  • Kite, a micro-service framework

Individual components

Web frameworks

Additional reading

gokit's People

Contributors

adg avatar bg451 avatar bictorman avatar chrishines avatar daniel-garcia avatar goonzoid avatar grobie avatar mattheath avatar peterbourgon avatar sevein avatar sqs avatar taotetek avatar tsenart avatar

Watchers

 avatar  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.