mirror of
https://github.com/octoleo/lsyncd.git
synced 2025-01-24 07:38:28 +00:00
This commit is contained in:
parent
6afaafaf5a
commit
fc547790ea
148
lsyncd.lua
148
lsyncd.lua
@ -506,6 +506,10 @@ local Inlet, InletControl = (function()
|
|||||||
return true
|
return true
|
||||||
end
|
end
|
||||||
|
|
||||||
|
if k == "config" then
|
||||||
|
return sync.config
|
||||||
|
end
|
||||||
|
|
||||||
local f = eventListFuncs[k]
|
local f = eventListFuncs[k]
|
||||||
if not f then
|
if not f then
|
||||||
error("event list does not have function '"..k.."'", 2)
|
error("event list does not have function '"..k.."'", 2)
|
||||||
@ -853,19 +857,34 @@ local Sync = (function()
|
|||||||
end
|
end
|
||||||
InletControl.setSync(self)
|
InletControl.setSync(self)
|
||||||
local rc = self.config.collect(InletControl.d2e(delay), exitcode)
|
local rc = self.config.collect(InletControl.d2e(delay), exitcode)
|
||||||
-- TODO honor return codes of the collect?
|
if rc == "die" then
|
||||||
|
log("Error", "Critical exitcode.");
|
||||||
|
terminate(-1) --ERRNO
|
||||||
|
end
|
||||||
|
if rc ~= "again" then
|
||||||
|
-- if its active again the collecter restarted the event
|
||||||
removeDelay(self, delay)
|
removeDelay(self, delay)
|
||||||
log("Delay","Finish of ",delay.etype," on ",
|
log("Delay", "Finish of ",delay.etype," on ",
|
||||||
self.source,delay.path," = ",exitcode)
|
self.source,delay.path," = ",exitcode)
|
||||||
|
else
|
||||||
|
-- sets the delay on wait again
|
||||||
|
delay.status = "wait"
|
||||||
|
end
|
||||||
else
|
else
|
||||||
log("Delay", "collected a list")
|
log("Delay", "collected a list")
|
||||||
InletControl.setSync(self)
|
InletControl.setSync(self)
|
||||||
local rc = self.config.collect(InletControl.dl2el(delay), exitcode)
|
local rc = self.config.collect(InletControl.dl2el(delay), exitcode)
|
||||||
-- TODO honor return codes of collect?
|
if rc == "die" then
|
||||||
|
log("Error", "Critical exitcode.");
|
||||||
|
terminate(-1) --ERRNO
|
||||||
|
end
|
||||||
for k, d in pairs(delay) do
|
for k, d in pairs(delay) do
|
||||||
if type(k) == "number" then
|
if type(k) == "number" then
|
||||||
|
if rc ~= "again" then
|
||||||
removeDelay(self, d)
|
removeDelay(self, d)
|
||||||
|
else
|
||||||
|
d.status = "wait"
|
||||||
|
end
|
||||||
end
|
end
|
||||||
end
|
end
|
||||||
log("Delay","Finished list = ",exitcode)
|
log("Delay","Finished list = ",exitcode)
|
||||||
@ -2158,6 +2177,37 @@ end
|
|||||||
-- lsyncd default settings
|
-- lsyncd default settings
|
||||||
--============================================================================
|
--============================================================================
|
||||||
|
|
||||||
|
|
||||||
|
-----
|
||||||
|
-- Exitcodes to retry on network failures of rsync.
|
||||||
|
--
|
||||||
|
local rsync_exitcodes = {
|
||||||
|
[ 1] = "die",
|
||||||
|
[ 2] = "die",
|
||||||
|
[ 3] = "again",
|
||||||
|
[ 4] = "die",
|
||||||
|
[ 5] = "again",
|
||||||
|
[ 6] = "again",
|
||||||
|
[ 10] = "again",
|
||||||
|
[ 11] = "again",
|
||||||
|
[ 12] = "again",
|
||||||
|
[ 14] = "again",
|
||||||
|
[ 20] = "again",
|
||||||
|
[ 21] = "again",
|
||||||
|
[ 22] = "again",
|
||||||
|
[ 25] = "die",
|
||||||
|
[ 30] = "again",
|
||||||
|
[ 35] = "again",
|
||||||
|
[255] = "again",
|
||||||
|
}
|
||||||
|
|
||||||
|
-----
|
||||||
|
-- Exitcodes to retry on network failures of rsync.
|
||||||
|
--
|
||||||
|
local rsync_ssh = {
|
||||||
|
[255] = "again",
|
||||||
|
}
|
||||||
|
|
||||||
-----
|
-----
|
||||||
-- lsyncd classic - sync with rsync
|
-- lsyncd classic - sync with rsync
|
||||||
--
|
--
|
||||||
@ -2198,10 +2248,15 @@ local default_rsync = {
|
|||||||
end,
|
end,
|
||||||
|
|
||||||
-----
|
-----
|
||||||
-- Calls rsync with this options
|
-- Calls rsync with this options.
|
||||||
--
|
--
|
||||||
rsyncOps = "-lts",
|
rsyncOps = "-lts",
|
||||||
|
|
||||||
|
-----
|
||||||
|
-- exit codes for rsync.
|
||||||
|
--
|
||||||
|
exitcodes = rsync_exitcodes,
|
||||||
|
|
||||||
-----
|
-----
|
||||||
-- Default delay 3 seconds
|
-- Default delay 3 seconds
|
||||||
--
|
--
|
||||||
@ -2244,6 +2299,49 @@ local default_rssh = {
|
|||||||
config.host .. ":" .. config.targetdir)
|
config.host .. ":" .. config.targetdir)
|
||||||
end,
|
end,
|
||||||
|
|
||||||
|
-----
|
||||||
|
-- Called when collecting a finished child process
|
||||||
|
--
|
||||||
|
collect = function(agent, exitcode)
|
||||||
|
if agent.etype == "Blanket" then
|
||||||
|
if exitcode == 0 then
|
||||||
|
log("Normal", "Startup of '",agent.source,"' finished.")
|
||||||
|
elseif rsync_exitcodes[exitcode] == "again" then
|
||||||
|
log("Normal",
|
||||||
|
"Retring startup of '",agent.source,"' finished.")
|
||||||
|
return "again"
|
||||||
|
else
|
||||||
|
log("Error", "Failure on startup of '",agent.source,"'.")
|
||||||
|
terminate(-1) -- ERRNO
|
||||||
|
end
|
||||||
|
end
|
||||||
|
|
||||||
|
if agent.isList then
|
||||||
|
local rc = rsync_exitcodes[exitcode]
|
||||||
|
if rc == "die" then
|
||||||
|
return rc
|
||||||
|
end
|
||||||
|
if rc == "again" then
|
||||||
|
log("Normal", "Retrying a list on exitcode = ",exitcode)
|
||||||
|
else
|
||||||
|
log("Normal", "Finished a list = ",exitcode)
|
||||||
|
end
|
||||||
|
return rc
|
||||||
|
else
|
||||||
|
local rc = ssh_exitcodes[exitcode]
|
||||||
|
if rc == "die" then
|
||||||
|
return rc
|
||||||
|
end
|
||||||
|
if rc == "again" then
|
||||||
|
log("Normal", "Retrying ",agent.etype,
|
||||||
|
" on ",agent.sourcePath," = ",exitcode)
|
||||||
|
else
|
||||||
|
log("Normal", "Finished ",agent.etype,
|
||||||
|
" on ",agent.sourcePath," = ",exitcode)
|
||||||
|
end
|
||||||
|
end
|
||||||
|
end,
|
||||||
|
|
||||||
-----
|
-----
|
||||||
-- Spawns the recursive startup sync
|
-- Spawns the recursive startup sync
|
||||||
--
|
--
|
||||||
@ -2279,7 +2377,9 @@ local default_rssh = {
|
|||||||
}
|
}
|
||||||
|
|
||||||
-----
|
-----
|
||||||
-- The default table for the user to access
|
-- The default table for the user to accesss.
|
||||||
|
-- Provides all the default layer 1 functions.
|
||||||
|
--
|
||||||
-- TODO make readonly
|
-- TODO make readonly
|
||||||
--
|
--
|
||||||
default = {
|
default = {
|
||||||
@ -2316,10 +2416,6 @@ default = {
|
|||||||
-- 3 ... events block.
|
-- 3 ... events block.
|
||||||
--
|
--
|
||||||
collapse = function(event1, event2, config)
|
collapse = function(event1, event2, config)
|
||||||
print(event1.path, event2.path)
|
|
||||||
print(event1.etype, event1.move)
|
|
||||||
print(event2.etype, event2.move)
|
|
||||||
|
|
||||||
if event1.path == event2.path then
|
if event1.path == event2.path then
|
||||||
local e1 = event1.etype .. event1.move
|
local e1 = event1.etype .. event1.move
|
||||||
local e2 = event2.etype .. event2.move
|
local e2 = event2.etype .. event2.move
|
||||||
@ -2356,7 +2452,7 @@ print(event2.etype, event2.move)
|
|||||||
Create = {Attrib=1, Modify=1, Create=1, Delete=0, MoveFr=3, MoveTo= 2},
|
Create = {Attrib=1, Modify=1, Create=1, Delete=0, MoveFr=3, MoveTo= 2},
|
||||||
Delete = {Attrib=1, Modify=1, Create=3, Delete=1, MoveFr=3, MoveTo= 2},
|
Delete = {Attrib=1, Modify=1, Create=3, Delete=1, MoveFr=3, MoveTo= 2},
|
||||||
MoveFr = {Attrib=3, Modify=3, Create=3, Delete=3, MoveFr=3, MoveTo= 3},
|
MoveFr = {Attrib=3, Modify=3, Create=3, Delete=3, MoveFr=3, MoveTo= 3},
|
||||||
-- MoveTo = {Attrib=3, Modify=3, Create=2, Delete=2, MoveFr=9, MoveTo= 2}, TODO 9
|
-- TODO MoveFr=9
|
||||||
MoveTo = {Attrib=3, Modify=3, Create=2, Delete=2, MoveFr=3, MoveTo= 2},
|
MoveTo = {Attrib=3, Modify=3, Create=2, Delete=2, MoveFr=3, MoveTo= 2},
|
||||||
},
|
},
|
||||||
|
|
||||||
@ -2364,21 +2460,45 @@ print(event2.etype, event2.move)
|
|||||||
-- Called when collecting a finished child process
|
-- Called when collecting a finished child process
|
||||||
--
|
--
|
||||||
collect = function(agent, exitcode)
|
collect = function(agent, exitcode)
|
||||||
if agent.isList then
|
local config = agent.config
|
||||||
log("Normal", "Finished a list = ",exitcode)
|
|
||||||
else
|
|
||||||
if agent.etype == "Blanket" then
|
if agent.etype == "Blanket" then
|
||||||
if exitcode == 0 then
|
if exitcode == 0 then
|
||||||
log("Normal", "Startup of '",agent.source,"' finished.")
|
log("Normal", "Startup of '",agent.source,"' finished.")
|
||||||
|
elseif config.exitcodes and
|
||||||
|
config.exitcodes[exitcode] == "again"
|
||||||
|
then
|
||||||
|
log("Normal",
|
||||||
|
"Retring startup of '",agent.source,"' finished.")
|
||||||
|
return "again"
|
||||||
else
|
else
|
||||||
log("Error", "Failure on startup of '",agent.source,"'.")
|
log("Error", "Failure on startup of '",agent.source,"'.")
|
||||||
terminate(-1) -- ERRNO
|
terminate(-1) -- ERRNO
|
||||||
end
|
end
|
||||||
return
|
return
|
||||||
end
|
end
|
||||||
|
|
||||||
|
local rc = config.exitcodes and config.exitcodes[exitcode]
|
||||||
|
if rc == "die" then
|
||||||
|
return rc
|
||||||
|
end
|
||||||
|
|
||||||
|
if agent.isList then
|
||||||
|
if rc == "again" then
|
||||||
|
log("Normal", "Retrying a list on exitcode = ",exitcode)
|
||||||
|
else
|
||||||
|
log("Normal", "Finished a list = ",exitcode)
|
||||||
|
end
|
||||||
|
else
|
||||||
|
if rc == "again" then
|
||||||
|
log("Normal", "Retrying ",agent.etype,
|
||||||
|
" on ",agent.sourcePath," = ",exitcode)
|
||||||
|
else
|
||||||
log("Normal", "Finished ",agent.etype,
|
log("Normal", "Finished ",agent.etype,
|
||||||
" on ",agent.sourcePath," = ",exitcode)
|
" on ",agent.sourcePath," = ",exitcode)
|
||||||
end
|
end
|
||||||
|
end
|
||||||
|
return rc
|
||||||
end,
|
end,
|
||||||
|
|
||||||
-----
|
-----
|
||||||
|
Loading…
x
Reference in New Issue
Block a user