Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/bilibili/discovery
A registry for resilient mid-tier load balancing and failover.
https://github.com/bilibili/discovery
discovery eureka golang
Last synced: 1 day ago
JSON representation
A registry for resilient mid-tier load balancing and failover.
- Host: GitHub
- URL: https://github.com/bilibili/discovery
- Owner: bilibili
- License: mit
- Created: 2018-04-20T12:57:50.000Z (almost 7 years ago)
- Default Branch: master
- Last Pushed: 2023-07-16T03:33:04.000Z (over 1 year ago)
- Last Synced: 2025-01-17T10:05:11.898Z (9 days ago)
- Topics: discovery, eureka, golang
- Language: Go
- Size: 2.39 MB
- Stars: 1,784
- Watchers: 63
- Forks: 401
- Open Issues: 27
-
Metadata Files:
- Readme: README.md
- Changelog: CHANGELOG.md
- License: LICENSE
Awesome Lists containing this project
- my-awesome - bilibili/discovery - 07 star:1.8k fork:0.4k A registry for resilient mid-tier load balancing and failover. (Go)
- awesome-go-extra - discovery - tier load balancing and failover.|1682|389|23|2018-04-20T12:57:50Z|2021-11-16T10:34:44Z| (Server Applications / HTTP Clients)
README
# Discovery
[![Build Status](https://travis-ci.org/bilibili/discovery.svg?branch=master)](https://travis-ci.org/bilibili/discovery)
[![Go Report Card](https://goreportcard.com/badge/github.com/bilibili/discovery)](https://goreportcard.com/report/github.com/bilibili/discovery)
[![codecov](https://codecov.io/gh/Bilibili/discovery/branch/master/graph/badge.svg)](https://codecov.io/gh/Bilibili/discovery)Discovery is a based service that is production-ready and primarily used at [Bilibili](https://www.bilibili.com/) for locating services for the purpose of load balancing and failover of middle-tier servers.
## Quick Start
### env
`go1.12.x` (and later)
### build
```shell
cd $GOPATH/src
git clone https://github.com/bilibili/discovery.git
cd discovery/cmd/discovery
go build
```### run
```shell
./discovery -conf discovery.toml -alsologtostderr
````-alsologtostderr` is `glog`'s flag,means print into stderr. If you hope print into file, can use `-log.dir="/tmp"`. [view glog doc](https://godoc.org/github.com/golang/glog).
### Configuration
You can view the comments in `cmd/discovery/discovery.toml` to understand the meaning of the config.
### Client
* [API Doc](doc/api.md)
* [Go SDK](naming/client.go) | [Example](naming/example_test.go)
* [Java SDK](https://github.com/flygit/discoveryJavaSDK)
* [CPP SDK](https://github.com/brpc/brpc/blob/master/src/brpc/policy/discovery_naming_service.cpp)
* [Python SDK](https://github.com/tomwei7/discovery-client)
* [other language](doc/sdk.md)## Intro/Arch/Practice
* [Introduction](doc/intro.md)
* [Architecture](doc/arch.md)
* [Practice in Bilibili](doc/practice.md)## Feedback
Please report bugs, concerns, suggestions by issues, or join QQ-group 716486124 to discuss problems around source code.