pirsyncd - Python Inotify Rsync Daemon
Published by ebal on Monday, 13 July 2009
This is the home page of pirsyncd.
pirsyncd stands for: Python Inotify Rsync Daemon.
Created by Evaggelos Balaskas <ebalaskas AT ebalaskas DOT gr>
Description:
This is an attempt of writing a daemon to watch a directory for kernel’s inotify events and then execute an rsync command to synchronize two different directories (local or remote). This is a poor man’s mirroring or an alternative (not so) real data replication mechanism and it is based on Pyinotify.
Download:
Always the latest version is here: pirsyncd
Latest version is 20110412
Current md5sum & sha1sum:
md5: e2cc45ae7c5f163cd3f4a1ce39b60c38
sha1: f8fc7ea799976fa699c0a6db7ff014c6fc9afb33
or via mercurial, pirsyncd on bitbucket
hg clone https://ebal@bitbucket.org/ebal/pirsyncd/
Features:
Some of the features of the pirsyncd:
- There is no need of installation!
- Run as a Daemon
- Can run as a Daemon in foreground
- Simple Configuration, you only have to configure your source and destination directories
- Configuration Check at the begging
- Ability to check and stop the daemon
- Syntax help with ––help
- For every parameter there is a usage examples with ––examples
- Support multiple running instances
- Mirroring to a remote (destination) server (needs password-less connection) through ssh connection
- Mirroring to a remote (destination) server (needs rsync password-file) through rsync connection
- Error handling via exceptions
- A customized delay for mirroring directories (dont rsync asap when an event is trigged)
- Gets arguments from command line - there is no need of hack the code.
- Synchronization at start (mirroring via rsync) - first run
- Definition of rsync version from command line
- Logging functionality of rsync process
- Partial rsync functionality
- Append rsync functionality
- Functionality to exclude files larger than MAX-SIZE or smaller than MIN-SIZE
- Debugging pyinotify events
- Debugging rsync command
- Autolearning new subdirectories
- Rsync & Pyinotify exclude pattern
- Resolving duplicates inode events for multiple files/events
- You can rsync every n (NUMBER) inode events (simple delay method)
- Supports python3 with pirsyncd.Py3k
- Pyinotify version 0.9.1 (20110405)
- Clean code and python code styling using pylint
- 7.58/10 (previous run: 7.50/10) with pylint !
- Lines of code (has a lot of comments !) and it is written on KISS principle
egrep -vc '#|^$|"""' pirsyncd 427
pirsyncd monitors for these inotify events:
- IN_ATTRIB
- IN_CLOSE_WRITE
- IN_CREATE
- IN_DELETE
- IN_MODIFY
- IN_MOVED_TO
- IN_MOVED_FROM
- IN_DELETE_SELF
PS: this is my very first python script, i would appreciate any comments
FAQ:
For people who can read greek, there is a FAQ about pirsyncd: FAQ – pirsyncd
Mini Presentation:
Here is a mini presentation or inotify,pyinotify and pirsyncd
You can find pirsyncd on: