LNMP 环境下使用 Zstd 压缩优化网站备份脚本

2024-06-04 02:36

本文主要是介绍LNMP 环境下使用 Zstd 压缩优化网站备份脚本,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

网站的备份一直都是网站运营、服务器运维中很重要的一环,明月无论是在自己的服务器还是客户的代运维服务器上都是非常重视网站备份的,尤其热衷于优化网站备份这块儿,毕竟明月自己的服务器配置一直都是最低的 1H1G 呀,就这配置常年都是 4-5 个网站放着呢!明月的博客毕竟有十来年了,单单网站文件就占用了至少 5G 了,这还不包括数据库的占用。

LNMP 环境下使用 Zstd 压缩优化网站备份脚本

随着网站文件的日积月累,LNMP 环境下网站备份脚本的运行效率是越来越吃力了,以前都是每天一次备份的,现在因为备份期间服务器负载飙升相当恐怖都改成一周一次备份了:

LNMP 环境下使用 Zstd 压缩优化网站备份脚本

有图有真相,备份期间明月服务器的负载(load avvrage)情况实时截图

这个负载值已经严重影响备份期间网站的正常访问了,甚至会出现 503、502 等错误,反正每次备份期间,明月是不敢去访问网站的,并且这个过程持续的时间一般都在 2-3 个小时左右,很明显这不科学呀。

经过对 LNMP 环境下网站备份脚本 backup.sh 代码的分析,发现造成备份期间服务器负载持续飙升的罪魁祸首是备份时的压缩算法 gzip,上面的截图里就可以看到备份期间 gzip 的进程占据了很多,明月简单统计了一下能有 20-30 多个 gzip 进程,压缩是需要大量的 CPU 运算和内存的,明月服务器的 1H1G 很明显是承受不了这么“蹂躏”的,是时候给网站备份脚本更换压缩算法了。这时候看到了一则旧闻:

LNMP 环境下使用 Zstd 压缩优化网站备份脚本

这个 Zstd 压缩算法真的是太牛逼了,Linux 内核组件都在用了,那要是拿来用在网站备份上也不知道是个啥效果,于是果断施展搜索大法一番了解后得出结论完全没有问题的,于是就诞生了【Zstd(Zstandard)助力网站备份利器】的运维学习笔记,又因为实操发现有了【更新 tar 命令到最新版本】笔记,先在自己服务器上调试一番后终于成功实现了用 Zstd 压缩算法网站备份,马上给一个客户的服务器也用上了,效果非常的好,备份结果对比一下也是非常的满意:

LNMP 环境下使用 Zstd 压缩优化网站备份脚本

上图左边是 gzip 压缩算法备份的网站文件和数据库导出的 sql 大小,右边是采用 Zstd 压缩算法后备份产生的文件大小

虽然对比网站文件在大小上没有很明显的差异,这主要是因为服务器硬件配置和压缩参数的问题,可以进行调优来改善的,明月最喜欢的是采用 Zstd 压缩算法后备份期间的服务器负载表现都快亮瞎眼了:

LNMP 环境下使用 Zstd 压缩优化网站备份脚本

这是明月自己 1H1G 服务器备份期间的负载实时截图

LNMP 环境下使用 Zstd 压缩优化网站备份脚本

这是客户服务器(1H2G,老薛海外云主机)备份期间的负载实时截图

这负载直接下降了近十倍呀,太神奇了吧!哈哈!并且明月持续观察了很长一段时间,都是这个状态,波动也都是维持在个位数而已,备份期间完全不影响网站的访问、登录等等,并且整体的备份耗时至少缩减了一倍还多,整个备份期间无论是前端还是后端都是毫无感受,看来明月这 1H1G 配置的服务器还能再挺几年是没有问题的了!完美!!!

又在多个不同客户、不同地域、不同硬件配置、不同服务器生产环境上测试后,实测证明 Zstd 压缩算法的强大真不是盖的的,Linux 内核都采用了可见一斑!好了,废话不多说了,下面给大家分享一下明月的这个 Zstd 压缩算法的网站备份脚本代码:

