chihaya

command module
v0.0.0-...-461761a Latest Latest
Warning

This package is not in the latest version of its module.

Go to latest
Published: Aug 3, 2013 License: BSD-2-Clause Imports: 8 Imported by: 0

README

#chihaya Build Status

chihaya is a high-performance BitTorrent tracker written in the Go programming language. It isn't quite ready for prime-time just yet, but these are the features that it targets:

  • Requests are multiplexed over all available threads (1 goroutine per request)
  • Low processing and memory footprint
  • IPv6 support
  • Generic storage interface that can be easily adapted to use any data store
  • Scaling properties that directly correlate with the chosen data store's scaling properties

##installing

$ go install github.com/pushrax/chihaya

##configuring

Configuration is done in a JSON formatted file specified with the -config flag. An example configuration can be seen in the exampleConfig variable of config/config_test.go.

##out of the box drivers

Chihaya currently supports the following drivers out of the box:

##implementing custom storage

The storage package is heavily inspired by the standard library's database/sql package. To write a new storage backend, create a new Go package that has an implementation of the DS, Tx, and Driver interfaces. Within that package, you must also define an func init() that calls storage.Register("driverName", &myDriver{}). Please read the documentation and understand these interfaces as there are assumptions about thread-safety. After you've implemented a new driver, all you have to do is remember to add import _ path/to/your/library to the top of any file (preferably main.go) and the side effects from func init() will globally register your driver so that config files will recognize your driver by name. If you're writing a driver for a popular data store, consider contributing it.

##contributing

If you're interested in contributing, please contact us in #chihaya on freenode(webchat) or post to the issue tracker. Please don't offer massive pull requests with no prior communication attempts as it will most likely lead to confusion and time wasted for everyone. However, small unannounced fixes are welcome.

And remember: good gophers always use gofmt!

Documentation

The Go Gopher

There is no documentation for this package.

Directories

Path Synopsis
Package config implements the configuration for a BitTorrent tracker
Package config implements the configuration for a BitTorrent tracker
Package server implements a BitTorrent tracker
Package server implements a BitTorrent tracker
Package storage provides a generic interface for manipulating a BitTorrent tracker's data store.
Package storage provides a generic interface for manipulating a BitTorrent tracker's data store.
redis
Package redis implements the storage interface for a BitTorrent tracker.
Package redis implements the storage interface for a BitTorrent tracker.

Jump to

Keyboard shortcuts

? : This menu
/ : Search site
f or F : Jump to
y or Y : Canonical URL