iis服务器助手广告广告
返回顶部
首页 > 资讯 > 数据库 >MySQL中如何进行大文本存储压缩
  • 146
分享到

MySQL中如何进行大文本存储压缩

mysql 2023-02-13 15:02:46 146人浏览 独家记忆
摘要

今天小编给大家分享一下Mysql中如何进行大文本存储压缩的相关知识点,内容详细,逻辑清晰,相信大部分人都还太了解这方面的知识,所以分享这篇文章给大家参考一下,希望大家阅读完这篇文章后有所收获,下面我们一起来

今天小编给大家分享一下Mysql中如何进行大文本存储压缩的相关知识点,内容详细,逻辑清晰,相信大部分人都还太了解这方面的知识,所以分享这篇文章给大家参考一下,希望大家阅读完这篇文章后有所收获,下面我们一起来了解一下吧。

存量数据分析

select
  table_name as '表名',
  table_rows as '记录数',
  truncate(data_length/1024/1024, 2) as '数据容量(MB)',
  truncate(index_length/1024/1024, 2) as '索引容量(MB)',
  truncate(DATA_FREE/1024/1024, 2) as '碎片占用(MB)'
from
  infORMation_schema.tables
where
  table_schema=${数据库名}
order by
  data_length desc, index_length desc;

MySQL中如何进行大文本存储压缩MySQL中如何进行大文本存储压缩

相关内容介绍

innodb引擎页数据超出16kb怎么办?

我们都知道innodb的页块默认大小为16k,如果表中一行数据长度超出了16k,就会出现行溢出,溢出的行是存放在另外的地方(uncompress blob page)。由于innodb采用聚簇索引把数据进行存放起来,即B+Tree结构,因此每个页块中至少有两行数据,否则就失去了B+Tree的意义,这样就得出一行数据最大的长度限制为8k(大字段在数据页会存储768个字节数据,剩余的数据溢出到另外的页中,数据页还有20个字节记录溢出页的地址)

  • 对 dynamic 格式来说,如果大对象字段(text/blob)存储数据大小小于 40 字节,那全部放在数据页,剩余的场景,数据页只保留一个 20 字节的指针指向溢出页。 这种场景下,如果每个大对象字段保存的数据小于 40 个字节,也就和 varchar(40),效果一样。

  • innodb-row-format-dynamic:dev.mysql.com/doc/refman/…

linux 稀疏文件 & 空洞

  • 稀疏文件(Sparse File):稀疏文件与其他普通文件基本相同,区别在于文件中的部分数据全为0,且这部分数据不占用磁盘空间

  • 文件空洞:文件位移量可以大于文件的实际长度(位于文件中但未被写过的字节被设为0),空洞是否占用磁盘空间由操作系统决定

    • MySQL中如何进行大文本存储压缩

文件空洞部分不占用磁盘空间、文件所占用的磁盘空间仍然是连续的

innodb提供的压缩方案

页面压缩

适用场景:由于数据量太大,磁盘空间不足,负载主要体现在IO上,而服务器的CPU又有比较多的余量的场景。

1)COMPRESS页压缩

相关文档:dev.mysql.com/doc/refman/…

  • 在MySQL5.7版本之前就提供的页压缩功能,在创建表时指定 ROW_FORMAT = COMPRESS,并通过 KEY_BLOCK_SIZE 设置压缩页的大小

  • 存在设计上的缺陷,有可能会导致性能下降明显,然后其设计初衷是为了提升性能,引入了“日志即数据”的理念

    • MySQL中如何进行大文本存储压缩

    • MySQL中如何进行大文本存储压缩

    • 对于压缩页的数据修改,并不会直接修改页本身,而是将修改日志存储在这个页中,这确实对数据的变更比较友好,不用每次修改都进行压缩/解压

    • 对于数据的读取,压缩的数据是无法直接读取的,所以这种算法会在内存中保留一个解压后的16K的页,以供数据的读取

    • 这就导致了一个页在缓冲池中可能会有两个版本(压缩版和非压缩版),引发一个非常严重的问题,即缓冲池中能缓存的页的数量大大的减少了,从而可能会导致数据库的性能极大的下降

2)TPC(透明页压缩)
  • 工作原理:写入页面时,使用指定的压缩算法对页面进行压缩,压缩后写入磁盘,其中通过打孔机制从页面末尾释放空(需要操作系统支持空洞特性)

  • ALTER TABLE xxx COMPRESSION = ZLIB 可以启用TPC页压缩功能,但这只是对后续增量数据进行压缩,如果期望对整个表进行压缩,则需要执行 OPTIMIZE TABLE xxx

  • 实现过程:一个压缩页在缓冲池中都是一个16K的非压缩页,只有在数据刷盘的时候,会进行一次压缩,压缩后剩余的空间会用 0x00 填满,利用文件系统的空洞特性(hole punch)对文件进行裁剪,释放 0x00 占用的稀疏空间