要在服务器上用 Zstd 压缩算法有两个必备条件:

  • 1、升级 tar(打包命令)到最新版,至少 1.30 以上。可参考【更新 tar 命令到最新版本】一文;
  • 2、安装 Zstd,当然最新版最好。可参考【Zstd(Zstandard)助力网站备份利器】一文;

上述两个条件是必备的,否则下面的脚本是没法执行的哦!

这里我们以军哥 LNMP 一键安装包里的网站备份脚本 backup.sh 为例,里面原本的压缩备份打包文件的代码如下:

TodayWWWBackup=www-*-$(date +"%Y%m%d").tar.gz
TodayDBBackup=db-*-$(date +"%Y%m%d").sql
OldWWWBackup=www-*-$(date -d -3day +"%Y%m%d").tar.gz
OldDBBackup=db-*-$(date -d -3day +"%Y%m%d").sqlBackup_Dir()
{Backup_Path=$1Dir_Name=`echo ${Backup_Path##*/}`Pre_Dir=`echo ${Backup_Path}|sed 's/'${Dir_Name}'//g'`tar zcf ${Backup_Home}www-${Dir_Name}-$(date +"%Y%m%d").tar.gz -C ${Pre_Dir} ${Dir_Name}
}
Backup_Sql()
{${MySQL_Dump} -u$MYSQL_UserName -p$MYSQL_PassWord $1 > ${Backup_Home}db-$1-$(date +"%Y%m%d").sql
}

只需要对照修改成下面代码即可:

TodayWWWBackup=www-*-$(date +"%Y%m%d").tar.zst
TodayDBBackup=db-*-$(date +"%Y%m%d").sql.zst
OldWWWBackup=www-*-$(date -d -1day +"%Y%m%d").tar.zst
OldDBBackup=db-*-$(date -d -1day +"%Y%m%d").sql.zstBackup_Dir()
{Backup_Path=$1Dir_Name=`echo ${Backup_Path##*/}`Pre_Dir=`echo ${Backup_Path}|sed 's/'${Dir_Name}'//g'`tar '-I zstd -19 -T0' -cf ${Backup_Home}www-${Dir_Name}-$(date +"%Y%m%d").tar.zst -C ${Pre_Dir} ${Dir_Name}
}
Backup_Sql()
{${MySQL_Dump} -u$MYSQL_UserName -p$MYSQL_PassWord $1 | zstd -19 -T0 > ${Backup_Home}db-$1-$(date +"%Y%m%d").sql.zst
}

完成后,保存退出即可,想测试了也可以直接备份一下实测对比一下结果,其中上述代码里 zstd 命令后面的参数可以根据自己的服务器硬件配置进行调整的会有意想不到的效果的哦!

参数:-19

指的是压缩等级为 19,这是目前默认最高的,效果取决于你的内存了,内存越多效果越好。

参数: -T0

指的是压缩的时候使用所有 CPU,会影响压缩比的哦,比如你是 4H 的 CPU 就是 -T4,其他配置一次类推即可。
 

LNMP 环境下使用 Zstd 压缩优化网站备份脚本

上图就是一个 8H 服务器备份期间负载截图,结果是 4G 的网站文件压缩到了 2.5G,很牛逼的压缩比了!

目前,明月所有代运维的服务器都已经采用 Zstd 压缩算法网站备份了,毕竟效果那是真的没的说,看来明月很有必要给军哥 LNMP 一键安装包也建议一下对 Zstd 的支持了,毕竟独乐乐不如众乐乐呀!先分享给有需要的站长朋友再说了!

这篇关于LNMP 环境下使用 Zstd 压缩优化网站备份脚本的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/1028820

相关文章

python管理工具之conda安装部署及使用详解

