首页
学习
活动
专区
工具
TVP
发布
精选内容/技术社群/优惠产品,尽在小程序
立即前往

mysql启用 innodb

基础概念

MySQL中的InnoDB存储引擎是MySQL的默认存储引擎,它提供了事务安全(ACID兼容)的表,并且支持行级锁定和外键。InnoDB设计用于处理大量的短期事务,并提供了高性能和可伸缩性。

优势

  1. 事务支持:InnoDB支持ACID事务,确保数据的完整性和一致性。
  2. 行级锁定:InnoDB使用行级锁定来提高并发性能,允许多个用户同时读取和写入不同的行。
  3. 外键支持:InnoDB支持外键约束,有助于维护数据之间的关联性。
  4. 崩溃恢复:InnoDB具有崩溃恢复功能,可以在系统崩溃后自动恢复数据。
  5. MVCC(多版本并发控制):InnoDB使用MVCC来提高并发性能,允许多个事务同时读取同一行数据而不会相互干扰。

类型

InnoDB存储引擎主要分为以下几种类型:

  1. 共享表空间:所有表的数据和索引都存储在一个共享的表空间文件中。
  2. 独立表空间:每个表都有自己的独立表空间文件,可以单独管理。

应用场景

InnoDB适用于以下场景:

  1. 高并发读写:InnoDB的行级锁定和外键支持使其非常适合高并发读写操作。
  2. 事务处理:InnoDB的事务支持使其非常适合需要事务处理的业务场景,如金融系统、电子商务系统等。
  3. 数据完整性:InnoDB的外键约束和事务支持有助于维护数据的完整性和一致性。

启用InnoDB

要在MySQL中启用InnoDB存储引擎,可以通过以下步骤进行配置:

  1. 修改配置文件: 打开MySQL的配置文件(通常是my.cnfmy.ini),找到[mysqld]部分,添加或修改以下配置:
  2. 修改配置文件: 打开MySQL的配置文件(通常是my.cnfmy.ini),找到[mysqld]部分,添加或修改以下配置:
  3. 重启MySQL服务: 修改配置文件后,重启MySQL服务以使更改生效。
  4. 重启MySQL服务: 修改配置文件后,重启MySQL服务以使更改生效。
  5. 或者
  6. 或者
  7. 验证InnoDB启用: 登录到MySQL数据库,执行以下SQL语句来验证InnoDB是否已启用:
  8. 验证InnoDB启用: 登录到MySQL数据库,执行以下SQL语句来验证InnoDB是否已启用:
  9. 在结果中,应该能看到InnoDB引擎,并且Support列显示为YES

常见问题及解决方法

  1. InnoDB表空间不足
    • 问题:InnoDB表空间不足会导致无法创建新表或插入大量数据。
    • 解决方法:增加InnoDB表空间大小,可以通过修改配置文件中的innodb_data_file_path参数来实现。
    • 解决方法:增加InnoDB表空间大小,可以通过修改配置文件中的innodb_data_file_path参数来实现。
    • 然后重启MySQL服务。
  • InnoDB性能问题
    • 问题:在高并发环境下,InnoDB可能会出现性能瓶颈。
    • 解决方法:优化InnoDB配置,如调整innodb_buffer_pool_sizeinnodb_log_file_size等参数,或者使用SSD硬盘来提高I/O性能。
    • 解决方法:优化InnoDB配置,如调整innodb_buffer_pool_sizeinnodb_log_file_size等参数,或者使用SSD硬盘来提高I/O性能。
    • 然后重启MySQL服务。

参考链接

通过以上步骤和配置,你可以成功启用和优化InnoDB存储引擎,以满足各种高并发和事务处理的需求。

页面内容是否对你有帮助?
有帮助
没帮助

相关·内容

Mysql-InnoDB 系列】InnoDB 架构

封面图片来自:mysql官方文档,8.0版本,InnoDB Architecture。 一 概述 ? 如上图所示,mysqlInnoDB存储引擎架构,包括了内存架构和磁盘架构两部分。...本章将阐述Mysql InnoDB的架构中的组成部分,并在后续系列文章中详细描述各部分的细节。...了解如何利用缓冲池将频繁访问的数据保存在内存中,是MySQL调优的一个重要方面。 ? 2.2 修改缓冲区 修改缓冲区是一个特殊的数据结构,用于缓存不在缓冲池中的那些二级索引页的变更。...MySQL 8.0.20版本之前,双写缓冲区存储空间归属于InnoDB的系统表空间。MySQL 8.0.20开始,双写表空间存储区域放在了双写文件中。...MySQL以循环方式写入重做日志文件。重做日志中的数据按照受影响的记录进行编码,这些数据统称为重做。重做日志的数据传递由不断增加的LSN值表示。