MySQL中如何进行大文本存储压缩

  • TPC虽好,但它依赖操作系统的 Hole Punch 特性,且裁剪后的文件大小需要和文件系统块大小对齐(4K)。即假如压缩后的页大小是9K,那么实际占用的空间是12K

列压缩

MySQL目前没有直接针对列压缩的方案,有一个曲线救国的方法,就是在业务层使用MySQL提供的压缩和解压函数来针对列进行压缩和解压操作。也就是如果需要对某一列做压缩,在写入时调用COMPRESS函数对那个列的内容进行压缩,读取的时候,使用UNCOMPRESS函数对压缩过的数据进行解压。

  • 使用场景:针对表中某些列数据长度比较大的情况,一般是 varchar、text、blob、JSON等数据类型

  • 相关函数:

    • 压缩函数:COMPRESS()

    • 解压缩函数:UNCOMPRESS()

    • 字符串长度函数:LENGTH()

    • 未解压字符串长度函数:UNCOMPRESSED_LENGTH()

  • 测试

    • 插入数据:insert into xxx (content) values (compress('xxx....'))

    • 读取压缩的数据:select c_id, uncompressed_length(c_content) uncompress_len, length(c_content) compress_len from xxx

MySQL中如何进行大文本存储压缩

为什么innodb提供的都是基于页面的压缩技术?

  • 记录压缩:每次读写记录的时候,都要进行压缩或解压,过度依赖CPU的计算能力,性能相对会比较差

  • 表空间压缩:压缩效率高,但要求表空间文件是静态不增长的,这对于我们大部分的场景都是不适用的

  • 页面压缩:既能提升效率,又能在性能中取得一定的平衡

总结

  • 对于一些性能不敏感的业务表,如日志表、监控表、告警表等,这些表只期望对存储空间进行优化,对性能的影响不是很关注,可以使用COMPRESS页压缩

  • 对于一些比较核心的表,则比较推荐使用TPC压缩

  • 列压缩过度依赖CPU,性能方面会稍差,且对业务有一定的改造成本,不够灵活,需要评估影响范围,做好切换的方案。好处是可以由业务端决定哪些数据需要压缩,并控制解压操作

  • 对页面进行压缩,在业务侧不用进行什么改动,对线上完全透明,压缩方案也非常成熟

为什么要进行数据压缩?

  • 由于处理器和高速缓存存储器的速度提高超过了磁盘存储设备,因此很多时候工作负载都是受限于磁盘I/O。数据压缩可以使数据占用更小的空间,可以节省磁盘I/O、减少网络I/O从而提高吞吐量,虽然会牺牲部分CPU资源作为代价

  • 对于OLTP系统,经常进行update、delete、insert等操作,通过压缩表能够减少存储占用和IO消耗

  • 压缩其实是一种平衡,并不一定是为了提升数据库的性能,这种平衡取决于解压缩带来的收益和开销之间的一种权衡,但压缩对存储空间来说,收益无疑是很大的

简单测试

innodb透明页压缩(TPC)

测试数据

1)创建表
  • create table table_origin ( ...... ) comment '测试原表';

  • create table table_compression_zlib ( ...... ) comment '测试压缩表_zlib' compression = 'zlib';

  • create table table_compression_lz4 ( ...... ) comment '测试压缩表_lz4' compression = 'lz4';

2)往表中写入10w行测试数据

压缩率

SELECT NAME, FS_BLOCK_SIZE, FILE_SIZE, ALLOCATED_SIZE
FROM information_schema.INNODB_TABLESPACES WHERE NAME like 'test_compress%';

MySQL中如何进行大文本存储压缩

  • FS_BLOCK_SIZE:文件系统块大小,也就是打孔使用的单位大小

  • FILE_SIZE:文件的表观大小,表示文件的最大大小,未压缩

  • ALLOCATED_SIZE:文件的实际大小,即磁盘上分配的空间量

压缩率:

  • zlib:1320636416/3489660928 = 37.8%

  • lz4:1566949376/3489660928 = 45%

耗时

  • 循环插入10w条记录

    • 原表:918275 ms

    • zlib:878540 ms

    • lz4:875259 ms

  • 循环查询10w条记录

    • 原表:332519 ms

    • zlib:373387 ms

    • lz4:343501 ms

