免费注册 查看新帖 |

Chinaunix

  平台 论坛 博客 文库
最近访问板块 发新帖
查看: 3343 | 回复: 2
打印 上一主题 下一主题

[文本处理] 灵异,inotifywait 不能继续监视被vim修改过的文件 [复制链接]

论坛徽章:
12
寅虎
日期:2013-12-04 20:37:4915-16赛季CBA联赛之广东
日期:2017-08-22 19:23:1215-16赛季CBA联赛之上海
日期:2016-06-18 23:05:05操作系统版块每日发帖之星
日期:2016-06-06 06:20:00操作系统版块每日发帖之星
日期:2016-06-05 06:20:00操作系统版块每日发帖之星
日期:2016-06-03 06:20:002015年辞旧岁徽章
日期:2015-03-03 16:54:152015年亚洲杯之巴勒斯坦
日期:2015-02-10 21:38:08卯兔
日期:2014-10-31 20:42:23申猴
日期:2014-06-11 17:15:10处女座
日期:2014-05-22 09:00:1815-16赛季CBA联赛之广夏
日期:2017-09-25 23:37:46
跳转到指定楼层
1 [收藏(0)] [报告]
发表于 2012-10-29 21:24 |只看该作者 |倒序浏览

无意中发现的灵异问题,哪位大能来解解惑?inotifywait到底是啥原理?没弄明白

实验步骤很简单,如下:

终端1:
  1. $ touch test
  2. $ inotifywait -m test
  3. Setting up watches.
  4. Watches established.
复制代码
终端2:
  1. $ echo "hello" > test
复制代码
终端1,此时一切正常,能正常监视:
  1. $ inotifywait -m test
  2. Setting up watches.
  3. Watches established.
  4. test MODIFY
  5. test OPEN
  6. test MODIFY
  7. test CLOSE_WRITE,CLOSE
复制代码
终端2,使用vim打开test
  1. $ vim test
复制代码
终端1,此时仍然能监视到事件:
  1. $ inotifywait -m test
  2. Setting up watches.
  3. Watches established.
  4. test MODIFY
  5. test OPEN
  6. test MODIFY
  7. test CLOSE_WRITE,CLOSE
  8. test OPEN
  9. test CLOSE_NOWRITE,CLOSE
  10. test OPEN
  11. test ACCESS
  12. test CLOSE_NOWRITE,CLOSE
复制代码
终端2,我在随便往test里写入内容之后,:wq退出。

终端1,此时仍然ok,能够正常监视此次事件:
  1. $ inotifywait -m test
  2. Setting up watches.
  3. Watches established.
  4. test MODIFY
  5. test OPEN
  6. test MODIFY
  7. test CLOSE_WRITE,CLOSE
  8. test OPEN
  9. test CLOSE_NOWRITE,CLOSE
  10. test OPEN
  11. test ACCESS
  12. test CLOSE_NOWRITE,CLOSE
  13. test OPEN
  14. test CLOSE_NOWRITE,CLOSE
  15. test ATTRIB
  16. test DELETE_SELF
复制代码
终端2,当我继续往test里echo,或者重新使用vim打开test,inotifywait好似患了老年痴呆症一般,傻了。
  1. $ echo "hello" > test
复制代码
终端1,没有任何反应:
  1. [code]$ inotifywait -m test
  2. Setting up watches.
  3. Watches established.
  4. test MODIFY
  5. test OPEN
  6. test MODIFY
  7. test CLOSE_WRITE,CLOSE
  8. test OPEN
  9. test CLOSE_NOWRITE,CLOSE
  10. test OPEN
  11. test ACCESS
  12. test CLOSE_NOWRITE,CLOSE
  13. test OPEN
  14. test CLOSE_NOWRITE,CLOSE
  15. test ATTRIB
  16. test DELETE_SELF
复制代码
[/code]

论坛徽章:
0
2 [报告]
发表于 2012-10-29 21:32 |只看该作者
回复 1# wait_rabbit


   
test DELETE_SELF


    其实你 ls -i 也能看到, inode 变了.
    猜可能是因为 vim :w 是根据原文件与变更 合并出另外一个同名文件后删了原文件.

论坛徽章:
12
寅虎
日期:2013-12-04 20:37:4915-16赛季CBA联赛之广东
日期:2017-08-22 19:23:1215-16赛季CBA联赛之上海
日期:2016-06-18 23:05:05操作系统版块每日发帖之星
日期:2016-06-06 06:20:00操作系统版块每日发帖之星
日期:2016-06-05 06:20:00操作系统版块每日发帖之星
日期:2016-06-03 06:20:002015年辞旧岁徽章
日期:2015-03-03 16:54:152015年亚洲杯之巴勒斯坦
日期:2015-02-10 21:38:08卯兔
日期:2014-10-31 20:42:23申猴
日期:2014-06-11 17:15:10处女座
日期:2014-05-22 09:00:1815-16赛季CBA联赛之广夏
日期:2017-09-25 23:37:46
3 [报告]
发表于 2012-10-29 21:49 |只看该作者
回复 2# hbmhalley

hmmmm.……兄台好细心,看来还真是如此。。。

inotifywait监视了一个不存在的文件。


您需要登录后才可以回帖 登录 | 注册

本版积分规则 发表回复

  

北京盛拓优讯信息技术有限公司. 版权所有 京ICP备16024965号-6 北京市公安局海淀分局网监中心备案编号:11010802020122 niuxiaotong@pcpop.com 17352615567
未成年举报专区
中国互联网协会会员  联系我们:huangweiwei@itpub.net
感谢所有关心和支持过ChinaUnix的朋友们 转载本站内容请注明原作者名及出处

清除 Cookies - ChinaUnix - Archiver - WAP - TOP