- c - 在位数组中找到第一个零
- linux - Unix 显示有关匹配两种模式之一的文件的信息
- 正则表达式替换多个文件
- linux - 隐藏来自 xtrace 的命令
这对我来说可能有点愚蠢,但它提出了很多有趣的问题。我有一个来自聊天客户端的日志文件目录,每次其中一个发生更改时,我都希望使用 notify-osd 得到通知。
我编写的脚本基本上使用 os.popen 在每个文件上运行 linux tail 命令以获取最后一行,然后根据上次运行时的行字典检查每一行。如果线路发生变化,它会使用 pynotify 向我发送通知。
这个脚本实际上运行得很好,除了它使用了大量的 cpu(可能是因为它在每次循环运行时在通过 sshfs 挂载的文件上运行 tail 大约 16 次。)
好像是this将是一个很好的解决方案,但我不知道如何为多个文件实现它。
Here是我写的脚本。请原谅我缺乏评论和糟糕的风格。
编辑:澄清一下,这都是桌面上的 Linux。
最佳答案
即使不查看您的源代码,也有两种方法可以让您更轻松地更高效地执行此操作并处理多个文件。
除非万不得已,否则不要费心跑尾部。只需 os.stat
所有文件并记录最后修改时间。如果上次修改时间不同,则发出通知。
使用 pyinotify调用 Linux 的 inotify设施;这将使内核为您执行选项 1,并在目录中的任何文件更改时回调给您。然后将回调转换为您的 OSD 通知。
现在,可能会有一些棘手的问题,具体取决于有多条消息时您需要多少条通知,以及您是否关心错过某条消息的通知。
保留使用 tail
的方法是改为使用 tail -f
。使用 tail -f
打开所有文件,然后使用 select
模块让操作系统在为 打开的文件描述符之一上有附加输入时通知您尾-f
。您的主循环将调用 select,然后遍历每个可读描述符以生成通知。 (您可以不使用 tail
并在可读时调用 readline()
来执行此操作。)
脚本中其他需要改进的地方:
os.listdir
和 native Python 过滤(例如,使用列表理解),而不是带有一堆 grep
过滤器的 popen
。 subprocess.popen
代替 os.popen
。关于python - 在python中尾部多个日志文件,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/5725051/
我发现了一些令人费解的行为。给定一个包含 50 个日期的列表: structure(c("15513", "12830", "16503", "-3628", "15833", "13553", "4
我正在尝试创建单链表,但我不知道我做错了什么。 在插入元素 5、6、7、2、3、4 后,尾部应该是 4,但我得到的是 3,我不明白为什么。 这是我的代码: public void Insert(int
这是我的尾部代码(前 10 行): #include #include #include typedef char storage_datatype; #define MAXLINESIZE 1
关闭。这个问题不符合Stack Overflow guidelines .它目前不接受答案。 要求我们推荐或查找工具、库或最喜欢的场外资源的问题对于 Stack Overflow 来说是偏离主题的,
是否有一种有效的方法可以从 List 中删除 X 元素的范围(例如尾部),例如LinkedList 在 Java 中? 显然可以一个一个地删除最后一个元素,这应该会导致 O(X) 级别的性能。至少对于
在之前的一篇文章我们介绍了《如何向php数组中头部和尾部添加元素》既然有添加元素,那么就有删除元素,今天这篇文章详细介绍如何删除数组中的头部元素和尾部元素,还有任意数组元素。 删除末尾元素:arr
在双向链表的实现中,我使用了典型的结构: struct node { void *data; struct node *prev; struct node *next; };
ECMA-335,III.2.4指定可以在递归函数中使用的tail.前缀。但是,我在C#和F#代码中都找不到它的用法。有使用in的示例吗? 最佳答案 您不会在当前的MS C#编译器生成的任何代码中找到
关闭。这个问题不符合Stack Overflow guidelines .它目前不接受答案。 我们不允许提问寻求书籍、工具、软件库等的推荐。您可以编辑问题,以便用事实和引用来回答。 关闭 7 年前。
这个问题在这里已经有了答案: How to 'grep' a continuous stream? (13 个答案) 关闭 8 年前。 Tail 有以下选项: -f The -f opti
我试图弄清楚一旦我击中某个字符,如何从尾部修剪 Bash 中的字符串。 示例:如果我的字符串是这个(或任何链接):https://www.cnpp.usda.gov/Innovations/DataS
我试图弄清楚一旦我击中某个字符,如何从尾部修剪 Bash 中的字符串。 示例:如果我的字符串是这个(或任何链接):https://www.cnpp.usda.gov/Innovations/DataS
当我执行这段代码时,循环总是在第一次结束(即使 auth.log 的最后两行不包含“exit”),这意味着 $c总是得到一些字符串: while true; do c=$(tail -2 /v
我正在尝试编写一个“添加”函数,该函数接受节点中保存的值(表示为“n”),以及节点要添加到链表中的位置(表示为“pos”)。 我看到代码中有 3 个单独的添加函数 - addAtBeginning、a
为什么我不能得到“cd fjadf”? 程序总是向我显示 Bus error: 10... 我想用这个super_cut_tail()函数来截断用户指定的///fjdakf。但是为什么这个功能不能实现
有一个简化的表 mytable,其中列 ('id', 'mycolumn') 为 int 和 varchar(255 )分别。 在 mycolumn 中查找当前字符串具有最长公共(public)右侧部
这个问题已经有答案了: 已关闭13 年前。 Possible Duplicate: Get last n lines of a file with Python, similar to tail 你好
我想通过对写出的响应主体进行哈希处理来计算响应的实体标签。当我计算实体标签时,将实体标签添加到响应 header 已经太晚了。我想将实体标签添加到预告片中。我看到 net/http 包支持编写预告片,
我正在尝试通过 script.sh 从第 2 行到第 5 行打印文件 (myfile) 的内容。脚本无法从位置 2 打开文件。并且内容从第 1 行打印到第 4 行。以下是文件内容、命令和命令的输出。
在一个特殊的控制台上,我喜欢从/var/log/syslog 中过滤一些信息。这并不是很棘手: tail -f /var/log/syslog | awk '{print $2,$1,$9,$3,"\
我是一名优秀的程序员,十分优秀!