Nginx写日志文件是什么原理

在做Nginx的日志文件切割,发现一个诡异的问题。当我手工把Nginx的日志文件转移位置以后,如果不reload配置文件,Nginx还是继续写这个被转移到其他目录的日志文件。
难道Nginx写日志的时候不是通过文件路径吗?
为什么日志文件被转移走了还是能写到?

慕码人8056858
浏览 1487回答 3
3回答

月关宝盒

nginx为了更快的速度,一般都缓存了文件的inode的。

回首忆惘然

我觉得原因是,nginx打开的log文件之后,在系统中实际上是以inode来标识的,移动文件并不会修改inode的编号,所以还会继续写入该文件。

12345678_0001

这是文件系统的特性,有点类似编程语言管理变量生命周期的里的引用计数。移动一个文件,甚至删除一个文件,只要这个文件还被某个进程打开着,这个文件就还能被访问到。但如果所有的“引用”都没有了,例如文件名,硬链接(hard link)及文件句柄(不再被程序打开着),才影响对文件的下一次引用,就表现为“找不到文件了”。
打开App,查看更多内容
随时随地看视频慕课网APP