11

所以在亚历克斯回答之后,这是我的步骤:

创建外壳代码

root@ip[/]# touch mylog.sh
root@ip[/]# nano mylog.sh

复制 mylog.sh 中的代码

#!/bin/bash
echo "File $1 created." >> /mylog.log

允许

root@ip[/]# chmod +x mylog.sh

创建日志文件

root@ip[/]# touch mylog.log 

打开铁桌

incrontab -e

输入新命令

/test/ IN_CREATE mylog.sh $@$#

重新加载 incron - 创建一个新文件 - 检查日志文件

root@ip[/]# incrontab --reload
requesting table reload for user 'root'...
request done

root@ip[/]# cd test
root@ip[/test]# touch newfile.txt

root@ip[/test]# cd /
root@ip[/]# nano mylog.log

但仍然是空的日志文件......我错过了什么吗?


最后用完整路径调用shell脚本就可以了:

/test/ IN_CREATE /mylog.sh $@$#
4

1 回答 1

2

您通常可以在/var/log/messages中找到 incron 日志

如果要将事件记录到特定文件,可以使用:

/test/ IN_CREATE mylog.sh $@$#

其中 mylog.sh 是一个处理日志记录的 shell 脚本。

#!/bin/bash
echo "File $1 created." >> /home/myuser/filescreated.log

不要忘记通过 chmod +x mylog.sh 授予此 shell 脚本的执行权限

说明:一旦您开始为您正在调用的命令使用参数,您就必须将其全部放入一个 shell 脚本中。由于 incron 不会将参数传递给您的命令,而是将其解释为自身的参数。

更改 incrontab 后不要忘记调用 incrontab --reload。

另一个例子

incrontab -e

/text/ IN_CREATE /home/myuser/mylog.sh $@ $#

我的日志文件

#!/bin/bash
echo "$(date) File $2 in $1 created." >> /home/myuser/log.txt
于 2016-02-03T10:51:28.790 回答