我的编程空间,编程开发者的网络收藏夹
学习永远不晚

mysql 5.7有哪些优缺点

短信预约 -IT技能 免费直播动态提醒
省份

北京

  • 北京
  • 上海
  • 天津
  • 重庆
  • 河北
  • 山东
  • 辽宁
  • 黑龙江
  • 吉林
  • 甘肃
  • 青海
  • 河南
  • 江苏
  • 湖北
  • 湖南
  • 江西
  • 浙江
  • 广东
  • 云南
  • 福建
  • 海南
  • 山西
  • 四川
  • 陕西
  • 贵州
  • 安徽
  • 广西
  • 内蒙
  • 西藏
  • 新疆
  • 宁夏
  • 兵团
手机号立即预约

请填写图片验证码后获取短信验证码

看不清楚,换张图片

免费获取短信验证码

mysql 5.7有哪些优缺点

这篇文章主要讲解了“mysql 5.7有哪些优缺点”,文中的讲解内容简单清晰,易于学习与理解,下面请大家跟着小编的思路慢慢深入,一起来研究和学习“mysql 5.7有哪些优缺点”吧!

原理

innodb的透明页IO压缩,利用punch hole和数据压缩来实现。在内存中是一个正常的页,只有在写到磁盘时,才进行压缩。调用函数os_file_io_complete进行punch hole操作,os_file_io_complete调用的是fallocate()操作系统函数,并且使用 FALLOC_FL_PUNCH_HOLE | FALLOC_FL_KEEP_SIZE标签,回收磁盘上页的空闲block。具体方法是先将压缩后的内容写入到磁盘,此时磁盘上页仍然是16K,写完成后,调用fallocate函数回收磁盘页中空闲的block,该block以系统block_size为单位。

优点

1、内存中方便管理,只有正常页,不存在压缩后的页

2、更加简单灵活的使用压缩算法

3、代码上可以针对各种类型的页进行压缩

缺点

引用淘宝数据库内核月报中内容:

  • 无法完美压缩:例如9KB的数据可能需要12kb来存储,取决于block size;

  • 无法压缩Buffer pool, 这是和传统innodb压缩相比,以前的压缩方式可以在内存中只存放压缩页拷贝 (然而也有可能同时存在压缩和解压页),因此用户可能需要去购买iops更高的设备,而oracle正好也卖这些….

  • punch hole 可能产生的文件碎片化,底层的文件管理更加复杂;

  • 对innodb文件做punch hole可能带来的后果是,使得每个文件的page变成一个独立的segment,文件系统需要单独的journal和metadata来管理。另外也有可能有性能问题:可能比non-sparse的写操作昂贵五倍 (这依赖于具体的内核);

  • 删除一个拥有几百万个段管理对象的数据文件带来的开销会非常昂贵。

mariadb

mysql的innodb中仅支持2种压缩算法,而mariadb的XTRADB中可支持zlib、lz4、lzo、lzma、bzip2、snappy等5种算法。除了,zlib、lz4外,其他的需要下载代码进行编译安装。

感谢各位的阅读,以上就是“mysql 5.7有哪些优缺点”的内容了,经过本文的学习后,相信大家对mysql 5.7有哪些优缺点这一问题有了更深刻的体会,具体使用情况还需要大家实践验证。这里是亿速云,小编将为大家推送更多相关知识点的文章,欢迎关注!

免责声明:

① 本站未注明“稿件来源”的信息均来自网络整理。其文字、图片和音视频稿件的所属权归原作者所有。本站收集整理出于非商业性的教育和科研之目的,并不意味着本站赞同其观点或证实其内容的真实性。仅作为临时的测试数据,供内部测试之用。本站并未授权任何人以任何方式主动获取本站任何信息。

② 本站未注明“稿件来源”的临时测试数据将在测试完成后最终做删除处理。有问题或投稿请发送至: 邮箱/279061341@qq.com QQ/279061341

mysql 5.7有哪些优缺点

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

下载Word文档

猜你喜欢

mysql行锁的优缺点有哪些

这篇文章给大家分享的是有关mysql行锁的优缺点有哪些的内容。小编觉得挺实用的,因此分享给大家做个参考,一起跟随小编过来看看吧。1、行锁的优势:锁的粒度小,发生锁冲突的概率低;处理并发的能力强。在很多线程请求不同记录时减少冲突锁。事务回滚时
2023-06-15

Docker有哪些优缺点

今天小编给大家分享一下Docker有哪些优缺点的相关知识点,内容详细,逻辑清晰,相信大部分人都还太了解这方面的知识,所以分享这篇文章给大家参考一下,希望大家阅读完这篇文章后有所收获,下面我们一起来了解一下吧。Docker解决的问题:由于不同
2023-06-27

memSQL有哪些优缺点

MemSQL的优点包括:1. 高性能:MemSQL是一个内存中的数据库,可以提供极高的读写性能和低延迟查询。它可以通过在内存中存储和处理数据来加速数据访问和查询。2. 实时分析:MemSQL支持实时数据分析,可以在大规模数据集上进行复杂的分
2023-09-13

Mustache有哪些优缺点

优点:简单易用:Mustache的语法非常简单,易于学习和使用。跨平台:Mustache是一种跨平台的模板引擎,可以用于多种编程语言,如JavaScript、Java、Python等。可读性强:Mustache模板具有良好的可读性,易于
2023-10-23

MySQL表分区的优缺点有哪些

MySQL表分区的优点包括:1. 提高查询性能:通过将数据分散存储在多个分区中,可以实现更快的查询性能。当查询仅涉及到一个或几个分区时,MySQL只会扫描所需的分区,而不需要扫描整个表。2. 提高维护效率:通过分区可以将数据划分为更小的块,
2023-10-12

angularjs的优缺点有哪些

这篇文章主要介绍angularjs的优缺点有哪些,文中介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们一定要看完!谈到流行的开源web app框架,那一定少不了angularjs,angularjs能够解决阻碍单页应用程序开发的各种挑战
2023-06-14

java swing有哪些优缺点

Java Swing是Java平台上的一个GUI工具包,具有以下优点和缺点。优点:1. 跨平台性:Java Swing可以在不同的操作系统上运行,保持相同的用户界面和功能。2. 定制性强:Swing提供了许多自定义组件和布局管理器,可以根据
2023-08-25

MemSQL的优缺点有哪些

MemSQL是一种内存数据库管理系统,它具有以下优点和缺点:优点:高性能:MemSQL是基于内存的数据库,能够提供快速的数据读写操作。它支持并行处理和分布式架构,能够处理大规模数据集和高并发请求。实时分析:MemSQL支持实时数据分析和
2023-10-24

muduo库有哪些优缺点

muduo库是一个基于C++的高性能网络编程库,它主要用于开发服务器应用程序。以下是muduo库的一些优点和缺点:优点:1. 高性能:muduo库采用了多线程的设计,可以充分发挥多核处理器的性能,提高服务器的并发处理能力。2. 异步编程模型
2023-08-24

mysql存储过程的优缺点有哪些

这篇文章给大家介绍mysql存储过程的优缺点有哪些,内容非常详细,感兴趣的小伙伴们可以参考借鉴,希望对大家能有所帮助。1、优点(1)处理封装在易于使用的单元中,简化了复杂的操作;(2)由于不需要重复建立一系列处理步骤,因此保证了数据的完整性
2023-06-15

编程热搜

目录