Questo è come si accende la modalità non-blocking su di un file in UNIX:
fd = os.open("filename", os.O_CREAT | os.O_WRONLY | os.O_NONBLOCK)
os.write(fd, "data")
os.close(fd)
Su UNIX, tuttavia, turning on non-blocking mode has no visible effect for regular files! Anche se il file è in modalità non bloccante, la chiamata os.write
non verrà restituita immediatamente, ma verrà interrotta fino al completamento della scrittura. Per dimostrare a voi stessi sperimentalmente, provate questo:
import os
import datetime
data = "\n".join("testing\n" * 10 for x in xrange(10000000))
print("Size of data is %d bytes" % len(data))
print("open at %s" % str(datetime.datetime.now()))
fd = os.open("filename", os.O_CREAT | os.O_WRONLY | os.O_NONBLOCK)
print("write at %s" % str(datetime.datetime.now()))
os.write(fd, data)
print("close at %s" % str(datetime.datetime.now()))
os.close(fd)
print("end at %s" % str(datetime.datetime.now()))
Si noterà che la chiamata os.write
ci vuole qualche secondo. Anche se la chiamata è non bloccante (tecnicamente, non blocca, sta dormendo), la chiamata è non asincrona.
AFAIK, non c'è modo di scrivere in un file in modo asincrono su Linux o su Windows. Puoi simularlo, tuttavia, usando i thread. Twisted ha un metodo chiamato deferToThread
per questo scopo. Ecco come lo si utilizza:
from twisted.internet import threads, reactor
data = "\n".join("testing\n" * 10 for x in xrange(10000000))
print("Size of data is %d bytes" % len(data))
def blocking_write():
print("Starting blocking_write")
f = open("testing", "w")
f.write(data)
f.close()
print("End of blocking_write")
def test_callback():
print("Running test_callback, just for kicks")
d = threads.deferToThread(blocking_code)
reactor.callWhenRunning(cc)
reactor.run()
possibile duplicato (http://stackoverflow.com/questions/319132/asynchronous-file-writing-possible-in-python) – jcollado
[file di Asynchronous scrittura possibile in Python?] No, no, ho bisogno di mantenerlo semplice usando solo fcntl :) – Rahul