本文作者:kris

简单了解MySQL存储引擎-简单了解mysql存储引擎的方法

kris 2025-01-17 18:18:56 3
简单了解MySQL存储引擎-简单了解mysql存储引擎的方法摘要: MySQL存储引擎通常有哪3种?各自分别有什么特点?应用场景是哪些?在当前的后台开发中,MySQL应用非常普遍,企业在选拔Java人才时也会考察求职者诸如性能优化、高可用性、备份、...

MySQL存储引擎通常有哪3种?各自分别有什么特点?应用场景是哪些?

在当前的后台开发中,MySQL应用非常普遍,企业在选拔Java人才时也会考察求职者诸如性能优化、高可用性、备份、集群、负载均衡、读写分离等问题。想要成为高薪Java工程师,一定要熟练掌握MySQL,接下来给大家分享MySQL数据库应用场景知识。

简单了解MySQL存储引擎-简单了解mysql存储引擎的方法

1、单Master

单Master的情况是普遍存在的,对于很多个人站点、初创公司、小型内部系统,考虑到成本、更新频率、系统重要性等问题,系统只依赖一个单例数据库提供服务,基本上已经满足需求。单Master场景下应该关注四点:数据备份(冷备、热备、温备)、数据还原、备份监控、数据文件远程存储。

2、一主一从

考虑一主一从的多数初衷是系统性能和系统高可用性问题,除了单Master场景中的备份工作需要做好以外,还有性能优化、读写分离、负载均衡三项重点工作需要考虑。

3、一主n从

一旦开始考虑一主多从的服务器架构,则证明你的系统对可用性、一致性、性能中一种或者多种的要求比较高。好多系统在开始搭建的时候都会往这个方向看齐,这样“看起来”系统会健壮很多。一主n从关注的重点是:数据一致性、脑裂、雪崩、连接池管理。

4、横向集群

横向集群主要是从业务特性的角度对系统进行切分,最彻底就是切分成了各个子系统,子系统之间通过一些数据同步的方案来把一些核心数据进行共享,以避免跨库调用Join。然后是各种系统接口调用,把大事务拆成小事务,事务之间做好隔离和同步。横向集群学习的重点是表路由、跨库Join、分布式事务。

5、纵向集群

横向集群的切分思路最终是切分子系统,而纵向集群最后遇到的最棘手的问题是扩缩容。纵向集群学习的重点是库路由、分布式主键、扩/缩容。

6、混合模式

混合模式是对以上5种场景中的一个总结,将每个场景中的重点、问题点考虑全了,混合模式下的问题就不是问题。

除了要掌握MySQL数据库知识,Java工程师更要掌握专业的技能,比如面向对象、Java常用的类、库等。

mysql默认的存储引擎是?

mysql默认引擎:mysql-5.1版本之前默认引擎是MyISAM,之后是innoDB

MyISAM是非集聚引擎,支持全文索引;不支持事务;它是表级锁;会保存表的具体行数.

  innoDB是集聚引擎,5.6以后才有全文索引;支持事务;它是行级锁;不会保存表的具体行数.

一般:不用事务的时候,count计算多的时候适合myisam引擎。对可靠性要求高就是用innodby引擎。

mysql默认存储引擎类型有哪些?

​MySQL5.7支持的存储引擎包含 : InnoDB 、MyISAM 、BDB、MEMORY、MERGE、EXAMPLE、NDB Cluster、ARCHIVE、CSV、BLACKHOLE、FEDERATED等。

其中InnoDB和BDB提供事务安全表,其他存储引擎是非事务安全表。Mysql5.5之前的默认存储引擎是MyISAM,5.5之后改为InnoDB。

MySQL的存储引擎为MyISAM不支持事务是什么意思?

MyISAM引擎设计简单,数据以紧密格式存储,所以某些读取场景下性能很好。

但是MyISAM最典型的还是表锁问题,这样会导致长期处于"Locked"状态。而且数据恢复时间长,无事务等问题或短板。

虽然5.1之前MyISAM的读比Innodb快很多,但是在5.1之后,默认引擎已经变为Innodb。

Innodb读写有很大的提高,采用MVCC来支持高并发,针对行加锁,是使用最广泛的存储引擎。

官方建议尽量将MyISAM都换为Innodb。

文章版权及转载声明

作者:kris本文地址:https://www.damoyx.com/p/24441.html发布于 2025-01-17 18:18:56
文章转载或复制请以超链接形式并注明出处大漠游侠网

阅读
分享