An open API service indexing awesome lists of open source software.

https://github.com/drunomics/syncd

Watches for file changes and rsyncs them to a remote machine.
https://github.com/drunomics/syncd

Last synced: 3 months ago
JSON representation

Watches for file changes and rsyncs them to a remote machine.

Awesome Lists containing this project

README

          

syncd
=====

Syncd is a simple bash script that watches for file changes and rsyncs them to a remote machine. It uses inotify to watch for file system changes and syncs the whole directory to a remote machine using rsync. The script makes sure to aggregate change events during a running rsync, such that after the initial sync a subsequent sync can be triggered (and so on).

Requirements
------------
Right now a linux based system with inotify-tools and rsync installed is required, .e.g for ubuntu/debian based systems run
```
apt-get install inotify-tools rsync
```

For Mac OS X support https://github.com/ggreer/fsevents-tools could be integrated instead of inotify.

Installation
------------
* Clone the script in a directory of your choice, e.g.
```
cd ~/opt
git clone git@github.com:drunomics/syncd.git
```
* Best, put syncd in your $PATH, for example by running:
```
cd syncd
sudo ln -s $PWD/syncd /usr/local/bin/syncd
```

Usage
-----
* Copy the syncd.conf file to the directory you want to sync, or in some of its parent directories and adapt it your needs.
* Run "syncd start" in any directory below of the directory holding your syncd.conf file to start the daemon script.
* By default, the script will create a .syncd.pid file for tracking the daemon process ID and a .syncd.log file to which the rsync output will be written.
* Arguments known are the ones known from initd scripts (start,stop,restart,status) as well as "run" for manually triggering a rsync and "log" for checking the rsync output.

Author
------
Wolfgang Ziegler, nuppla@zites.net, drunomics GmbH