我想要理解mysqldump是如何工作的:
如果我在我的电脑上执行mysqldump并连接到一个远程服务器:
mysqldump -u mark -h 34.32.23.23 -pxxx --quick | gzip > dump.sql.gz
服务器会将数据压缩成gzip格式后再发送给我吗?还是我的电脑会先接收到所有数据,然后再进行压缩?
因为我需要导出一个非常大的远程数据库,我想知道如何在网络上以最快的方式完成。
我想要理解mysqldump是如何工作的:
如果我在我的电脑上执行mysqldump并连接到一个远程服务器:
mysqldump -u mark -h 34.32.23.23 -pxxx --quick | gzip > dump.sql.gz
服务器会将数据压缩成gzip格式后再发送给我吗?还是我的电脑会先接收到所有数据,然后再进行压缩?
因为我需要导出一个非常大的远程数据库,我想知道如何在网络上以最快的方式完成。
你应该使用ssh + scp,因为本地主机上的转储速度更快,
并且你只需要将gzip文件进行scp传输(网络开销较小)。
很可能你可以这样做。
ssh $username@34.32.23.23 "mysqldump -u mark -h localhost -pxxx --quick | gzip > /tmp/dump.sql.gz"
scp $username@34.32.23.23:/tmp/dump.sql.gz .
(可选的 /tmp 目录,应更改为您习惯的任何目录)
mysqldump | gzip --rsyncalbe
并将文件通过 rsync
同步到目标位置,而不是使用 scp
。这样可以避免获取已经存在的位。 - MatrixManAtYrService您尝试过使用--compress参数吗?
http://dev.mysql.com/doc/refman/5.1/en/mysqldump.html#option_mysqldump_compress
--compress
参数的工作原理,文档资料并不多。我可以做出一个有根据的猜测,但需要查看源代码才能确定。但是我认为你的问题是它是在服务器端还是客户端进行压缩。在你的示例中,它肯定是在客户端进行的。如果你已经看到了压缩参数减少了数据传输量,那么这应该回答了你的问题,即它是在服务器端进行压缩的。 - Mark Fraser这是我的做法:
使用SELECT INTO OUTFILE
进行部分导出,并在同一服务器上创建文件。
如果您的表包含1000万行,则每次以100万行的方式进行部分导出,每次在单独的文件中。
一旦第一个文件准备好,您可以压缩并传输它。同时,MySQL可以继续将数据导出到下一个文件中。
在另一个服务器上,您可以开始将文件加载到新数据库中。
顺便说一句,很多东西都可以脚本化。
gzip
也将在您的PC上运行。这意味着您将获得未压缩的原始转储。 - pritaeas