All Projects → chihaya → Chihaya

chihaya / Chihaya

Licence: other
A customizable, multi-protocol BitTorrent Tracker

Programming Languages

go
31211 projects - #10 most used programming language

Projects that are alternatives of or similar to Chihaya

Katwebx
An extremely fast static web server and reverse proxy for the modern web.
Stars: ✭ 39 (-96.55%)
Mutual labels:  high-performance
Rats Search
BitTorrent P2P multi-platform search engine for Desktop and Web servers with integrated torrent client.
Stars: ✭ 1,037 (-8.23%)
Mutual labels:  bittorrent
Netmap Tutorial
Netmap tutorial at SIGCOMM 2017 and AsiaBSDCon 2018
Stars: ✭ 60 (-94.69%)
Mutual labels:  high-performance
Tarsbenchmark
benchmark tool for tars/http service
Stars: ✭ 41 (-96.37%)
Mutual labels:  high-performance
Torrent Client
Tiny BitTorrent client written in Go
Stars: ✭ 1,024 (-9.38%)
Mutual labels:  bittorrent
Webtorrent Desktop
❤️ Streaming torrent app for Mac, Windows, and Linux
Stars: ✭ 8,587 (+659.91%)
Mutual labels:  bittorrent
Awesome Scalability Toolbox
My opinionated list of products and tools used for high-scalability projects
Stars: ✭ 34 (-96.99%)
Mutual labels:  high-performance
Fast String Interpolator
Scala macro that generates ultra-fast string interpolators.
Stars: ✭ 64 (-94.34%)
Mutual labels:  high-performance
Radiance
High-Performance BitTorrent Tracker written in C++
Stars: ✭ 46 (-95.93%)
Mutual labels:  high-performance
Erlcass
High-Performance Erlang Cassandra driver based on DataStax cpp-driver
Stars: ✭ 59 (-94.78%)
Mutual labels:  high-performance
Uvloop
Ultra fast asyncio event loop.
Stars: ✭ 8,246 (+629.73%)
Mutual labels:  high-performance
Geojs
Geo-location lookup API
Stars: ✭ 45 (-96.02%)
Mutual labels:  high-performance
Edgedb Js
JavaScript bindings for EdgeDB
Stars: ✭ 59 (-94.78%)
Mutual labels:  high-performance
Bittorrent Dht
🕸 Simple, robust, BitTorrent DHT implementation
Stars: ✭ 1,004 (-11.15%)
Mutual labels:  bittorrent
Goods Seckill
高性能电商秒杀解决方案,redis预减库存,消息队列异步下单,订单防重,订单防刷,秒杀接口地址隐藏,数学公式验证码
Stars: ✭ 61 (-94.6%)
Mutual labels:  high-performance
Geatpy
Evolutionary algorithm toolbox and framework with high performance for Python
Stars: ✭ 990 (-12.39%)
Mutual labels:  high-performance
Bittorrent Peerid
Map a BitTorrent peer ID to a human-readable client name and version
Stars: ✭ 47 (-95.84%)
Mutual labels:  bittorrent
Phpspidermagnetbittorrent
php实现p2p中DHT网络爬虫,并提供搜索下载
Stars: ✭ 64 (-94.34%)
Mutual labels:  bittorrent
Go Workerpool
Worker pool implementation
Stars: ✭ 62 (-94.51%)
Mutual labels:  high-performance
Lambda
LAMBDA – the Local Aligner for Massive Biological DatA
Stars: ✭ 59 (-94.78%)
Mutual labels:  high-performance

Chihaya

Build Status Docker Repository on Quay.io Go Report Card GoDoc Lines of Code 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:

  • HTTP and UDP protocols
  • IPv4 and IPv6 support
  • Pre/Post middleware hooks
  • YAML configuration
  • Metrics via Prometheus
  • High Availability via Redis
  • Kubernetes deployment via Helm

Why Chihaya?

Chihaya is built for developers looking to integrate BitTorrent into a preexisting production environment. Chihaya's pluggable architecture and middleware framework offers a simple and flexible integration point that abstracts the BitTorrent tracker protocols. The most common use case for Chihaya is enabling peer-to-peer cloud software deployments.

Development

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.

Getting Started

Building from HEAD

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

$ git clone [email protected]:chihaya/chihaya.git
$ cd chihaya
$ go build ./cmd/chihaya
$ ./chihaya --help

Docker

Docker containers are available for HEAD and stable releases.

Testing

The following will run all tests and benchmarks. Removing -bench will just run unit tests.

$ go test -bench $(go list ./...)

The Chihaya executable contains a command to end-to-end test a BitTorrent tracker. See

$ chihaya --help

Configuration

Configuration of Chihaya is done via one YAML configuration file. The dist/ directory contains an example configuration file. Files and directories under docs/ contain detailed information about configuring middleware, storage implementations, architecture etc.

Related projects

  • BitTorrent.org: a static website containing the BitTorrent spec and all BEPs
  • OpenTracker: a popular BitTorrent tracker written in C
  • Ocelot: a private BitTorrent tracker written in C++
Note that the project description data, including the texts, logos, images, and/or trademarks, for each open source project belongs to its rightful owner. If you wish to add or remove any projects, please contact us at [email protected].