A tracker for the LBRY protocol.
Find a file
Jimmy Zelinskie ab6726b895 Merge pull request #192 from mrd0ll4r/cpuprofile
general: add CPU profiling
2016-08-01 19:54:02 -04:00
cmd/chihaya general: add CPU profiling 2016-08-01 16:51:48 -04:00
middleware middleware: fix varinterval README (#175) 2016-05-25 01:36:52 -04:00
pkg pkg: add stopper 2016-06-19 12:40:13 -04:00
server store: do not test AnnouncePeers 2016-07-21 12:23:20 -04:00
tracker store: add ErrResourceDoesNotExist and update memory implementation 2016-05-17 00:49:06 -04:00
.travis.yml travis: add golint, goimports and go vet (#173) 2016-05-20 13:12:51 -04:00
AUTHORS Bring in more old behaviour, use types for peer_id and infohash 2016-03-02 21:05:31 -05:00
chihaya.go store: fix various small test issues 2016-07-05 16:36:40 -04:00
chihaya_test.go make infohash and peerID byte arrays (#169) 2016-05-16 23:48:23 -04:00
config.go middleware: made middleware configurable 2016-03-16 18:20:59 +01:00
config_example.yaml config: make example config work (#168) 2016-05-19 10:37:47 -04:00
CONTRIBUTING.md readme: add CONTRIBUTING.md 2016-03-30 01:21:53 -04:00
CONTRIBUTORS CONTRIBUTORS: add myself to the contributors list 2016-03-31 02:30:34 +01:00
Dockerfile add dockerfile 2016-05-21 17:59:04 -04:00
glide.lock add glide.yaml 2016-05-21 17:59:04 -04:00
glide.yaml add glide.yaml 2016-05-21 17:59:04 -04:00
LICENSE Bring in more old behaviour, use types for peer_id and infohash 2016-03-02 21:05:31 -05:00
README.md README: reorganize and add warnings 2016-04-02 19:35:04 -04:00

Chihaya

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

Note: The master branch may be in an unstable or even broken state during development. Please use releases instead of the master branch in order to get stable binaries.

Chihaya is an open source BitTorrent tracker written in Go.

Differentiating features include:

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

Development

Getting Started

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

$ go get -t -u github.com/chihaya/chihaya
$ go install github.com/chihaya/chihaya/cmd/chihaya

Contributing

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.

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.

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