Josh de Kock a9d3c2e071 store/peer_store: Add tests & functions for getting info about peers
This commit adds four functions: GetSeeders, GetLeechers,
NumSeeders, and NumLeechers to the store/peer_store API. The
first two functions are for getting a list of all the
seeders/leechers by an info hash, the latter two are helper
functions which use the Get functions, combine the ipv4, and
ipv4, and then len() them. It also adds some minimal tests for
memory/peer_store.
2016-04-02 21:49:08 +01:00
2016-03-02 21:05:33 -05:00
2016-03-02 21:05:31 -05:00
2016-03-30 00:20:51 -04:00
2016-03-30 01:21:53 -04:00
2016-03-02 21:05:31 -05:00
2016-03-30 01:21:53 -04:00

Chihaya

Build Status Docker Repository on Quay.io GoDoc License IRC Channel

Chihaya is an open source BitTorrent tracker written in Go.

Differentiating features include:

  • Protocol-agnostic and middleware-composed logic
  • Low resource consumption and fast, asynchronous request processing
  • Unified IPv4 and IPv6 swarms
  • YAML configuration
  • Optional metrics via Prometheus

Production Use

Facebook

Facebook uses BitTorrent to deploy new versions of their software. In order to optimize the flow of traffic within their datacenters, Chihaya is configured to prefer peers within the same subnet. Because Facebook organizes their network such that server racks are allocated IP addresses in the same subnet, the vast majority of deployment traffic never impacts the congested areas of their network.

CoreOS

Quay is a container registry that offers the ability to download containers via BitTorrent in order to speed up large or geographically distant deployments. Announce URLs from Quay's torrent files contain a JWT in order to allow Chihaya to verify that an infohash was approved by the registry. By verifying the infohash, Quay can be sure that only their content is being shared by their tracker.

Getting Started

In order to compile the project, the latest stable version of Go and a working Go environment are required.

$ go get github.com/chihaya/chihaya
$ go install github.com/chihaya/chihaya/cmd/chihaya

Development

Long-term discussion and bug reports are maintained via GitHub Issues. Code review is done via GitHub Pull Requests. Real-time discussion is done via freenode IRC.

For more information read CONTRIBUTING.md.

  • OpenTracker: a popular BitTorrent tracker written in C
  • Ocelot: a private BitTorrent tracker written in C++

License

Chihaya is distributed under the 2-Clause BSD license that can be found in the LICENSE file.

Languages
Go 99.6%
Dockerfile 0.2%
Shell 0.2%