Difference between revisions of "Anything-sync-daemon"

From ArchWiki
Jump to: navigation, search
Line 1: Line 1:
 
[[Category:Scripts]]
 
[[Category:Scripts]]
 
[[Category:Daemons and system services]]
 
[[Category:Daemons and system services]]
{{i18n|Anything-sync-daemon}}
 
 
 
{{Article summary start}}
 
{{Article summary start}}
 
{{Article summary text|{{AUR|Anything-sync-daemon}} (asd) is a tiny shell script designed to manage target directories in tmpfs and to periodically sync them back to your physical disc (HDD/SSD).  This is accomplished via a symlinking step and an innovative use of rsync to maintain back-up and synchronization between the two.  One of the major design goals of asd is a completely transparent user experience.}}
 
{{Article summary text|{{AUR|Anything-sync-daemon}} (asd) is a tiny shell script designed to manage target directories in tmpfs and to periodically sync them back to your physical disc (HDD/SSD).  This is accomplished via a symlinking step and an innovative use of rsync to maintain back-up and synchronization between the two.  One of the major design goals of asd is a completely transparent user experience.}}

Revision as of 16:18, 13 June 2012

Summary help replacing me
Anything-sync-daemonAUR (asd) is a tiny shell script designed to manage target directories in tmpfs and to periodically sync them back to your physical disc (HDD/SSD). This is accomplished via a symlinking step and an innovative use of rsync to maintain back-up and synchronization between the two. One of the major design goals of asd is a completely transparent user experience.
Related
Profile-sync-daemon

Benefits of Asd

Running this daemon is beneficial for two reasons:

  1. Reduced wear to physical discs
  2. Speed

Since the target directories are relocated into tmpfs, the corresponding onslaught of I/O associated with system usage of them is also redirected from the physical disc to RAM, thus reducing wear to the physical disc and also improving speed and responsiveness. The access time of RAM is on the order of nanoseconds while the access time of physical discs is on the order of milliseconds. This is a difference of six orders of magnitude or 1,000,000 times faster.

Setup and Installation

Anything-sync-daemonAUR is available for download from the AUR. Build it and install like any other package.

Edit /etc/asd.conf

Edit the included /etc/asd.conf defining the target directories in the WHATTOSYNC array. These will be syncronized and managed by asd.

Note: At least one location needs to be defined.

Example:

WHATTOSYNC=('/var/log' '/srv/http' '/home/foo/bar')

Optionally redefine the location of the tmpfs space to use. Do this in the TMPFS variable. Note that for Arch Linux, the default value of /dev/shm should work just fine. Be sure to read the warning about using software such as bleachbit with asd since bleachbit likes to remove files stored in /tmp. This is why a value of /dev/shm is better.

Using asd

The initial synchronization will occur when the daemon starts. Additionally, cron (if running) will call it to sync or update once per hour. Finally, asd will sync back a final time when it is called to stop.

Using SysVinit (Arch default)

Call the daemon to start, stop, or sync (restart) like any standard Arch daemon:

# rc.d command asd

It is highly recommended to start/stop the daemon at boot/shutdown. This is accomplished by adding asd to the DAEMONS array in /etc/rc.conf like so:

DAEMONS=(... @asd ...)

Using systemd

Users making use of Systemd may manage the service using the systemctl command. Start/stop the service using:

# systemctl start asd.service
# systemctl stop asd.service

Enable the asd daemon to start/stop at boot/shutdown (highly recommended) using:

# systemctl enable asd.service

Sync at More Frequent Intervals (Optional)

Note: This step is NOT required. asd will update once per hour on its own.

Users wishing to have syncs occur more frequently can simply add a line to the root crontab to call the sync function of asd like so:

# crontab -e

Example syncing targets once every ten minutes:

 */10 * * * *     rc.d sync asd &> /dev/null

Support

Post in the discussion thread with comments or concerns.