2
0
mirror of https://github.com/deajan/osync synced 2024-11-17 09:25:42 +00:00
osync/README.md

160 lines
8.6 KiB
Markdown
Raw Normal View History

2016-08-30 12:06:56 +00:00
# osync [![Build Status](https://travis-ci.org/deajan/osync.svg?branch=master)](https://travis-ci.org/deajan/osync) [![GitHub Release](https://img.shields.io/github/release/deajan/osync.svg?label=Latest)](https://github.com/deajan/osync/releases/latest)
2013-06-18 10:56:16 +00:00
A two way filesync script with fault tolerance, resume, soft deletion, conflictual file backups running on bash (linux, BSD and virtually any system supporting bash).
File synchronization is bidirectional, based on rsync, can be run manually, as scheduled task, or triggered on file changes.
2013-06-18 11:02:41 +00:00
## About
2015-07-02 17:19:27 +00:00
Osync provides the following capabilities
2013-07-24 19:13:15 +00:00
2013-11-02 20:57:15 +00:00
- Fault tolerance with resume scenarios
- Email alerts
2013-07-24 19:13:15 +00:00
- Logging facility
- Soft deletition and multiple backups handling
- Before / after command execution
- Time control
2014-01-19 19:31:14 +00:00
- Directory monitoring
- Running on schedule or as daemon
- Batch runner for multiple sync tasks with rerun option for failed sync tasks
2016-07-27 08:49:11 +00:00
- ACL synchronization
2013-07-24 19:03:58 +00:00
2016-08-22 08:27:08 +00:00
osync is a state synchronizer. This means that it doesn't have to monitor files for changes. Instead, it compares replica lists between runs.
A full run takes about 2 seconds on a local-local replication and about 10 seconds on a local-remote replication.
Disabling some features file like attributes preservation and disk space checks may speed up execution.
2016-07-27 08:49:11 +00:00
osync uses a initiator / target sync schema. It can sync local to local or local to remote directories. By definition, initiator replica is always a local directory on the system osync runs on.
osync uses pidlocks to prevent multiple concurrent sync processes on/to the same initiator / target replica.
You may launch concurrent sync processes on the same system but only for different initiator replicas.
osync tasks may be launched sequentially by osync osync-batch tool.
2013-06-18 11:02:41 +00:00
2016-07-27 08:49:11 +00:00
Currently, it has been tested on CentOS 5.x, 6.x, 7.x, Debian 6, Debian 7, Linux Mint 14-17, Ubuntu 12.04, 12.10, FreeBSD 8.3, 10.1, 10.3, Mac OS X and pfSense.
Microsoft Windows is supported via MSYS or Cygwin.
2013-06-18 11:02:41 +00:00
## Installation
Osync has been designed to not delete any data, but rather make backups of conflictual files or soft deletes.
Nevertheless, you should always have a neat backup of your data before trying a new sync tool.
2013-07-24 19:03:58 +00:00
2016-08-30 09:59:25 +00:00
You can download the latest stable release of osync at https://github.com/deajan/osync/archive/v1.1.2.tar.gz
2015-09-08 14:10:09 +00:00
You may also get the last development version at https://github.com/deajan/osync with the following command
2014-05-27 11:00:52 +00:00
2016-08-09 13:41:27 +00:00
$ git clone -b "v1.1-maint" https://github.com/deajan/osync
2015-07-02 17:19:27 +00:00
$ sh install.sh
2013-07-24 19:13:15 +00:00
2015-07-02 17:19:27 +00:00
Osync will install itself to /usr/local/bin and an example configuration file will be installed to /etc/osync
2013-07-24 19:03:58 +00:00
2014-05-21 17:12:19 +00:00
Osync needs to run with bash shell. Using any other shell will most probably result in errors.
2014-05-27 11:00:52 +00:00
If bash is not your default shell, you may invoke it using
2014-01-19 19:31:14 +00:00
$ bash osync.sh [options]
2013-07-24 19:03:58 +00:00
2015-07-19 11:37:18 +00:00
On *BSD, be sure to have bash installed.
On MSYS, On top of your basic install, you need msys-rsync and msys-coreutils-ext packages.
## Upgrade from v1.0x
Since osync v1.1 the config file format has changed in semantics and adds new config options.
Also, master is now called initiator and slave is now called target.
2016-08-30 09:59:25 +00:00
You can upgrade all v1.0x-v1.2-dev config files by running the upgrade script
2016-08-30 09:59:25 +00:00
$ ./upgrade-v1.0x-v1.2x.sh /etc/osync/your-config-file.conf
2016-07-27 08:49:11 +00:00
The script will backup your config file, update it's content and try to connect to initiator and target replicas to update the state dir.
2013-07-24 19:03:58 +00:00
## Usage
2014-05-27 11:00:52 +00:00
Osync can work with in three flavors: Quick sync mode, configuration file mode, and daemon mode.
While quick sync mode is convenient to do fast syncs between some directories, a configuration file gives much more functionnality.
Please use double quotes as path delimiters. Do not use escaped characters in path names.
2013-11-03 19:29:17 +00:00
2014-05-27 11:00:52 +00:00
QuickSync example
-----------------
2016-07-27 08:49:11 +00:00
# osync.sh --initiator="/path/to/dir1" --target="/path/to/remote dir2"
# osync.sh --initiator="/path/to/another dir" --target="ssh://user@host.com:22//path/to/dir2" --rsakey=/home/user/.ssh/id_rsa_private_key_example.com
2013-11-03 19:29:17 +00:00
2016-08-30 10:55:04 +00:00
QuickSync with minimal options
------------------------------
In order to run osync the quickest (without transferring file attributes, without softdeletion, without prior space checks and without remote connectivity checks, you may use the following:
2016-09-05 20:28:50 +00:00
# MINIMUM_SPACE=0 PRESERVE_PERMISSIONS=no PRESERVE_OWNER=no PRESERVE_GROUP=no PRESERVE_EXECUTABILITY=no SOFT_DELETE_DAYS=0 CONFLICT_BACKUP_DAYS=0 REMOTE_HOST_PING=no osync.sh --initiator="/path/to/another dir" --target="ssh://user@host.com:22//path/to/dir2" --rsakey=/home/user/.ssh/id_rsa_private_key_example.com
2016-08-30 10:55:04 +00:00
All the settings described here may also be configured in the conf file.
Running osync with a Configuration file
---------------------------------------
2013-11-03 19:29:17 +00:00
You'll have to customize the sync.conf file according to your needs.
2014-05-21 17:12:19 +00:00
If you intend to sync a remote directory, osync will need a pair of private / public RSA keys to perform remote SSH connections.
2013-11-03 19:29:17 +00:00
Also, running sync as superuser requires to configure /etc/sudoers file.
2014-05-21 17:12:19 +00:00
Please read the documentation about remote sync setups.
2013-11-02 20:57:15 +00:00
Once you've customized a sync.conf file, you may run osync with the following test run:
2013-07-24 19:03:58 +00:00
2015-07-02 17:19:27 +00:00
# osync.sh /path/to/your.conf --dry
2013-07-24 19:03:58 +00:00
If everything went well, you may run the actual configuration with one of the following:
2015-07-02 17:19:27 +00:00
# osync.sh /path/to/your.conf
# osync.sh /path/to/your.conf --verbose
# osync.sh /path/to/your.conf --no-maxtime
2013-07-24 19:03:58 +00:00
Verbose option will display which files and attrs are actually synchronized and which files are to be soft deleted / are in conflict.
2014-11-29 14:07:09 +00:00
You may mix "--silent" and "--verbose" parameters to output verbose input only in the log files.
No-Maxtime option will disable execution time checks, which is usefull for big initial sync tasks that might take long time. Next runs should then only propagate changes and take much less time.
2015-07-02 17:19:27 +00:00
Once you're confident about your fist runs, you may add osync as cron task like the following in /etc/crontab which would run osync every 30 minutes:
2013-07-24 19:03:58 +00:00
2015-07-02 17:19:27 +00:00
*/30 * * * * root /usr/local/bin/osync.sh /etc/osync/my_sync.conf --silent
2013-07-24 19:03:58 +00:00
2014-11-26 10:28:35 +00:00
Batch mode
----------
You may want to sequentially run multiple sync sets between the same servers. In that case, osync-batch.sh is a nice tool that will run every osync conf file, and, if a task fails,
run it again if there's still some time left.
The following example will run all .conf files found in /etc/osync, and retry 3 times every configuration that fails, if the whole sequential run took less than 2 hours.
2015-07-02 17:19:27 +00:00
# osync-batch.sh --path=/etc/osync --max-retries=3 --max-exec-time=7200
2014-11-26 10:28:35 +00:00
Having multiple conf files can then be run in a single cron command like
00 00 * * * root /usr/local/bin/osync-batch.sh --path=/etc/osync --silent
2014-05-27 11:00:52 +00:00
Daemon mode
-----------
2016-07-27 08:49:11 +00:00
Additionnaly, you may run osync in monitor mode, which means it will perform a sync upon file operations on initiator replica.
This can be a drawback on functionnality versus scheduled mode because this mode only launches a sync task if there are file modifications on the initiator replica, without being able to monitor the target replica.
Target replica changes are only synced when initiator replica changes occur, or when a given amount of time (default 600 seconds) passed without any changes on initiator replica.
2014-05-21 17:12:19 +00:00
File monitor mode can also be launched as a daemon with an init script. Please read the documentation for more info.
2013-11-25 12:24:55 +00:00
Note that monitoring changes requires inotifywait command (inotify-tools package for most Linux distributions).
2014-05-27 11:00:52 +00:00
BSD, MacOS X and Windows are not yet supported for this operation mode, unless you find a inotify-tools package on these OSes.
2013-11-18 21:44:20 +00:00
2015-07-02 17:19:27 +00:00
# osync.sh /etc/osync/my_sync.conf --on-changes
2014-05-21 17:12:19 +00:00
Osync file monitor mode may be run as system service with the osync-srv init script. Any configuration file found in /etc/osync will then create a osync daemon instance.
2014-05-27 11:00:52 +00:00
You may run the install.sh script which should work in most cases or copy the files by hand (osync.sh to /usr/bin/local, osync-srv to /etc/init.d, sync.conf to /etc/osync).
2013-11-18 21:44:20 +00:00
2014-05-21 17:12:19 +00:00
$ service osync-srv start
2015-07-02 17:19:27 +00:00
$ chkconfig osync-srv on
2014-05-21 17:12:19 +00:00
Systemd specific (one service per config file)
$ systemctl start osync-srv@configfile.conf
$ systemctl enable osync-srv@configfile.conf
2016-08-02 09:11:19 +00:00
Contributions
-------------
2016-08-30 09:59:25 +00:00
Bug fixes and ideas are welcome. When submitting a PR, please be sure to modify files in dev directory (dev/n_osync.sh & dev/ofunctions.sh) instead of osync.sh which are autogenerated.
2016-08-02 09:11:19 +00:00
Consider reading CODING_STYLE.TXT before submitting a patch.
2014-05-27 11:00:52 +00:00
Troubleshooting
---------------
2016-07-27 08:49:11 +00:00
You may find osync's logs in /var/log/osync.*.log (or current directory if /var/log is not writable).
2014-05-27 11:00:52 +00:00
Additionnaly, you can use the --verbose flag see to what actions are going on.
2013-06-18 11:02:41 +00:00
## Author
2013-07-24 19:03:58 +00:00
Feel free to mail me for limited support in my free time :)
2016-07-27 08:49:11 +00:00
Orsiris de Jong | ozy@netpower.fr