3 回答

TA貢獻(xiàn)2051條經(jīng)驗(yàn) 獲得超10個(gè)贊
一個(gè)大小為'PIPE_BUF'的寫入應(yīng)該是原子的。這至少應(yīng)該是512字節(jié),雖然它可能很容易變大(linux似乎將它設(shè)置為4096)。
這假設(shè)您正在談?wù)撍型耆螾OSIX的組件。例如,在NFS上不是這樣。
但假設(shè)您寫入以“O_APPEND”模式打開的日志文件并將您的行(包括換行符)保留在“PIPE_BUF”字節(jié)長的情況下,您應(yīng)該能夠?qū)⒍鄠€(gè)寫入器寫入日志文件而不會(huì)出現(xiàn)任何損壞問題。任何中斷都將在寫入之前或之后到達(dá),而不是在中間。如果您希望文件完整性在重新啟動(dòng)后繼續(xù)存在,您還需要fsync(2)
在每次寫入后調(diào)用,但這對(duì)于性能而言非常糟糕。
澄清:閱讀評(píng)論和Oz Solomon的回答。我不確定O_APPEND
應(yīng)該具有那么PIPE_BUF
大小的原子性。它完全有可能是Linux實(shí)現(xiàn)的方式write()
,或者可能是由于底層文件系統(tǒng)的塊大小。

TA貢獻(xiàn)1911條經(jīng)驗(yàn) 獲得超7個(gè)贊
我寫了一個(gè)腳本來經(jīng)驗(yàn)測(cè)試最大原子附加大小。用bash編寫的腳本生成多個(gè)工作進(jìn)程,這些進(jìn)程都將特定于工作程序的簽名寫入同一文件。然后它讀取文件,查找重疊或損壞的簽名。您可以在此博客文章中查看腳本的來源。
實(shí)際的最大原子附加大小不僅因操作系統(tǒng)而異,而且因文件系統(tǒng)而異。
在Linux + ext3上,大小為4096,在Windows + NTFS上,大小為1024.有關(guān)更多大小,請(qǐng)參閱下面的注釋。
添加回答
舉報(bào)