2016-02-26 01:17:30 +01:00
# Chihaya
2022-01-15 18:56:15 +01:00
[![Build Status ](https://github.com/chihaya/chihaya/workflows/Build%20&%20Test/badge.svg )](https://github.com/chihaya/chihaya/actions)
[![Container Image ](https://img.shields.io/github/v/release/chihaya/chihaya?color=%232496ED&label=container&logo=docker "Container Image" )](https://quay.io/repository/jzelinskie/chihaya?tab=tags)
2016-02-26 01:17:30 +01:00
[![GoDoc ](https://godoc.org/github.com/chihaya/chihaya?status.svg )](https://godoc.org/github.com/chihaya/chihaya)
[![License ](https://img.shields.io/badge/license-BSD-blue.svg )](https://en.wikipedia.org/wiki/BSD_licenses#2-clause_license_.28.22Simplified_BSD_License.22_or_.22FreeBSD_License.22.29)
2021-06-23 02:41:56 +02:00
[![IRC Channel ](https://img.shields.io/badge/IRC-%23chihaya-%235555ff.svg "IRC Channel" )](https://web.libera.chat/#chihaya)
2016-04-03 01:35:04 +02:00
2016-02-26 01:17:30 +01:00
Chihaya is an open source [BitTorrent tracker] written in [Go].
Differentiating features include:
2018-08-31 06:56:18 +02:00
- HTTP and UDP protocols
2016-08-17 05:51:24 +02:00
- IPv4 and IPv6 support
2021-01-20 13:06:28 +01:00
- Pre/Post middleware hooks
2016-03-05 17:09:28 +01:00
- [YAML] configuration
2016-08-17 05:51:24 +02:00
- Metrics via [Prometheus]
2018-12-12 08:26:11 +01:00
- High Availability via [Redis]
2018-08-31 06:56:18 +02:00
- Kubernetes deployment via [Helm]
2016-02-26 01:17:30 +01:00
2021-06-23 02:41:56 +02:00
**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.
2016-04-03 01:35:04 +02:00
[releases]: https://github.com/chihaya/chihaya/releases
2018-08-31 06:56:18 +02:00
[BitTorrent tracker]: https://en.wikipedia.org/wiki/BitTorrent_tracker
2016-02-26 01:17:30 +01:00
[Go]: https://golang.org
2018-08-31 06:56:18 +02:00
[YAML]: https://yaml.org
[Prometheus]: https://prometheus.io
2018-12-12 08:26:11 +01:00
[Redis]: https://redis.io
2018-08-31 06:56:18 +02:00
[Helm]: https://helm.sh
2016-02-26 01:17:30 +01:00
2016-09-18 00:39:01 +02:00
## Why Chihaya?
2016-08-20 08:27:24 +02:00
2016-09-18 00:39:01 +02:00
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.
2018-08-31 06:56:18 +02:00
The most common use case for Chihaya is enabling peer-to-peer cloud software deployments.
2016-08-20 08:27:24 +02:00
2016-04-03 01:35:04 +02:00
## Development
2016-03-30 06:38:57 +02:00
2018-08-31 06:56:18 +02:00
### 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].
[GitHub Issues]: https://github.com/chihaya/chihaya/issues
[GitHub Pull Requests]: https://github.com/chihaya/chihaya/pulls
[freenode IRC]: http://webchat.freenode.net/?channels=chihaya
[CONTRIBUTING.md]: https://github.com/chihaya/chihaya/blob/master/CONTRIBUTING.md
2016-04-03 01:35:04 +02:00
### Getting Started
2016-02-26 01:17:30 +01:00
2017-01-28 22:02:14 +01:00
#### Building from HEAD
In order to compile the project, the [latest stable version of Go] and knowledge of a [working Go environment] are required.
2016-03-05 17:09:28 +01:00
```sh
2022-01-15 19:03:41 +01:00
git clone git@github.com:chihaya/chihaya.git
cd chihaya
go build ./cmd/chihaya
./chihaya --help
2016-03-05 17:09:28 +01:00
```
2016-02-26 01:17:30 +01:00
2016-04-03 01:35:04 +02:00
[latest stable version of Go]: https://golang.org/dl
[working Go environment]: https://golang.org/doc/code.html
2017-01-28 22:02:14 +01:00
#### Docker
Docker containers are available for [HEAD] and [stable] releases.
[HEAD]: https://quay.io/jzelinskie/chihaya-git
[stable]: https://quay.io/jzelinskie/chihaya
#### Testing
The following will run all tests and benchmarks.
Removing `-bench` will just run unit tests.
```sh
2022-01-15 19:03:41 +01:00
go test -bench $(go list ./...)
2017-01-28 22:02:14 +01:00
```
2019-10-17 07:59:44 +02:00
The Chihaya executable contains a command to end-to-end test a BitTorrent tracker.
See
```sh
2022-01-15 19:03:41 +01:00
chihaya --help
```
2019-10-17 07:59:44 +02:00
### 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.
2016-02-26 01:17:30 +01:00
## Related projects
2016-08-17 05:51:24 +02:00
- [BitTorrent.org ](https://github.com/bittorrent/bittorrent.org ): a static website containing the BitTorrent spec and all BEPs
2016-02-26 01:17:30 +01:00
- [OpenTracker ](http://erdgeist.org/arts/software/opentracker ): a popular BitTorrent tracker written in C
- [Ocelot ](https://github.com/WhatCD/Ocelot ): a private BitTorrent tracker written in C++