mirror of
https://github.com/octoleo/lsyncd.git
synced 2025-01-10 02:07:13 +00:00
43 lines
1.5 KiB
Markdown
43 lines
1.5 KiB
Markdown
---
|
||
layout: default
|
||
title: "FAQ: How can I call a script before or after each rsync operation?"
|
||
---
|
||
The issue with this quite frequent request is, by itself it complicates error handling a lot. What should Lsyncd do, when the script fails that it ought to run after each rsync call? If it should recall the post script it would require a new state for each rsync event which would complicate Lsyncd code quite a bit.
|
||
|
||
The easiest way to get around this, is by replacing the rsync binary Lsyncd calls by a script from you, that calls rsync and does whatever you want to do, when rsync completes. The only thing to take care is that Lsyncd communicates with rsync using stdin/out/err-pipes and thus better not interfere with these.
|
||
|
||
Also take care the script properly forwards the exit code rsync returned.
|
||
|
||
This is an example bash script to wrap around rsync:
|
||
|
||
{% highlight shell %}
|
||
#!/bin/bash
|
||
/usr/bin/rsync "$@"
|
||
result=$?
|
||
(
|
||
if [ $result -eq 0 ]; then
|
||
echo "my commands";
|
||
fi
|
||
) >/dev/null 2>/dev/null </dev/null
|
||
|
||
exit $result
|
||
{% endhighlight %}
|
||
|
||
It does not do error handling for post commands. If you need this, you'll have to code them here fitting your requirements.
|
||
|
||
Above script can be used as rsync wrapper replacement like this:
|
||
|
||
|
||
{% highlight lua %}
|
||
sync {
|
||
default.rsync,
|
||
source = "/path/to/source",
|
||
target = "targethost::targetdir",
|
||
rsync = {
|
||
binary = "/path/to/bash/handler.sh"
|
||
}
|
||
}
|
||
{% endhighlight %}
|
||
|
||
## [‹‹ back to FAQ index](../)
|