第二十二章 MySQL有哪些“饮鸩止渴”提高性能的方法?

本文主要是介绍第二十二章 MySQL有哪些“饮鸩止渴”提高性能的方法?,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

第二十二章 MySQL有哪些“饮鸩止渴”提高性能的方法?

短连接风暴

在想要短期提高数据库性能的情况下,为什么说可以对短连接进行一些处理 ?

因为连接过程中,权限收集校验是比较耗性能的

在高频短连接访问数据库的情况下,想要短期业务无损地提高服务器性能,怎么做 ?

  • max_connections 设置为合理的参数,因为超过这个连接数的连接会被拒绝,但过大的话,连接了的线程又拿不到 CPU 资源去执行
  • 其次,即使是空闲的线程只要保持连接也会占用一个 connection 位置,所以 kill 掉这些空闲的连接也是一个思路
  • 此外,启用 –skip-grant-tables 参数,可以让整个 MySQL 跳过所有的权限验证阶段,这样也可以减少连接过程的消耗
    • 但是,极力不推荐在外网环境下这么做

你说 kill 掉空闲的线程,那我直接 killshow processlist 中的 sleep 的线程可以吗 ? 为什么 ?

  • 不可以
  • 因为这样子可能是有损的,例如一个执行了多种操作但还没提交的事务,此时会回滚

应该怎么干掉一些空闲的线程 ?

  • 先执行 show processlist 查看哪些线程处于 sleep 中
  • 再看 information_schemainnodb_trx,根据里面的 trx_mysql_thread_id 判断哪些 sleep 的线程处于事务当中,干掉事务外的 sleep 线程
kill connection thread_id

从服务端干掉线程,需要注意什么 ?

  • 客户端下一次请求时才会收到 connection 断开的报错,有的客户端会重新发起连接,而有的客户端会一直报错
  • 因此若 DBA 要干掉线程,应该通知到业务研发团队

你说可以减少连接过程的权限验证,会产生什么问题呢 ? 具体的操作步骤又是怎么样的 ?

  • 没有权限验证,更容易被攻击,尤其是暴露在外网的数据库
  • 跳过权限验证的方法:
    • 重启数据库,并使用 –skip-grant-tables 参数启动
    • 这样,整个 MySQL 会跳过所有的权限验证阶段,包括连接过程和语句执行过程在内
  • 注意:8.0 版本在使用该参数时,MySQL 会默认把 -skip-networking 参数打开,保证这时候数据库只能被本地的客户端连接

慢查询性能问题

在 MySQL 中,哪些情况会引发性能问题的慢查询 ?

  1. 索引没有设计好
  2. SQL 语句没写好
  3. MySQL 选错了索引

方式一:紧急创建索引。如果是表数据较少,直接在主库执行即可,如果表数据量较大,此时应该分三步走

  • 在备库 B 上执行 set sql_log_bin=off,也就是不写 binlog,然后执行 alter table 语句加上索引
  • 执行主备切换
  • 这时候主库是 B,备库是 A。在 A 上执行 set sql_log_bin=off,然后执行 alter table 语句加上索引

方式二:使用 5.7 提供的 query_rewrite (查询重写) 功能

  • 该插件在 MySQL 的 share 包中自带,但需要执行安装才能使用
[root@localhost share]# mysql -uroot -p < install_rewriter.sql
  • query_rewrite 可以把一个语句改写成另外一个语句
insert into query_rewrite.rewrite_rules(pattern, replacement, pattern_database) values ("select * from t where id + 1 = ?", "select * from t where id = ? - 1", "db1");call query_rewrite.flush_rewrite_rules();
  • 如上,如果执行的语句被 pattern 匹配了,会被替代为 replacement 中的语句执行

SQL 维护这一块,平时你们是怎么做的 ?

  • 迭代的时候,上线前,测试环境中启动慢查询配置,模拟线上操作,观察日志中的每类语句输出,留意扫描行数是否与预期一致
  • 如果是新项目,最好还是进行全量回归测试,使用开源工具 pt-query-digest 进行测试。

QPS 突增问题

如果应用模块功能出现 bug,如果要去从数据库层面卸掉这个功能,怎么做 ?

  • 可以用查询重写功能,但需要考虑到查询重写的模板“误杀”和即使重写,重写的结果是否会导致后面的业务逻辑失败的问题
  • 此外,还有虚拟化、白名单机制、业务账号分离等选项

