我正在尝试了解inotifywait。我安装了inotify-tools:
Start-Date: 2019-08-31 18:11:48
Commandline: apt install inotify-tools
Requested-By: dkb (1000)
Install: inotify-tools:amd64 (3.14-7), libinotifytools0:amd64 (3.14-7, automatic)
End-Date: 2019-08-31 18:11:58
我制作了这个脚本jl.sh ,将~/Desktop/vvtemp中的任何修改文件复制到~/Public并为复制的文件添加时间戳:
#!/bin/bash
dir_to_watch="/home/dkb/Desktop/vvtemp/"
inotifywait -m -e modify --format '%w%f' "${dir_to_watch}" | while read line
do
s=$line
newname=/home/dkb/Public/$(date +%Y%m%d%H%M%S)"-${s##*/}"
cp $line $newname
done
我创建了一个名为test.txt的文件并在一个终端中启动了脚本。没有错误或警告。
在另一个终端中,我用nano打开test.txt,对其进行编辑,保存并关闭它一次。
然后我使用gedit和geany编辑了同一个文件
我查看了目标文件夹~/Public中的文件列表:
dkb@Udin:~/Public$ ll
total 36
drwxr-xr-x 2 dkb dkb 4096 Aug 31 18:27 ./
drwxr-xr-x 17 dkb dkb 4096 Aug 31 18:08 ../
-rw-r--r-- 1 dkb dkb 1024 Aug 31 18:24 20190831182416-.test.txt.swp
-rw-r--r-- 1 dkb dkb 1024 Aug 31 18:24 20190831182419-.test.txt.swp
-rw-r--r-- 1 dkb dkb 159 Aug 31 18:24 20190831182441-test.txt
-rw-r--r-- 1 dkb dkb 179 Aug 31 18:26 20190831182619-.goutputstream-QN1A7Z
-rw-r--r-- 1 dkb dkb 198 Aug 31 18:26 20190831182638-.goutputstream-UDEB7Z
-rw-r--r-- 1 dkb dkb 210 Aug 31 18:27 20190831182722-.goutputstream-0X2K7Z
-rw-r--r-- 1 dkb dkb 221 Aug 31 18:27 20190831182733-.goutputstream-01D86Z
dkb@Udin:~/Public$
前三个文件与使用nano编辑和保存test.txt有关。前两个文件有一个.swp后缀。第三个文件是具有预期时间戳文件名的预期文件。
然后我尝试使用gedit或geany编辑同一个文件。这些编辑器创建了备份文件,每次我修改和保存文件时都会创建一个,但生成的备份虽然具有预期的内容,但文件名类似于20190831182733-.goutputstream-01D86Z。因此,似乎时间戳得到了尊重,但“基本名称”却没有。
我的问题是:
为什么我使用nano时inotifywait创建了两个.swp文件?
为什么我使用gedit或geany时没有生成预期的名称?
在 /etc/nanorc 或 ~/.nanorc 或 $XDG_CONFIG_HOME/nano/nanorc 或 ~/.config/nano/nanorc 中注释“设置锁定”
如果你调试 inotify 你可以看到 gedit 没有修改测试:
但两者都使用事件“close_write”,或者您可以按照 inotify 事件并在备份位置重新创建步骤。