上次讲了onCreate、 OnDelete等钩子或者事自定义。今天来讲一下,如果想要知道什么时候同步完毕,或者同步完毕时候进行日志记录,那么怎么办呢?
data:image/s3,"s3://crabby-images/55be4/55be43c50c510e417a2272462314937b371472ef" alt=""
研究一番发现collect函数是在同步结束后调用的,我们可以重新collect来进行同步完毕后的日志记录
data:image/s3,"s3://crabby-images/f9df4/f9df498aec6fa0685eae552cb15bba140445ab1e" alt=""
来验证一下echoCollect在什么时间调用,以及会不会在sleep 10秒输出xxxxxx之后调用并输出日志
data:image/s3,"s3://crabby-images/4eaaa/4eaaa7704c8817de6057fd52056c122796af39a0" alt=""
data:image/s3,"s3://crabby-images/d7c1e/d7c1efd6f0f57ef8215b0c996913b5ad7f43bde3" alt=""
启动,并在监控目录创建一个文件,看日志输出
1.onStartup同步执行完毕后,会触发一次collect函数调用, 触发事件类型为Init
2.onCreate同步成功之后,触发了collect函数调用,触发事件类型为Create
从第二个输出我们可以看到,collect并不是在onCreate或者onStartup函数执行完毕后调用的,而是在相对于的同步事件执行数据同步成功之后才去调用。比如,onCreate,直到sleep 10秒,输出xxxxxxx之后才输出了同步成功日志。
在echoCollect中,我们使用了agent.etype,agent指的是当前同步操作的事件,etype是事件类型,是事件内置的属性之一,事件还内置了很多属性。
data:image/s3,"s3://crabby-images/55be4/55be43c50c510e417a2272462314937b371472ef" alt=""
研究一番发现collect函数是在同步结束后调用的,我们可以重新collect来进行同步完毕后的日志记录
data:image/s3,"s3://crabby-images/f9df4/f9df498aec6fa0685eae552cb15bba140445ab1e" alt=""
来验证一下echoCollect在什么时间调用,以及会不会在sleep 10秒输出xxxxxx之后调用并输出日志
data:image/s3,"s3://crabby-images/4eaaa/4eaaa7704c8817de6057fd52056c122796af39a0" alt=""
data:image/s3,"s3://crabby-images/d7c1e/d7c1efd6f0f57ef8215b0c996913b5ad7f43bde3" alt=""
启动,并在监控目录创建一个文件,看日志输出
1.onStartup同步执行完毕后,会触发一次collect函数调用, 触发事件类型为Init
2.onCreate同步成功之后,触发了collect函数调用,触发事件类型为Create
从第二个输出我们可以看到,collect并不是在onCreate或者onStartup函数执行完毕后调用的,而是在相对于的同步事件执行数据同步成功之后才去调用。比如,onCreate,直到sleep 10秒,输出xxxxxxx之后才输出了同步成功日志。
在echoCollect中,我们使用了agent.etype,agent指的是当前同步操作的事件,etype是事件类型,是事件内置的属性之一,事件还内置了很多属性。