我知道这个问题的一部分已经被问过,但我有一些相关的问题。python subprocess和mysqldump
我试图执行
mysqldump -u uname -ppassword --add-drop-database --databases databaseName | gzip > fileName
我可能倾倒非常大(200GB?)分贝。这本身就是一件愚蠢的事情吗?然后我想通过网络发送压缩文件进行存储,删除本地转储,并清除一些表格。
无论如何,我正在使用这样的子进程,因为似乎没有办法在没有子进程的情况下执行整个原始调用。以表格名称。:
from subprocess import Popen, PIPE
f = open(FILENAME, 'wb')
args = ['mysqldump', '-u', 'UNAME', '-pPASSWORD', '--add-drop-database', '--databases', 'DB']
p1 = Popen(args, stdout=PIPE)
P2 = Popen('gzip', stdin=p1.stdout, stdout=f)
p2.communicate()
但后来我读了通信缓存数据在内存中,这对我不起作用。这是真的?
我终于实现了,现在是什么:当然
import gzip
subprocess.call(args, stdout=f)
f.close()
f = open(filename, 'rb')
zipFilename = filename + '.gz'
f2 = gzip.open(zipFilename, 'wb')
f2.writelines(f)
f2.close()
f.close()
这需要一万年,我恨它。
我的问题: 1.我可以在非常大的分贝上使用我的第一种方法吗? 2.我能否将mysqldump的输出传输到套接字并在网络上触发它并在到达时保存它,而不是发送压缩文件?
谢谢!
相关:我如何使用subprocess.Popen连接管由多个进程?](http://stackoverflow.com/q/295459/4279) – jfs