存档

文章标签 ‘gzip’

mysqldump选择gzip压缩之后为.tar.gz格式如何再次导入

2020年11月12日 评论已被关闭

在使用mysqldump备份数据库的时候导出的时候一般有2种选择,压缩和不压缩

参见文章:
【实战】linux下mysql导入和导出数据库,source和mysqldump命令
http://www.zhanghongliang.com/article/498

这里我们记录下压缩的格式再次导入的特殊问题:mysqldump选择gzip压缩之后为.tar.gz格式如何再次导入

在上方链接的文章中,压缩命令是:

mysqldump -hlocalhost -uroot -p --quick 数据库名称 | gzip > /backup/备份文件名.sql.gz

但是往往有些人会用这个命令,导致压缩包格式为.tar.gz

mysqldump -hlocalhost -uroot -p --quick 数据库名称 | gzip > /backup/备份文件名.sql.tar.gz

那么当mysqldump选择gzip压缩之后为.tar.gz格式如何再次导入?请参考:
A,假设我们在windows服务器上操作,直接把备份文件名.sql.tar.gz(比如abc.sql.tar.gz)下载到本地windows,然后选择7-zip来操作,右键abc.sql.tar.gz,7-zip,提取到“abc.sql.tar\”;再使用source命令导入abc.sql.tar即可完成再次导入

B,假设我们在linux服务器上直接再次导入,可以
1,执行sudo gunzip abc.sql.tar.gz,得到:abc.sql.tar
2,source abc.sql.tar

这样我们就解决了.tar.gz再次导入的问题

php开启gzip压缩正宗3种可使用方法

2015年3月14日 没有评论

今天特别把php开启gzip压缩的三种不同的方法详细的整理并在这里介绍一下,php开启gzip压缩之后,效率会高出很多,但是同时也会增加服务器的承载,当然开启gzip是值得的

3种方案

第一:使用apache2中的mod_deflate.so
1,打开apache中的mod_deflate.so
2,php.ini:output_buffering = Off
3,php.ini为;output_handler = ob_gzhandler
zlib.output_compression = Off
;zlib.output_compression_level = -1
4,apache增加如下:

<IfModule deflate_module>
AddOutputFilter DEFLATE html php js css
</IfModule>

第二:使用php.ini中的zlib.output_compression
1,关闭apache中的mod_deflate.so
2,php.ini:output_buffering = On
2,php.ini为;output_handler =
zlib.output_compression = Off
zlib.output_compression_level = 6(等级-1至9,默认为6即可)

第三:用php的内置函数ob_gzhandler(必须保证extension中安装并开启了php_zlib.dll)
1,关闭apache中的mod_deflate.so
2,php.ini为output_handler = ob_gzhandler
zlib.output_compression = On
;zlib.output_compression_level = -1

第三种如果使用了php.ini中设置output_handler=ob_gzhandler,那么程序中就不需要再加ob_start(‘ob_gzhandler’);否则会双重压缩,实际上就是报错,一般程序我们会加以判断

设置php.ini为默认关闭,程序中增加,但是如果是自己服务器,就设置ini默认开启

三种只能选其一,实际项目中,建议使用第1种或者第2种:(特别建议使用第1种)

这个时候ob_start()可以自定义函数,写法如:ob_start(“compress_html”);

这样就可以压缩html格式

function compress_html($buffer){//去除文件中的注释
$pattern=array(“/> *([^ ]*) *</”,”/<!–[^!]*–>/”,”‘/\*[^*]*\*/'”,”/[\s]+/”,”/\r\n/”,”/\n/”,”/\t/”);
$replace=array(“>\\1<“,””,””,” “,””,””,””);
return ltrim(rtrim(preg_replace($pattern,$replace,$buffer)));
}

这样操作了之后,不仅可以压缩html格式(也可以使用gzip)

————————————————————————–

使用第一种,完整配置方案:

1,打开apache中的mod_deflate.so
2,php.ini为output_buffering = Off
3,php.ini为;output_handler = ob_gzhandler
;zlib.output_compression = Off
;zlib.output_compression_level = -1
4,apache增加如下:
<IfModule deflate_module>
AddOutputFilter DEFLATE html php js css
</IfModule>

在需要压缩html格式的php头部使用如下程序:
ob_start(“compress_html”);//需要将php.ini中的zlib.output_compression开启
function compress_html($buffer){//去除文件中的注释
$pattern=array(“/> *([^ ]*) *</”,”/<!–[^!]*–>/”,”‘/\*[^*]*\*/'”,”/[\s]+/”,”/\r\n/”,”/\n/”,”/\t/”);
$replace=array(“>\\1<“,””,””,” “,””,””,””);
return ltrim(rtrim(preg_replace($pattern,$replace,$buffer)));
}

这样就完整的开启了php的gzip压缩功能,而且支持浏览器查看源文件的时候html自动压缩格式化,试试看吧,绝对有用。

分类: php学习 标签: , ,
css.php