《python管理工具之conda安装部署及使用详解》这篇文章详细介绍了如何安装和使用conda来管理Python环境,它涵盖了从安装部署、镜像源配置到具体的conda使用方法,包括创建、激活、安装包... 目录pytpshheraerUhon管理工具:conda部署+使用一、安装部署1、 下载2、 安装3

Mysql虚拟列的使用场景

《Mysql虚拟列的使用场景》MySQL虚拟列是一种在查询时动态生成的特殊列,它不占用存储空间,可以提高查询效率和数据处理便利性,本文给大家介绍Mysql虚拟列的相关知识,感兴趣的朋友一起看看吧... 目录1. 介绍mysql虚拟列1.1 定义和作用1.2 虚拟列与普通列的区别2. MySQL虚拟列的类型2

使用MongoDB进行数据存储的操作流程

《使用MongoDB进行数据存储的操作流程》在现代应用开发中,数据存储是一个至关重要的部分,随着数据量的增大和复杂性的增加,传统的关系型数据库有时难以应对高并发和大数据量的处理需求,MongoDB作为... 目录什么是MongoDB?MongoDB的优势使用MongoDB进行数据存储1. 安装MongoDB

关于@MapperScan和@ComponentScan的使用问题

《关于@MapperScan和@ComponentScan的使用问题》文章介绍了在使用`@MapperScan`和`@ComponentScan`时可能会遇到的包扫描冲突问题,并提供了解决方法,同时,... 目录@MapperScan和@ComponentScan的使用问题报错如下原因解决办法课外拓展总结@

mysql数据库分区的使用

《mysql数据库分区的使用》MySQL分区技术通过将大表分割成多个较小片段,提高查询性能、管理效率和数据存储效率,本文就来介绍一下mysql数据库分区的使用,感兴趣的可以了解一下... 目录【一】分区的基本概念【1】物理存储与逻辑分割【2】查询性能提升【3】数据管理与维护【4】扩展性与并行处理【二】分区的

使用Python实现在Word中添加或删除超链接

《使用Python实现在Word中添加或删除超链接》在Word文档中,超链接是一种将文本或图像连接到其他文档、网页或同一文档中不同部分的功能,本文将为大家介绍一下Python如何实现在Word中添加或... 在Word文档中,超链接是一种将文本或图像连接到其他文档、网页或同一文档中不同部分的功能。通过添加超

Linux使用fdisk进行磁盘的相关操作

《Linux使用fdisk进行磁盘的相关操作》fdisk命令是Linux中用于管理磁盘分区的强大文本实用程序,这篇文章主要为大家详细介绍了如何使用fdisk进行磁盘的相关操作,需要的可以了解下... 目录简介基本语法示例用法列出所有分区查看指定磁盘的区分管理指定的磁盘进入交互式模式创建一个新的分区删除一个存

C#使用HttpClient进行Post请求出现超时问题的解决及优化

《C#使用HttpClient进行Post请求出现超时问题的解决及优化》最近我的控制台程序发现有时候总是出现请求超时等问题,通常好几分钟最多只有3-4个请求,在使用apipost发现并发10个5分钟也... 目录优化结论单例HttpClient连接池耗尽和并发并发异步最终优化后优化结论我直接上优化结论吧,

SpringBoot使用Apache Tika检测敏感信息

《SpringBoot使用ApacheTika检测敏感信息》ApacheTika是一个功能强大的内容分析工具,它能够从多种文件格式中提取文本、元数据以及其他结构化信息,下面我们来看看如何使用Ap... 目录Tika 主要特性1. 多格式支持2. 自动文件类型检测3. 文本和元数据提取4. 支持 OCR(光学

Java内存泄漏问题的排查、优化与最佳实践

《Java内存泄漏问题的排查、优化与最佳实践》在Java开发中,内存泄漏是一个常见且令人头疼的问题,内存泄漏指的是程序在运行过程中,已经不再使用的对象没有被及时释放,从而导致内存占用不断增加,最终... 目录引言1. 什么是内存泄漏?常见的内存泄漏情况2. 如何排查 Java 中的内存泄漏?2.1 使用 J