这篇关于第二十二章 MySQL有哪些“饮鸩止渴”提高性能的方法?的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/566393

相关文章

SQL BETWEEN 语句的基本用法详解

《SQLBETWEEN语句的基本用法详解》SQLBETWEEN语句是一个用于在SQL查询中指定查询条件的重要工具,它允许用户指定一个范围,用于筛选符合特定条件的记录,本文将详细介绍BETWEEN语... 目录概述BETWEEN 语句的基本用法BETWEEN 语句的示例示例 1:查询年龄在 20 到 30 岁

MySQL DQL从入门到精通

《MySQLDQL从入门到精通》通过DQL,我们可以从数据库中检索出所需的数据,进行各种复杂的数据分析和处理,本文将深入探讨MySQLDQL的各个方面,帮助你全面掌握这一重要技能,感兴趣的朋友跟随小... 目录一、DQL 基础:SELECT 语句入门二、数据过滤:WHERE 子句的使用三、结果排序:ORDE

Python中提取文件名扩展名的多种方法实现

《Python中提取文件名扩展名的多种方法实现》在Python编程中,经常会遇到需要从文件名中提取扩展名的场景,Python提供了多种方法来实现这一功能,不同方法适用于不同的场景和需求,包括os.pa... 目录技术背景实现步骤方法一:使用os.path.splitext方法二:使用pathlib模块方法三

Python打印对象所有属性和值的方法小结

《Python打印对象所有属性和值的方法小结》在Python开发过程中,调试代码时经常需要查看对象的当前状态,也就是对象的所有属性和对应的值,然而,Python并没有像PHP的print_r那样直接提... 目录python中打印对象所有属性和值的方法实现步骤1. 使用vars()和pprint()2. 使

CSS实现元素撑满剩余空间的五种方法

《CSS实现元素撑满剩余空间的五种方法》在日常开发中,我们经常需要让某个元素占据容器的剩余空间,本文将介绍5种不同的方法来实现这个需求,并分析各种方法的优缺点,感兴趣的朋友一起看看吧... css实现元素撑满剩余空间的5种方法 在日常开发中,我们经常需要让某个元素占据容器的剩余空间。这是一个常见的布局需求

MySQL MCP 服务器安装配置最佳实践

《MySQLMCP服务器安装配置最佳实践》本文介绍MySQLMCP服务器的安装配置方法,本文结合实例代码给大家介绍的非常详细,对大家的学习或工作具有一定的参考借鉴价值,需要的朋友参考下... 目录mysql MCP 服务器安装配置指南简介功能特点安装方法数据库配置使用MCP Inspector进行调试开发指

mysql中insert into的基本用法和一些示例

《mysql中insertinto的基本用法和一些示例》INSERTINTO用于向MySQL表插入新行,支持单行/多行及部分列插入,下面给大家介绍mysql中insertinto的基本用法和一些示例... 目录基本语法插入单行数据插入多行数据插入部分列的数据插入默认值注意事项在mysql中,INSERT I

一文详解MySQL如何设置自动备份任务

《一文详解MySQL如何设置自动备份任务》设置自动备份任务可以确保你的数据库定期备份,防止数据丢失,下面我们就来详细介绍一下如何使用Bash脚本和Cron任务在Linux系统上设置MySQL数据库的自... 目录1. 编写备份脚本1.1 创建并编辑备份脚本1.2 给予脚本执行权限2. 设置 Cron 任务2

SQL Server修改数据库名及物理数据文件名操作步骤

《SQLServer修改数据库名及物理数据文件名操作步骤》在SQLServer中重命名数据库是一个常见的操作,但需要确保用户具有足够的权限来执行此操作,:本文主要介绍SQLServer修改数据... 目录一、背景介绍二、操作步骤2.1 设置为单用户模式(断开连接)2.2 修改数据库名称2.3 查找逻辑文件名

Python常用命令提示符使用方法详解

《Python常用命令提示符使用方法详解》在学习python的过程中,我们需要用到命令提示符(CMD)进行环境的配置,:本文主要介绍Python常用命令提示符使用方法的相关资料,文中通过代码介绍的... 目录一、python环境基础命令【Windows】1、检查Python是否安装2、 查看Python的安