mirror of
https://github.com/octoleo/lsyncd.git
synced 2025-01-22 14:48:29 +00:00
adding direct default configuration
This commit is contained in:
parent
7188748d64
commit
70f880384b
98
lsyncd.lua
98
lsyncd.lua
@ -2558,6 +2558,9 @@ USAGE:
|
|||||||
|
|
||||||
default rsync with mv's through ssh:
|
default rsync with mv's through ssh:
|
||||||
lsyncd [OPTIONS] -rsyncssh [SOURCE] [HOST] [TARGETDIR]
|
lsyncd [OPTIONS] -rsyncssh [SOURCE] [HOST] [TARGETDIR]
|
||||||
|
|
||||||
|
default local copying mechanisms (cp|mv|rm):
|
||||||
|
lsyncd [OPTIONS] -direct [SOURCE] [TARGETDIR]
|
||||||
|
|
||||||
OPTIONS:
|
OPTIONS:
|
||||||
-delay SECS Overrides default delay times
|
-delay SECS Overrides default delay times
|
||||||
@ -2649,6 +2652,11 @@ function runner.configure(args, monitors)
|
|||||||
clSettings.syncs = clSettings.syncs or {}
|
clSettings.syncs = clSettings.syncs or {}
|
||||||
table.insert(clSettings.syncs, {"rsyncssh", src, host, tdir})
|
table.insert(clSettings.syncs, {"rsyncssh", src, host, tdir})
|
||||||
end},
|
end},
|
||||||
|
direct =
|
||||||
|
{2, function(src, trg)
|
||||||
|
clSettings.syncs = clSettings.syncs or {}
|
||||||
|
table.insert(clSettings.syncs, {"direct", src, trg})
|
||||||
|
end},
|
||||||
version =
|
version =
|
||||||
{0, function()
|
{0, function()
|
||||||
io.stdout:write("Version: ", lsyncd_version,"\n")
|
io.stdout:write("Version: ", lsyncd_version,"\n")
|
||||||
@ -2747,6 +2755,8 @@ function runner.initialize()
|
|||||||
sync{default.rsync, source=s[2], target=s[3]}
|
sync{default.rsync, source=s[2], target=s[3]}
|
||||||
elseif s[1] == "rsyncssh" then
|
elseif s[1] == "rsyncssh" then
|
||||||
sync{default.rsyncssh, source=s[2], host=s[3], targetdir=s[4]}
|
sync{default.rsyncssh, source=s[2], host=s[3], targetdir=s[4]}
|
||||||
|
elseif s[1] == "direct" then
|
||||||
|
sync{default.direct, source=s[2], target=s[3]}
|
||||||
end
|
end
|
||||||
end
|
end
|
||||||
end
|
end
|
||||||
@ -3409,6 +3419,89 @@ local default_rsyncssh = {
|
|||||||
xargs = {delimiter = '\000', binary = "xargs", xparams = {"-0", "rm -rf"}}
|
xargs = {delimiter = '\000', binary = "xargs", xparams = {"-0", "rm -rf"}}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
-----
|
||||||
|
-- Keeps two directories with /bin/cp, /bin/rm and /bin/mv in sync.
|
||||||
|
-- Startup still uses rsync tough.
|
||||||
|
--
|
||||||
|
local default_direct = {
|
||||||
|
-----
|
||||||
|
-- Spawns rsync for a list of events
|
||||||
|
--
|
||||||
|
action = function(inlet)
|
||||||
|
-- gets all events ready for syncing
|
||||||
|
local event, event2 = inlet.getEvent()
|
||||||
|
|
||||||
|
if event.etype == "Create" or event.etpye == "Modifiy" then
|
||||||
|
spawn(event, "/bin/cp", "-r", event.sourcePath, event.targetPathdir)
|
||||||
|
elseif event.etype == "Delete" then
|
||||||
|
local tp = event.targetPath
|
||||||
|
-- extra security check
|
||||||
|
if tp == "" or tp == "/" or not tp then
|
||||||
|
error("Refusing to erase your harddisk")
|
||||||
|
end
|
||||||
|
spawn(event, "/bin/rm", "-rf", tp)
|
||||||
|
elseif event.etype == "Move" then
|
||||||
|
spawn(event, "/bin/mv", event.targetPath, event2.targetPath)
|
||||||
|
else
|
||||||
|
error("Do not know how to handle unknown event")
|
||||||
|
end
|
||||||
|
end,
|
||||||
|
|
||||||
|
-----
|
||||||
|
-- Called when collecting a finished child process
|
||||||
|
--
|
||||||
|
collect = function(agent, exitcode)
|
||||||
|
local config = agent.config
|
||||||
|
|
||||||
|
if not agent.isList and agent.etype == "Blanket" then
|
||||||
|
if exitcode == 0 then
|
||||||
|
log("Normal", "Startup of '",agent.source,"' finished.")
|
||||||
|
elseif rsync_exitcodes and
|
||||||
|
rsync_exitcodes[exitcode] == "again"
|
||||||
|
then
|
||||||
|
log("Normal",
|
||||||
|
"Retrying startup of '",agent.source,"'.")
|
||||||
|
return "again"
|
||||||
|
else
|
||||||
|
log("Error", "Failure on startup of '",agent.source,"'.")
|
||||||
|
terminate(-1) -- ERRNO
|
||||||
|
end
|
||||||
|
return
|
||||||
|
end
|
||||||
|
|
||||||
|
-- everything else just is as is,
|
||||||
|
-- there is no network to retry something.
|
||||||
|
return nil
|
||||||
|
end,
|
||||||
|
|
||||||
|
-----
|
||||||
|
-- Spawns the recursive startup sync
|
||||||
|
-- identical to default rsync.
|
||||||
|
--
|
||||||
|
init = default_rsync.init,
|
||||||
|
|
||||||
|
-----
|
||||||
|
-- Checks the configuration.
|
||||||
|
--
|
||||||
|
prepare = function(config)
|
||||||
|
if not config.target then
|
||||||
|
error("default.direct needs 'target' configured", 4)
|
||||||
|
end
|
||||||
|
end,
|
||||||
|
|
||||||
|
-----
|
||||||
|
-- Default delay is very short.
|
||||||
|
--
|
||||||
|
delay = 1,
|
||||||
|
|
||||||
|
-----
|
||||||
|
-- On many system multiple disk operations just rather slow down
|
||||||
|
-- than speed up.
|
||||||
|
|
||||||
|
maxProcesses = 1,
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
-----
|
-----
|
||||||
-- The default table for the user to accesss.
|
-- The default table for the user to accesss.
|
||||||
-- Provides all the default layer 1 functions.
|
-- Provides all the default layer 1 functions.
|
||||||
@ -3524,6 +3617,11 @@ default = {
|
|||||||
-- a default rsync configuration with ssh'd move and rm actions
|
-- a default rsync configuration with ssh'd move and rm actions
|
||||||
--
|
--
|
||||||
rsyncssh = default_rsyncssh,
|
rsyncssh = default_rsyncssh,
|
||||||
|
|
||||||
|
-----
|
||||||
|
-- a default configuration using /bin/cp|rm|mv.
|
||||||
|
--
|
||||||
|
direct = default_direct,
|
||||||
|
|
||||||
-----
|
-----
|
||||||
-- Minimum seconds between two writes of a status file.
|
-- Minimum seconds between two writes of a status file.
|
||||||
|
42
tests/churn-direct.lua
Executable file
42
tests/churn-direct.lua
Executable file
@ -0,0 +1,42 @@
|
|||||||
|
#!/usr/bin/lua
|
||||||
|
-- a heavy duty test.
|
||||||
|
-- makes thousends of random changes to the source tree
|
||||||
|
require("posix")
|
||||||
|
dofile("tests/testlib.lua")
|
||||||
|
|
||||||
|
cwriteln("****************************************************************")
|
||||||
|
cwriteln(" Testing default.direct with random data activity ")
|
||||||
|
cwriteln("****************************************************************")
|
||||||
|
|
||||||
|
local tdir, srcdir, trgdir = mktemps()
|
||||||
|
|
||||||
|
-- makes some startup data
|
||||||
|
churn(srcdir, 10)
|
||||||
|
|
||||||
|
local logs = {}
|
||||||
|
--logs = {"-log", "Delay", "-log", "Fsevents" }
|
||||||
|
local pid = spawn("./lsyncd", "-nodaemon", "-delay", "5",
|
||||||
|
"-direct", srcdir, trgdir, unpack(logs))
|
||||||
|
|
||||||
|
cwriteln("waiting for Lsyncd to startup")
|
||||||
|
posix.sleep(1)
|
||||||
|
|
||||||
|
churn(srcdir, 500)
|
||||||
|
|
||||||
|
cwriteln("waiting for Lsyncd to finish its jobs.")
|
||||||
|
posix.sleep(10)
|
||||||
|
|
||||||
|
cwriteln("killing the Lsyncd daemon")
|
||||||
|
posix.kill(pid)
|
||||||
|
local _, exitmsg, lexitcode = posix.wait(lpid)
|
||||||
|
cwriteln("Exitcode of Lsyncd = ", exitmsg, " ", lexitcode)
|
||||||
|
|
||||||
|
exitcode = os.execute("diff -r "..srcdir.." "..trgdir)
|
||||||
|
cwriteln("Exitcode of diff = '", exitcode, "'")
|
||||||
|
if exitcode ~= 0 then
|
||||||
|
os.exit(1)
|
||||||
|
else
|
||||||
|
os.exit(0)
|
||||||
|
end
|
||||||
|
|
||||||
|
|
@ -1,7 +1,6 @@
|
|||||||
#!/usr/bin/lua
|
#!/usr/bin/lua
|
||||||
-- a heavy duty test.
|
-- a heavy duty test.
|
||||||
-- makes thousends of random changes to the source tree
|
-- makes thousends of random changes to the source tree
|
||||||
-- checks every X changes if lsyncd managed to keep target tree in sync.
|
|
||||||
require("posix")
|
require("posix")
|
||||||
dofile("tests/testlib.lua")
|
dofile("tests/testlib.lua")
|
||||||
|
|
||||||
|
@ -1,7 +1,6 @@
|
|||||||
#!/usr/bin/lua
|
#!/usr/bin/lua
|
||||||
-- a heavy duty test.
|
-- a heavy duty test.
|
||||||
-- makes thousends of random changes to the source tree
|
-- makes thousends of random changes to the source tree
|
||||||
-- checks every X changes if lsyncd managed to keep target tree in sync.
|
|
||||||
require("posix")
|
require("posix")
|
||||||
dofile("tests/testlib.lua")
|
dofile("tests/testlib.lua")
|
||||||
|
|
||||||
|
Loading…
x
Reference in New Issue
Block a user