Žiadny popis

Shengqi Chen ab8d1c2120 remove all cmd source files from coverage, make shanker happy 11 mesiacov pred
.github ab8d1c2120 remove all cmd source files from coverage, make shanker happy 11 mesiacov pred
.umlrootfs b372744640 update ci script 2 rokov pred
.vscode b2a22a9bbc update editor config 5 rokov pred
autocomplete 83fc766147 feat(bash and zsh autocompletion for tunasynctl): 9 rokov pred
cmd ef32197fef Run go fmt 11 mesiacov pred
docs bca49abd3c doc: increase default interval 2 rokov pred
internal a6a03decf0 doc: update README and bump to v0.9.0 11 mesiacov pred
manager 95c4d54ee2 Replace boltdb with bbolt, fix #173, close #174 11 mesiacov pred
systemd 28c8145137 feature(worker): limit rsync memory using cgroup 9 rokov pred
tests ef32197fef Run go fmt 11 mesiacov pred
worker 113df44f19 cgroup: upgrade to containerd/cgroup/v3 11 mesiacov pred
.gitignore 559f5705f6 ci: rename all coverage files to .gcov, ignore them in git 11 mesiacov pred
.testpackages.txt 44af0d5e62 feature(worker): framework of mirror provider 9 rokov pred
LICENSE 78f3501e19 Initial commit 11 rokov pred
Makefile 559f5705f6 ci: rename all coverage files to .gcov, ignore them in git 11 mesiacov pred
README.md a6a03decf0 doc: update README and bump to v0.9.0 11 mesiacov pred
go.mod 113df44f19 cgroup: upgrade to containerd/cgroup/v3 11 mesiacov pred
go.sum b4ca6f4c1e Run go get -u 11 mesiacov pred
package.json c311648546 chore(git): Made this repo commitizen frendly 9 rokov pred

README.md

tunasync

Build Status Coverage Status Commitizen friendly GPLv3

Get Started

Download

Pre-built binary for Linux x86_64 and ARM64 is available at Github releases.

Design

# Architecture

- Manager: Central instance for status and job management
- Worker: Runs mirror jobs

+------------+ +---+                  +---+
| Client API | |   |    Job Status    |   |    +----------+     +----------+ 
+------------+ |   +----------------->|   |--->|  mirror  +---->|  mirror  | 
+------------+ |   |                  | w |    |  config  |     | provider | 
| Worker API | | H |                  | o |    +----------+     +----+-----+ 
+------------+ | T |   Job Control    | r |                          |       
+------------+ | T +----------------->| k |       +------------+     |       
| Job/Status | | P |   Start/Stop/... | e |       | mirror job |<----+       
| Management | | S |                  | r |       +------^-----+             
+------------+ |   |   Update Status  |   |    +---------+---------+         
+------------+ |   <------------------+   |    |     Scheduler     |
|   BoltDB   | |   |                  |   |    +-------------------+
+------------+ +---+                  +---+


# Job Run Process


PreSyncing                           Syncing                               Success
+-----------+     +----------+    +-----------+    +-------------+     +--------------+
|  pre-job  +--+->| pre-exec +--->|  job run  +--->|  post-exec  +-+-->| post-success |
+-----------+  ^  +----------+    +-----------+    +-------------+ |   +--------------+
               |                                                   |
               |                +-----------------+                | Failed
               +----------------+    post-fail    |<---------------+
                                +-----------------+

Building

Go version: 1.22

# for native arch
> make all
# for other arch
> make ARCH=linux-arm64 all

Binaries are in build-$ARCH/, e.g., build-linux-amd64/.