1.2K10
  • MySQL InnoDB引擎

    原理分析 # 逻辑存储引擎 InnoDB的逻辑存储结构如下图所示: 表空间 表空间是InnoDB存储引擎逻辑结构的最高层, 如果用户启用了参数 innodb_file_per_table(在8.0版本中默认开启...# 架构 # 概述 MySQL5.5 版本开始,默认使用InnoDB存储引擎,它擅长事务处理,具有崩溃恢复特性,在日常开发中使用非常广泛。下面是InnoDB架构图,左侧为内存结构,右侧为磁盘结构。...参数设置: show variables like 'innodb_buffer_pool_size'; mysql> show variables like 'innodb_buffer_pool_size...MySQLinnoDB引擎中虽然没有直接支持hash索引,但是给我们提供了一个功能就是这个自适应hash索引。...(在MySQL5.x版本中还包含InnoDB数据字典、undolog等) 参数:innodb_data_file_path mysql> show variables like 'innodb_data_file_path

    1.3K10

    mysql innodb核心

    | 1032 | # Innodb_buffer_pool_pages_dirty | 0 | #脏页比例 Innodb_buffer_pool_pages_total | 8192...| #总的页数 mysql核心特性CR 简称断电恢复 需要用到的 redo 重做日志 inndb log buffer, ib_logfile.n undo 回滚日志 lsn 数据页的lsn号码 最新的...读取表空间头部拿到老的lsn号码 2把修改过的数据页和redo日志加载到内存 3把数据页进行前滚 4调用数据页头上两个db_trx_id , db_roll_ptr进行undo回滚 ib buffer pool mysql...核心参数 innodb_buffer_pool_size 是mysql中最大的一块内存结构设置是物理内存50%-75% innodb_buffer_pool_chunk_size 它是一个分配单元大小...自动回收的机制 innodb_purge_rseg_truncate_frequency 触发自动回收条件 ,单位是检测次数 innodb_undo_directory undo日志的位置 io innodb_io_capacity

    1.3K41

    MySQL系列 | MySQLInnoDB

    数据库和实例: 数据库:物理操作文件系统或其他形式文件类型的集合; 实例:MySQL 数据库由后台线程以及一个共享内存区组成; 02 数据库和实例 在 MySQL 中,实例和数据库往往都是一一对应的,...在 Unix 上,启动一个 MySQL 实例往往会产生两个进程,mysqld 就是真正的数据库服务守护进程,而 mysqld_safe 是一个用于检查和设置 mysqld 启动的控制程序,它负责监控 MySQL...03 MySQL架构 MySQL 从第一个版本发布到现在已经有了 20 多年的历史,在这么多年的发展和演变中,整个应用的体系结构变得越来越复杂: 最上层用于连接、线程处理的部分并不是 MySQL 『发明...05 如何存储表 MySQL 使用 InnoDB 存储表时,会将表的定义和数据索引等信息分开存储,其中前者存储在 .frm 文件中,后者存储在 .ibd 文件中,这一节就会对这两种不同的文件分别进行介绍...当 InnoDB 存储数据时,它可以使用不同的行格式进行存储;MySQL 5.7 版本支持以下格式的行存储方式: Antelope 是 InnoDB 最开始支持的文件格式,它包含两种行格式 Compact

    1.4K20

    MySQL Innodb和Myisam

    自适应哈希索引由innodb_adaptive_hash_index 变量启用,或在服务器启动时关闭 --skip-innodb-adaptive-hash-index。...2、.frm 文件 MySQL 将表的数据字典信息存储在数据库目录中的 .frm 文件中。与其他 MySQL 存储引擎不同, InnoDB它还在系统表空间内自己的内部数据字典中对有关表的信息进行编码。...当 MySQL 删除一个表或一个数据库时,它会删除一个或多个.frm文件以及InnoDB数据字典中的相应条目。 不能InnoDB简单地通过移动.frm 文件在数据库之间移动表。...当启用死锁检测(默认)并且死锁确实发生时,InnoDB检测条件并回滚其中一个事务(受害者)。...SQL语句时MySQL不能确定要扫描的范围,InnoDB表同样会锁全表 索引 MyISAM(堆组织表)使用的是非聚簇索引、索引和文件分开,随机存储,只能缓存索引 InnoDB(索引组织表)使用的聚簇索引

    1.7K20

    MySQL InnoDB Cluster 详解

    这篇文章将详细地介绍MySQL的高可用解决方案—— MySQL InnoDB Cluster。 说到高可用性,首先要了解一下什么是高可用性? ?...InnoDB Cluster管理 让我们看一下如何对InnoDB Cluster进行管理,我将会通过使用MySQL Shell为您展示相关内容。 ?...新节点不存在异于集群的事务 增量恢复适用于: 事务未被清理 新节点不包含空的GTID集 启用GTID 和二进制日志 ? ? ? ? ? 创建配置集群之后,介绍一下监控。 ? ? ? ? ? ? ?...总结: •InnoDB cluster 是MySQL内置的高可用解决方案 •MySQL Clone插件将InnoDB集群的可用性提升到了一个全新的高度!...InnoDB Cluster功能内置了对完整实例配置的支持 •MySQL Shell是开发人员和DBA的统一接口以及InnoDB Cluster的前端管理器 本文比较长,能看完的都是真爱!

    2.2K20

    MySQL InnoDB创建索引

    1.基本概念 1.1 聚簇索引 InnoDB的索引基于B+树实现,每张InnoDB的表都有一个特殊的索引,叫做聚簇索引(Clustered Index),聚簇索引存储了表中的真实数据。...聚簇索引的创建方式一般有三种: 用户定义了主键,那么InnoDB依据主键创建聚簇索引 用户没有定义主键,那么InnoDB根据表上的第一个唯一非空的列创建聚簇索引 如果以上两条都不符合,那么InnoDB会自动指定一个系统列作为聚簇索引...1.3 InnoDB系统列 InnoDB在创建表的时候,除了用户自定义的列之外,还会额外地增加几个隐藏的列,这些列在MySQL Server看来是不可见的,我们称之为系统列。...2.2 重启后创建索引 MySQL重启后,内部索引对象丢失,需要在启动后重新创建相关的索引。MySQL重启后首先会将数据字典内的信息进行读取和初始化,然后根据数据字典的信息进行索引的创建。...还是以上文的表t为例,假设现在MySQL重启,如何在t上构建索引? step1: 创建聚簇索引 无论如何,聚簇索引都会第一个创建。

    5.7K30

    MYSQL INNODB表压缩

    详细说明:https://dev.mysql.com/doc/refman/5.6/en/innodb-physical-record.html 压缩算法 压缩算法采用LZ77,在这个算法下,如果压缩效率好点的话...压缩方法 如果设置了ROW_FORMAT=COMPRESSED,那可以忽略key_block_size设置,这时默认的key_block_size为innodb_page_size值的一半,MYSQL默认设置...和INNODB_CMPMEM_RESET:innodb_buffer_pool中压缩页的信息; INNODB_CMP_PER_INDEX和INNODB_CMP_PER_INDEX_RESET:MYSQL5.7...= dynamic (Mysql5.7新加) 以下参数可能在未来版本中删除: innodb_file_format innodb_file_format_check innodb_file_format_max...InnoDB未压缩的数据页是16K,根据选项组合值,mysql为每个表的.ibd文件使用1kb,2kb,4kb,8kb,16kb页大小,实际的压缩算法并不会受KEY_BLOCK_SIZE值影响,这个值只是决定每个压缩块有多大

    9.4K40

    mysql-innodb-锁

    兼容 不兼容 IX 兼容 兼容 不兼容 不兼容 S 兼容 不兼容 兼容 不兼容 X 不兼容 不兼容 不兼容 不兼容 锁的监控表 查询锁的情况:information_schema下 innodb_trx...事务表 innodb_locks锁表 innodb_lock_wait锁等待表 锁算法 3种锁算法 Record Lock     单行记录加锁 Gap Lock     ...来控制等待时间默认50s innodb_rollback_on_timeout设置超时时是否回滚,默认off,不回滚。...来控制等待时间默认50s 通常来说InnoDB存储引擎选择回滚undo量最小的事务 补充2-自增长与锁 自增长的列,必须是索引,且必须是索引的第一个列...Mysql5.1.22后,提供了轻量级互斥量,在内存中计算自增值提高性能 补充3-外键与锁 innodb外键自动加索引 插入或更新数据时,

    92230

    Mysql存储引擎 innodb

    如果用户启用了参数innodb_file_per_table,则每张表内的数据可以单独放到一个表空间内。...如果启用innodb_file_per_table参数,也需要注意,每张表的表空间存放的只是数据、索引和插入缓冲Bitmap页,其它类的数据,如回滚(undo)信息,插入缓冲索引页、系统事务信息,二次写缓冲等还是存放在原来的共享表空间内...2.1、Compact 行记录格式Compact 行记录是在 MySQL 5.0 中引人的,其设计目标是髙效地存储数据。简单来说,一个页中存放的行数据越多,其性能就越髙。...变长字段的长度最大不可以超过 2 字节,这是因在 MySQL 数据库中 VARCHAR 类型的最大长度限制为 65535。...若 InnoDB 表没有定义主键,每行还会增加一个 6 字节的 rowid 列。Redundant 是 MySQL 5.0 版本之前 InnoDB 的 行 记 录 存 储 方 式,这里就不展开。

    4.8K92

    MySQL InnoDB 存储结构

    MySQL InnoDB 存储结构 InnoDB存储引擎的关键特性包括: 插入缓冲(Insert Buffer) 两次写(Double Write) 自适应哈希索引(Adaptive Hash Index...由上图可以看出,tablespace由segment组成,segment由extend组成,extend由page组成,page由row组成 在MySQL中默认会有一个共享表空间ibdata1,如果设置了...5个区,默认情况下,页的大小为16K,即一个区有64个页 注:在启用innodb_file_per_table之后,创建的表默认大小是96K,每个段开始时有32个页大小的碎片页(fragment page...缓冲池通常是通过LRU算法进行管理,同时还加入midpoint位置,新读取的页,将不会放到链表头端,而是放到midpoint的位置,默认配置下,该位置位于5/8处 参考: 高性能MySQL 第3版 MySQL...技术内幕-InnoDB存储引擎 第2版

    1.5K40

    mysql-innodb-锁

    update加X锁务必加上BEGIN, START TRANSACTION或者 SET AUTOCOMMIT=0select ... lock in share mode 加S锁 在最前 这是读书笔记,Mysql...,innodb系列一共3篇。...Mysql-innodb-B+索引 Mysql-innodb-锁 Mysql-innodb-事务预计20200530) 锁基本概念 锁类型说明锁级别意向共享锁 IS Lock事务想要获得一张表中某几行的数据的共享锁表级别锁意向排他锁...事务表 innodb_locks锁表 innodb_lock_wait锁等待表 锁算法 3种锁算法 Record Lock 单行记录加锁 Gap Lock Gap Lock间隙锁,锁一个范围...Mysql5.1.22后,提供了轻量级互斥量,在内存中计算自增值提高性能 补充3-外键与锁 innodb外键自动加索引 插入或更新数据时, 先使用SELECT…LOCK IN SHARE MODE方式,

    86400

    mysql-innodb-事务

    写在最前 这是读书笔记,Mysqlinnodb系列一共3篇。...Mysql-innodb-B+索引 Mysql-innodb-锁 Mysql-innodb-事务 ACID A:原子性,要么成功,要么失败 C:一致性,事务将数据库从一种状态转换为另一种稳定状态,不违反约束条件...未提交读,会造成脏读,违反持久性D READ COMMITTED 读已提交数据, 会造成幻读 违反一致性C REPEATABLE READ 可重复读,默认隔离级别 SERIALIZABLE 不会使用mysql...log大 commit后 undo加入history list中,供后续purge操作 判断undo页 的使用空间是否小于3/4,是新的undo log 记录到老的undo log后边 binlog MySQL...:5.7版本innodb开启binlog的commit过程 注意: THD是MySQL server层最核心的类 LSN: 日志序列号 重做日志写入的总量

    47000

    Mysql Innodb 性能优化

    概述 innodb 作为最主流使用的 mysql 存储引擎,尤其在新版本的 mysql 中 MyISAM 存储引擎被废除,更加提升了 innodb 如日中天的地位。...那么,作为 mysql 的使用者,如何优化 innodb 使之发挥更强大的性能,就成为了必修课。 2....: 如果分配过大,那么会导致 mysql 占用内存过大,使机器 swap 增多,导致查询变慢 如果分配过小,又会由于缓存无法被充分利用而致使磁盘io增多,降低性能 通过 show engine innodb...而事务提交不会触发写磁盘操作 2. 1 — 事务提交时立刻写入日志文件并刷新磁盘 3. 2 — 每次事务提交时,立即将数据写入文件,但每隔 1 秒刷新一次磁盘 2.5. autocommit 是否自动提交,1 表示启用...mysql innodb 引擎优化 — http://linux.chinaunix.net/techdoc/database/2009/04/28/1109193.shtml。

    1.7K50
    领券