以上就是“MySQL中如何进行大文本存储压缩”这篇文章的所有内容,感谢各位的阅读!相信大家阅读完这篇文章都有很大的收获,小编每天都会为大家更新不同的知识,如果还想学习更多的知识,请关注编程网数据库频道。

您可能感兴趣的文档:

--结束END--

本文标题: MySQL中如何进行大文本存储压缩

本文链接: https://www.lsjlt.com/news/195856.html(转载时请注明来源链接)

有问题或投稿请发送至: 邮箱/279061341@qq.com    QQ/279061341

本篇文章演示代码以及资料文档资料下载

下载Word文档到电脑,方便收藏和打印~

下载Word文档
猜你喜欢
  • MySQL中如何进行大文本存储压缩
    今天小编给大家分享一下MySQL中如何进行大文本存储压缩的相关知识点,内容详细,逻辑清晰,相信大部分人都还太了解这方面的知识,所以分享这篇文章给大家参考一下,希望大家阅读完这篇文章后有所收获,下面我们一起来...
    99+
    2023-02-13
    mysql
  • Android应用中如何对文件进行压缩与解压缩
    Android应用中如何对文件进行压缩与解压缩?相信很多没有经验的人对此束手无策,为此本文总结了问题出现的原因和解决方法,通过这篇文章希望你能解决这个问题。使用场景当我们在应用的Assets目录中需要加入文件时,可以直接将源文件放入,但这样...
    99+
    2023-05-31
    android roi
  • mysql中如何进行数据压缩性能对比
    这篇文章给大家分享的是有关mysql中如何进行数据压缩性能对比的内容。小编觉得挺实用的,因此分享给大家做个参考,一起跟随小编过来看看吧。1. 测试环境1.1 软硬件一台 64位 2.6.18-92 内核Linux开发机,4G内存,4个280...
    99+
    2023-06-25
  • 大数据中常见的文件存储格式以及hadoop中支持的压缩算法
    在大数据中常见的文件存储格式有:1. 文本文件(Text File):以纯文本的形式保存数据,例如CSV格式或JSON格式。2. 序...
    99+
    2023-10-11
    大数据
  • C语言数组中如何压缩存储特殊矩阵
    小编给大家分享一下C语言数组中如何压缩存储特殊矩阵,相信大部分人都还不怎么了解,因此分享这篇文章给大家参考一下,希望大家阅读完这篇文章后大有收获,下面让我们一起去了解一下吧!1.数组的定义数组是由n个相同类型的数据元素构成的有限序列,每个数...
    99+
    2023-06-21
  • 如何在Android中对字符串进行压缩
    这期内容当中小编将会给大家带来有关如何在Android中对字符串进行压缩,文章内容丰富且以专业的角度为大家分析和叙述,阅读完这篇文章希望大家可以有所收获。使用到的类库GZIPOutputStream代码示例import java....
    99+
    2023-05-30
    android 字符串
  • Java 中如何对图片进行压缩处理
    问题背景 图片过大时,会造成页面卡顿甚至于报错,而且现在页面,接口,很多地儿都有报文传输的最大限制要求,另外不知道各位有没有遇到过页面渲染比较大的 base64 图片时,会非常的卡顿。所以,我们必须对用户上传的原始图片进行压缩处理。 为何...
    99+
    2023-08-31
    java 开发语言 压缩图片
  • Linux下如何进行文件或者目录的打包及压缩、解压
    这篇文章将为大家详细讲解有关Linux下如何进行文件或者目录的打包及压缩、解压,文章内容质量较高,因此小编分享给大家做个参考,希望大家阅读完这篇文章后对相关知识有一定的了解。Linux下对于文件或者目录的打包及压缩、解压等操作压缩tar –...
    99+
    2023-06-05
  • 云虚拟机如何对FTP空间内的文件进行压缩或解压
    云虚拟机对FTP空间内文件进行压缩或解压的方法:1、登录云虚拟机控制台;2、点击左侧“云虚拟主机”;3、选择“云虚拟主机管理”;4、在列表中找到需要操作的云虚拟主机,点击右侧“管理”;5、在操作管理的文件系统设置中点击“压缩解压缩”;6、最...
    99+
    2022-10-24
  • 如何在Android应用中对图片进行压缩
    本篇文章给大家分享的是有关如何在Android应用中对图片进行压缩,小编觉得挺实用的,因此分享给大家学习,希望大家阅读完这篇文章后可以有所收获,话不多说,跟着小编一起来看看吧。1、质量压缩法设置bitmap options属性,降低图片的质...
    99+
    2023-05-31
    android 中对 roi
  • 如何使用phonegap进行本地存储
    这篇文章主要介绍了如何使用phonegap进行本地存储,具有一定借鉴价值,感兴趣的朋友可以参考下,希望大家阅读完这篇文章之后大有收获,下面让小编带着大家一起了解一下。实例如下:<!DOCTYPE&nb...
    99+
    2022-10-19
  • PHP中如何进行大数据存储和分析?
    PHP是一门广泛应用于Web开发领域的编程语言,其开放源代码的特性和易于学习使用的优点,使得PHP具有被广泛使用的特点。随着互联网的快速发展,数据的增长和存储已经成为了一个越来越大的难题。在这背景下,PHP开发者需要掌握大数据存储和分析的技...
    99+
    2023-05-21
    数据分析 PHP 大数据存储
  • PHP中如何进行模型融合和模型压缩?
    随着人工智能的快速发展,模型的复杂度越来越高,对资源的使用也越来越多。在PHP中,如何进行模型融合和模型压缩成为了一个热门话题。模型融合是指将多个单一模型融合在一起,从而提高整体的准确率和效率。模型压缩则是将模型的大小和计算复杂度减小,以节...
    99+
    2023-05-23
    模型融合 模型压缩 PHP
  • css如何设置文本首行缩进2字符
    本篇内容介绍了“css如何设置文本首行缩进2字符”的有关知识,在实际案例的操作过程中,不少人都会遇到这样的困境,接下来就让小编带领大家学习一下如何处理这些情况吧!希望大家仔细阅读,能够学有所成!具体操作步骤:给代码中的P标签添加text-i...
    99+
    2023-07-04
  • PHP中如何进行自适应系统和网络压缩?
    PHP是一种广泛应用于Web应用和动态网页开发的脚本语言。它可以轻松地创建丰富的网站和动态Web应用。然而,在处理大量数据时,应用程序可能会遇到一些性能和效率方面的问题。其中最常见的问题是系统的自适应和网络压缩。本文将探讨如何在PHP中进行...
    99+
    2023-05-21
    PHP 自适应系统 网络压缩
  • 如何解决 Ubuntu 中文乱码问题——文本、MP3和Rar压缩文件及aMule
    由于 Linux 中默认使用的编码是 UTF-8,与 Windows 的默认中文编码不同,因此在使用中会出现中文乱码问题。下面我们一起来看如何解决 Ubuntu 11.04 的一些中文乱码问题。 1. 解决文本乱码问...
    99+
    2022-06-03
    gedit Linux MP3 rar Ubuntu 中文乱码 压缩文件
  • 如何在DOS命令行中使用HaoZip命令压缩文件
    如何在DOS命令行中使用HaoZip命令压缩文件?针对这个问题,这篇文章详细介绍了相对应的分析和解答,希望可以帮助更多想解决这个问题的小伙伴找到更简单易行的方法。配置环境变量右键我的电脑——属性——高级系统设置——高级——环境变量,在系统变...
    99+
    2023-06-08
  • 如何在Windows系统中使用压缩归档文件安装MySQL
    本篇文章给大家分享的是有关如何在Windows系统中使用压缩归档文件安装MySQL,小编觉得挺实用的,因此分享给大家学习,希望大家阅读完这篇文章后可以有所收获,话不多说,跟着小编一起来看看吧。使用压缩文档安...
    99+
    2022-10-18
  • 如何在 ASP 中使用 http shell 对象进行数据压缩?
    ASP是一种常用的Web开发语言,其灵活性和易用性使其成为了许多开发者的首选。在ASP中,使用http shell对象进行数据压缩是一种非常常见的操作,本文将介绍如何在ASP中使用http shell对象进行数据压缩。 一、什么是http ...
    99+
    2023-06-02
    http shell 对象
  • 如何使用SQL语句在MongoDB中实现数据压缩和存储优化?
    如何使用SQL语句在MongoDB中实现数据压缩和存储优化?摘要:随着数据量的不断增大,如何有效地进行数据压缩和存储优化成为了数据库管理的重要问题。本文将介绍如何使用SQL语句在MongoDB中实现数据压缩和存储优化,并提供了具体的代码示例...
    99+
    2023-12-17
    MongoDB SQL语句 数据优化
软考高级职称资格查询
编程网,编程工程师的家园,是目前国内优秀的开源技术社区之一,形成了由开源软件库、代码分享、资讯、协作翻译、讨论区和博客等几大频道内容,为IT开发者提供了一个发现、使用、并交流开源技术的平台。
  • 官方手机版

  • 微信公众号

  • 商务合作