78 lines
2.9 KiB
Markdown
78 lines
2.9 KiB
Markdown
# magneticod
|
|
*Autonomous BitTorrent DHT crawler and metadata fetcher.*
|
|
|
|
**magneticod** is the daemon that crawls the BitTorrent DHT network in the background to discover info hashes and
|
|
fetches metadata from the peers.
|
|
|
|
## Installation
|
|
|
|
### Requirements
|
|
- Decent Internet access (IPv4)
|
|
|
|
**magneticod** uses UDP protocol to communicate with the nodes in the DHT network, and TCP to communicate with the
|
|
peers while fetching metadata. **Please make sure you have a healthy connection;** you can confirm this by checking at
|
|
the *connection status indicator* of your BitTorrent client: if it does not indicate any error (*e.g.* a misconfigured NAT),
|
|
**magneticod** should just work fine.
|
|
|
|
### Installing the Pre-Compiled Static Binary
|
|
You can find the latest pre-compiled static binaries on [GitHub](https://github.com/boramalper/magnetico/releases)
|
|
for versions from v0.7.0 onwards.
|
|
|
|
### Installing the Docker Image
|
|
Docker images are provided on [Docker Hub](https://hub.docker.com/r/boramalper/magnetico/tags/) at
|
|
the repository `boramalper/magnetico`. Images are tagged as `magneticod-vMAJOR.MINOR.PATCH`.
|
|
|
|
## Setup
|
|
1. (Optional, **requires root**) Disable iptables for a specified port:
|
|
|
|
```bash
|
|
iptables -I OUTPUT -t raw -p udp --sport PORT_NUMBER -j NOTRACK
|
|
iptables -I PREROUTING -t raw -p udp --dport PORT_NUMBER -j NOTRACK
|
|
```
|
|
|
|
This is to prevent excessive number of ``EPERM`` "Operation not permitted" errors, which also has a negative impact
|
|
on the performance.
|
|
|
|
### Configuration
|
|
Configuration file can be found at:
|
|
|
|
- **On Linux**
|
|
|
|
~/.config/magneticod/configuration.toml
|
|
|
|
|
|
## Usage
|
|
### Database
|
|
**magneticod** is designed to be able to use different database engines to store its data, but
|
|
currently only SQLite 3 is supported. The database file can be found in:
|
|
|
|
- **On Linux**
|
|
|
|
~/.local/share/magneticod/
|
|
|
|
**magneticod** uses write-ahead logging (WAL) for its database, so there might be multiple
|
|
files while it is operating, but ``database.sqlite3`` is *the database*.
|
|
|
|
### Using the Docker Image
|
|
You need to mount
|
|
|
|
- the data directory (`~/.local/share/magneticod/` on Linux, see the previous sections)
|
|
- the configuration file at (`~/.config/magneticod/configuration.toml` on Linux, see the previous sections)
|
|
|
|
hence run:
|
|
|
|
```bash
|
|
docker run \
|
|
-v ~/.local/share/magneticod:/root/.local/share/magneticod/ \
|
|
-v ~/.config/magneticod/configuration.toml:/root/.config/magneticod/configuration.toml \
|
|
magneticod
|
|
```
|
|
|
|
__Tip:__ Containers that you terminate won't be removed; run
|
|
`docker rm $(docker ps -q -f status=exited)` to remove exited containers.
|
|
|
|
### Remark About the Network Usage
|
|
**magneticod** does *not* have any built-in rate limiter *yet*, and it will literally suck the hell out of your
|
|
bandwidth. Unless you are running **magneticod** on a separate machine dedicated for it, you might want to consider
|
|
starting it manually only when network load is low (e.g. when you are at work or sleeping at night).
|