【mysql】索引、事务、日志、备份

本文涉及的产品
RDS MySQL Serverless 基础系列,0.5-2RCU 50GB
云数据库 RDS MySQL,集群系列 2核4GB
推荐场景:
搭建个人博客
RDS MySQL Serverless 高可用系列,价值2615元额度,1个月
简介: 文章目录前言一、索引1.1 概念1.2 分类/操作1.3 应用场景

一、索引

1.1 概念

  • 功能:查找索引后,直接指向数据所在的物理地址
  • 意义:加速查询速度,为字段排序
  • 副作用:额外占用磁盘空间,修改数据时需要同步修改索引(较麻烦)

1.2 分类/操作

类别/操作 创建方法
普通索引 alter table 表 add index 字段_index (字段);
唯一索引 alter table 表 add unique index 字段_index (字段);
主键索引 alter table 表 add primary key;
组合索引 alter table 表 add index 索引名 (字段1,…);
全局索引 alter table 表 add fulltext 索引名 (字
全局索引 alter table 表 add fulltext 索引名 (字段);
删除索引 alter table 表 drop index(索引名);
索引分析 explain select * from 字段;

1.3 应用场景

  • 唯一性较好的字段
  • 超过300行的字段
  • 经常表连接的字段
  • 不常更新的字段
  • 小字段

二、事务

2.1 概念/特性

  • 概念:一个不可分割的操作序列
  • 特性:原子性(无法分割),隔离性(独立,保证数据安全),一致性(事务的目的),持久性(最终效果)

2.2 隔离级别

级别 效果 隔离级别全称
ru:未提交读 允许脏读 read uncommitted
rc:已提交读 不允许脏读 read committed
rr:可重复读 不允许脏读,可重复读(mysql默认级别) repeatable read
串行读 一次只允许有一个事务 serializable
  • 脏读:一个事务可以看到其他事务未提交的修改
  • 不可重复读:第一个事务未结束时,恰巧别的事务修改了对应的数据,那么第一个事务刷新再读取的时候,数据就会变为被修改后的数据(可重复读:确保一个事务中执行的select语句都能得到相同结果)
  • 幻读:第一个事务修改所有数据的同时,恰巧别的事务添加了新的事务,此时第一个事务并不会修改别的事务刚添加的数据
  • 丢失更新:第一个事务读取数据修改的同时,第二个事务也在打开修改数据,此时第二个事务先保存,第一个事务后保存,那么第一个事务就会把第二个事务修改的数据覆盖掉,等同于第二个事务没有进行任何操作
  • 注:mysql默认的事务处理级别是repeatable read (可重复读), 而Oracle和SQL Server是 read committed(已提交读) 。

2.3 命令

命令 效果
begin 开启事务
commit 提交事务
rollback 回滚事务到初始
rollback to 快照点名称 回滚事务到某个快照点
savepoint 快照点名称 保存快照点
自动提交事务功能 set autocommit=1;(0为关,默认开启)
全局事务隔离级别 set global transaction isolation level 隔离级别;
当前会话隔离级别 set session transaction isolation level 隔离级别;
查询全局隔离级别 show global variables like ‘%isolation%’ ;
查询会话隔离级别 show session variables like ‘%isolation%’;

三、日志

  • 日志是维护中非常重要的存在,通过日志,我们可以快速得到自己想要的东西,比如错误日志产生,效率低下,数据恢复等

3.1 开启日志

  • mysql的日志存储路径默认为:/usr/local/mysql/data,默认配置文件为:/etc/my.cnf配置文件中的[mysqld]子配置中
日志分类 开启配置语句 默认情况
错误日志 log-error=存储路径 默认开启
二进制日志 log-bin=mysql-bin 默认开启
慢查询日志 slow_query_log=ON(打开)long_query_time=2(慢查询时间)slow_query_log_file=存储路径(存储位置) 默认关闭
慢查询日志 set global slow_query_log=ON;(在mysql中开启慢查询) 默认关闭
通用日志 general_log=ON(打开)general_log_file=存储路径(存储位置) 默认关闭

3.2 确认日志

  • mysql中查看日志是否开启
日志 命令
二进制日志 show variables like ‘log_bin%’;
慢查询日志 show variables like ‘%slow%’;
慢查询时间设置 show variables like ‘long_query_time%’;
通用日志 show variables like ‘general%’;

四、备份与恢复

4.1 完全备份

  • 特点:备份/恢复时间长,备份数据全面(对数据库进行完整的备份与恢复)

4.1.1 冷备份/恢复

  • 特点:必须关闭mysql服务才可以进行冷备份,在大多数生产环境中是不允许停止服务的(相对逻辑备份快)
#备份
systemctl stop mysqld                         #关闭mysql数据库服务
tar zcf /mnt/mysql_all-$(date +%F).tar.gz /usr/local/mysql/data     #压缩备份mysql数据并重命名为.tar.gz结尾
#恢复
tar zxf mysql_all-2022-06-05.tar.gz -C /mnt               #解压数据压缩包
\cp -rf ./data /usr/local/mysql/                    #将解压后的数据包移动/复制过去即可
systemctl start mysqld                          #启动mysql数据库服务

4.1.2 逻辑备份/恢复

  • 特点:不用关闭mysql的服务也能备份,恢复时候根据存储的mysql语句一条条恢复(相对较慢)
  • 工具:利用MySQL自带的备份工具mysqldump进行备份与恢复
mysqldump -u root -p密码 --databases 库 >备份路径                #备份库
mysqldump -u root -p密码 [-d] 库名 [表名1] [表名2] >备份路径              #备份表(-d表示只备份数据表结构)
查看备份文件:grep -v "^--" 备份路径|grep -v "^-"|grep -v "^$"         #通过过滤查看备份的内容
mysql -u root -p密码 <备份文件                          #恢复库
mysqldump -u root -p密码 库 <备份文件                      #恢复表

4.2 增量备份

  • 特点:通过二进制日志间接实现(flush logs刷新日志),没有冗余、备份时间短、恢复时间长

4.2.1 备份类别

  • 先在/etc/my.cnf中[mysqld]子配置中设置log-bin=mysql-bin开启二进制日志
  • 然后再:binlog_format = MIXED指定二进制日志的记录格式为混合模式
类型 特点
STATEMENT 基于sql语句备份,较快,高并发是容易出错(默认是这个类型)
ROW 基于数据库行内容备份,较慢,安全准确
MIXED 混合模式,兼有两者优点,生产环境一般都用这个

4.2.2 备份命令

mysqladmin -u root -p密码 flush-logs                  #备份日志
mysqlbinlog --no-defaults --base64-output=decode-rows -v 备份路径   #查看备份

4.2.3 恢复类别

类别 命令
一般恢复 mysqlbinlog --no-defaults 备份路径
位置恢复 mysqlbinlog --no-defaults --start-position=‘位置点’ --stop-position=‘位置点’ 备份路径
时间恢复 mysqlbinlog --no-defaults --start-datetime=‘时间点’ --stop-datetime=‘时间点’ 备份路径

4.3 差异备份

  • 由于差异备份会产生冗余较大的情况,因此很少用到差异备份

五、思维导图

相关实践学习
如何在云端创建MySQL数据库
开始实验后,系统会自动创建一台自建MySQL的 源数据库 ECS 实例和一台 目标数据库 RDS。
全面了解阿里云能为你做什么
阿里云在全球各地部署高效节能的绿色数据中心,利用清洁计算为万物互联的新世界提供源源不断的能源动力,目前开服的区域包括中国(华北、华东、华南、香港)、新加坡、美国(美东、美西)、欧洲、中东、澳大利亚、日本。目前阿里云的产品涵盖弹性计算、数据库、存储与CDN、分析与搜索、云通信、网络、管理与监控、应用服务、互联网中间件、移动服务、视频服务等。通过本课程,来了解阿里云能够为你的业务带来哪些帮助 &nbsp; &nbsp; 相关的阿里云产品:云服务器ECS 云服务器 ECS(Elastic Compute Service)是一种弹性可伸缩的计算服务,助您降低 IT 成本,提升运维效率,使您更专注于核心业务创新。产品详情: https://www.aliyun.com/product/ecs
相关文章
|
12天前
|
SQL 存储 缓存
MySQL进阶突击系列(02)一条更新SQL执行过程 | 讲透undoLog、redoLog、binLog日志三宝
本文详细介绍了MySQL中update SQL执行过程涉及的undoLog、redoLog和binLog三种日志的作用及其工作原理,包括它们如何确保数据的一致性和完整性,以及在事务提交过程中各自的角色。同时,文章还探讨了这些日志在故障恢复中的重要性,强调了合理配置相关参数对于提高系统稳定性的必要性。
|
27天前
|
SQL 关系型数据库 MySQL
【赵渝强老师】MySQL的全量日志文件
MySQL全量日志记录所有操作的SQL语句,默认禁用。启用后,可通过`show variables like %general_log%检查状态,使用`set global general_log=ON`临时开启,执行查询并查看日志文件以追踪SQL执行详情。
|
29天前
|
关系型数据库 MySQL 数据库
【赵渝强老师】MySQL的binlog日志文件
MySQL的binlog日志记录了所有对数据库的更改操作(不包括SELECT和SHOW),主要用于主从复制和数据恢复。binlog有三种模式,可通过设置binlog_format参数选择。示例展示了如何启用binlog、设置格式、查看日志文件及记录的信息。
|
28天前
|
SQL 关系型数据库 MySQL
【赵渝强老师】MySQL的慢查询日志
MySQL的慢查询日志用于记录执行时间超过设定阈值的SQL语句,帮助数据库管理员识别并优化性能问题。通过`mysqldumpslow`工具可查看日志。本文介绍了如何检查、启用及配置慢查询日志,并通过实例演示了慢查询的记录与分析过程。
108 3
|
1月前
|
存储 Oracle 关系型数据库
【赵渝强老师】MySQL的撤销日志文件和错误日志文件
本文介绍了MySQL的物理存储结构,重点讲解了InnoDB存储引擎中的撤销日志文件(undo log)和错误日志文件。从MySQL 8.0开始,默认生成两个10MB的undo表空间文件,并支持动态扩容和收缩。错误日志文件记录了MySQL启动、运行、关闭过程中的问题,通过示例展示了如何查看和使用这些日志。
|
1月前
|
XML 安全 Java
【日志框架整合】Slf4j、Log4j、Log4j2、Logback配置模板
本文介绍了Java日志框架的基本概念和使用方法,重点讨论了SLF4J、Log4j、Logback和Log4j2之间的关系及其性能对比。SLF4J作为一个日志抽象层,允许开发者使用统一的日志接口,而Log4j、Logback和Log4j2则是具体的日志实现框架。Log4j2在性能上优于Logback,推荐在新项目中使用。文章还详细说明了如何在Spring Boot项目中配置Log4j2和Logback,以及如何使用Lombok简化日志记录。最后,提供了一些日志配置的最佳实践,包括滚动日志、统一日志格式和提高日志性能的方法。
271 30
【日志框架整合】Slf4j、Log4j、Log4j2、Logback配置模板
|
6天前
|
监控 安全 Apache
什么是Apache日志?为什么Apache日志分析很重要?
Apache是全球广泛使用的Web服务器软件,支持超过30%的活跃网站。它通过接收和处理HTTP请求,与后端服务器通信,返回响应并记录日志,确保网页请求的快速准确处理。Apache日志分为访问日志和错误日志,对提升用户体验、保障安全及优化性能至关重要。EventLog Analyzer等工具可有效管理和分析这些日志,增强Web服务的安全性和可靠性。
|
2月前
|
XML JSON Java
Logback 与 log4j2 性能对比:谁才是日志框架的性能王者?
【10月更文挑战第5天】在Java开发中,日志框架是不可或缺的工具,它们帮助我们记录系统运行时的信息、警告和错误,对于开发人员来说至关重要。在众多日志框架中,Logback和log4j2以其卓越的性能和丰富的功能脱颖而出,成为开发者们的首选。本文将深入探讨Logback与log4j2在性能方面的对比,通过详细的分析和实例,帮助大家理解两者之间的性能差异,以便在实际项目中做出更明智的选择。
301 3
|
16天前
|
存储 监控 安全
什么是事件日志管理系统?事件日志管理系统有哪些用处?
事件日志管理系统是IT安全的重要工具,用于集中收集、分析和解释来自组织IT基础设施各组件的事件日志,如防火墙、路由器、交换机等,帮助提升网络安全、实现主动威胁检测和促进合规性。系统支持多种日志类型,包括Windows事件日志、Syslog日志和应用程序日志,通过实时监测、告警及可视化分析,为企业提供强大的安全保障。然而,实施过程中也面临数据量大、日志管理和分析复杂等挑战。EventLog Analyzer作为一款高效工具,不仅提供实时监测与告警、可视化分析和报告功能,还支持多种合规性报告,帮助企业克服挑战,提升网络安全水平。
|
2月前
|
存储 缓存 关系型数据库
MySQL事务日志-Redo Log工作原理分析
事务的隔离性和原子性分别通过锁和事务日志实现,而持久性则依赖于事务日志中的`Redo Log`。在MySQL中,`Redo Log`确保已提交事务的数据能持久保存,即使系统崩溃也能通过重做日志恢复数据。其工作原理是记录数据在内存中的更改,待事务提交时写入磁盘。此外,`Redo Log`采用简单的物理日志格式和高效的顺序IO,确保快速提交。通过不同的落盘策略,可在性能和安全性之间做出权衡。
1684 14