MySQL优化调优有没有做过_MySQL 调优/优化的 100 个建议

MySQL是一个强大的开源数据库。随着MySQL上的应用越来越多,MySQL逐渐遇到了瓶颈。这里提供 101 条优化 MySQL 的建议。有些技巧适合特定的安装环境,但是思路是相通的。我已经将它们分成了几类以帮助你理解。MySQL监控MySQL服务器硬件和OS(操作系统)调优:1、有足够的物理内存,能将整个InnoDB文件加载到内存里 —— 如果访问的文件在内存里,而不是在磁盘上,InnoDB会快很多。2、全力避免 Swap 操作 — 交换(swapping)是从磁盘读取数据,所以会很慢。3、使用电池供电的RAM(Battery-Backed RAM)。4、使用一个高级磁盘阵列 — 最好是 RAID10 或者更高。5、避免使用RAID5 — 和校验需要确保完整性,开销很高。6、将你的操作系统和数据分开,不仅仅是逻辑上要分开,物理上也要分开 — 操作系统的读写开销会影响数据库的性能。7、将临时文件和复制日志与数据文件分开 — 后台的写操作影响数据库从磁盘文件的读写操作。8、更多的磁盘空间等于更高的速度。9、磁盘速度越快越好。10、SAS优于SATA。11、小磁盘的速度比大磁盘的更快,尤其是在 RAID 中。12、使用电池供电的缓存 RAID(Battery-Backed Cache RAID)控制器。13、避免使用软磁盘阵列。14. 考虑使用固态IO卡(不是磁盘)来作为数据分区 — 几乎对所有量级数据,这种卡能够支持 2 GBps 的写操作。15、在 Linux 系统上,设置 swappiness 的值为0 — 没有理由在数据库服务器上缓存文件,这种方式在Web服务器或桌面应用中用的更多。16、尽可能使用 noatime 和 nodirtime 来挂载文件系统 — 没有必要为每次访问来更新文件的修改时间。17、使用 XFS 文件系统 — 一个比ext3更快的、更小的文件系统,拥有更多的日志选项,同时,MySQL在ext3上存在双缓冲区的问题。18、优化你的 XFS 文件系统日志和缓冲区参数 – -为了获取最大的性能基准。19、在Linux系统中,使用 NOOP 或 DEADLINE IO 调度器 — CFQ 和 ANTICIPATORY 调度器已经被证明比 NOOP 和 DEADLINE 慢。20、使用 64 位操作系统 — 有更多的内存能用于寻址和 MySQL 使用。21、将不用的包和后台程序从服务器上删除 — 减少资源占用。22、将使用 MySQL 的 host 和 MySQL自身的 host 都配置在一个 host 文件中 — 这样没有 DNS 查找。23、永远不要强制杀死一个MySQL进程 — 你将损坏数据库,并运行备份。24、让你的服务器只服务于MySQL — 后台处理程序和其他服务会占用数据库的 CPU 时间。MySQL 配置:25、使用 innodb_flush_method=O_DIRECT 来避免写的时候出现双缓冲区。26、避免使用 O_DIRECT 和 EXT3 文件系统 — 这会把所有写入的东西序列化。27、分配足够 innodb_buffer_pool_size ,来将整个InnoDB 文件加载到内存 — 减少从磁盘上读。28、不要让 innodb_log_file_size 太大,这样能够更快,也有更多的磁盘空间 — 经常刷新有利降低发生故障时的恢复时间。29、不要同时使用 innodb_thread_concurrency 和 thread_concurrency 变量 — 这两个值不能兼容。30、为 max_connections 指定一个小的值 — 太多的连接将耗尽你的RAM,导致整个MySQL服务器被锁定。31、保持 thread_cache 在一个相对较高的数值,大约是 16 — 防止打开连接时候速度下降。32、使用 skip-name-resolve — 移除 DNS 查找。33、如果你的查询重复率比较高,并且你的数据不是经常改变,请使用查询缓存 — 但是,在经常改变的数据上使用查询缓存会对性能有负面影响。34、增加 temp_table_size — 防止磁盘写。35、增加 max_heap_table_size — 防止磁盘写。36、不要将 sort_buffer_size 的值设置的太高 — 可能导致连接很快耗尽所有内存。37、监控 key_read_requests 和 key_reads,以便确定 key_buffer 的值 — key 的读需求应该比 key_reads 的值更高,否则使用 key_buffer 就没有效率了。38、设置 innodb_flush_log_at_trx_commit = 0 可以提高性能,但是保持默认值(1)的话,能保证数据的完整性,也能保证复制不会滞后。39、有一个测试环境,便于测试你的配置,可以经常重启,不会影响生产环境。MySQL Schema 优化:40、保证你的数据库的整洁性。41、归档老数据 — 删除查询中检索或返回的多余的行42、在数据上加上索引。43、不要过度使用索引,评估你的查询。44、压缩 text 和 blob 数据类型 — 为了节省空间,减少从磁盘读数据。45、UTF 8 和 UTF16 比 latin1 慢。46、有节制的使用触发器。47、保持数据最小量的冗余 — 不要复制没必要的数据.48、使用链接表,而不是扩展行。49、注意你的数据类型,尽可能的使用最小的。50、如果其他数据需要经常需要查询,而 blob/text 不需要,则将 blob/text 数据域其他数据分离。51、经常检查和优化表。52、经常做重写 InnoDB 表的优化。53、有时,增加列时,先删除索引,之后在加上索引会更快。54、为不同的需求选择不同的存储引擎。55、日志表或审计表使用ARCHIVE存储引擎 — 写的效率更高。56、将 session 数据存储在 memcache 中,而不是 MySQL 中 — memcache 可以设置自动过期,防止MySQL对临时数据高成本的读写操作。57、如果字符串的长度是可变的,则使用VARCHAR代替CHAR — 节约空间,因为CHAR是固定长度,而VARCHAR不是(utf8 不受这个影响)。58、逐步对 schema 做修改 — 一个小的变化将产生的巨大的影响。59、在开发环境测试所有 schema 变动,而不是在生产环境的镜像上去做。60、不要随意改变你的配置文件,这可能产生非常大的影响。61、有时候,少量的配置会更好。62、质疑使用通用的MySQL配置文件。

185332iavaazueppig6m4i.jpg 查询优化:63、使用慢查询日志,找出执行慢的查询。64、使用 EXPLAIN 来决定查询功能是否合适。65、经常测试你的查询,看是否需要做性能优化 — 性能可能会随着时间的变化而变化。66、避免在整个表上使用count(*) ,它可能会将整个表锁住。67、保持查询一致,这样后续类似的查询就能使用查询缓存了。68、如果合适,用 GROUP BY 代替 DISTINCT。69、在 WHERE、GROUP BY 和 ORDER BY 的列上加上索引。70、保证索引简单,不要在同一列上加多个索引。71、有时,MySQL 会选择错误的索引,这种情况使用 USE INDEX。72、使用 SQL_MODE=STRICT 来检查问题。73、索引字段少于5个时,UNION 操作用 LIMIT,而不是 OR。74、使用 INSERT ON DUPLICATE KEY 或 INSERT IGNORE 来代替 UPDATE,避免 UPDATE 前需要先 SELECT。75、使用索引字段和 ORDER BY 来代替 MAX。76、避免使用 ORDER BY RAND()。77、LIMIT M,N 在特定场景下会降低查询效率,有节制使用。78、使用 UNION 来代替 WHERE 子句中的子查询。79、对 UPDATE 来说,使用 SHARE MODE 来防止排他锁。80、重启 MySQL 时,记得预热数据库,确保将数据加载到内存,提高查询效率。81、使用 DROP TABLE ,然后再 CREATE TABLE ,而不是 DELETE FROM ,以删除表中所有数据。82、最小化你要查询的数据,只获取你需要的数据,通常来说不要使用 *。83、考虑持久连接,而不是多次建立连接,已减少资源的消耗。84、基准查询,包括服务器的负载,有时一个简单的查询会影响其他的查询。85、当服务器的负载增加时,使用SHOW PROCESSLIST来查看慢的/有问题的查询。86、在存有生产环境数据副本的开发环境中,测试所有可疑的查询。MySQL备份过程:87、在二级复制服务器上进行备份。88、备份过程中停止数据的复制,以防止出现数据依赖和外键约束的不一致。89、彻底停止MySQL之后,再从数据文件进行备份。90、如果使用MySQL dump进行备份,请同时备份二进制日志 — 确保复制过程不被中断。91、不要信任 LVM 快照的备份 — 可能会创建不一致的数据,将来会因此产生问题。92、为每个表做一个备份,这样更容易实现单表的恢复 — 如果数据与其他表是相互独立的。93、使用 mysqldump 时,指定 -opt 参数。94、备份前检测和优化表。95、临时禁用外键约束,来提高导入的速度。96、临时禁用唯一性检查,来提高导入的速度。97、每次备份完后,计算数据库/表数据和索引的大小,监控其增长。98、使用定时任务(cron)脚本,来监控从库复制的错误和延迟。99、定期备份数据。100、定期测试备份的数据。

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/533994.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

python语句print(type([1、2、3、4))_Python 学习第一天

一、学习内容1.print:表示输出print (“hello world”)单行注释:#多行注释:“““ ”””2.运算符注意:才表示等于,!表示不等于3.位运算符~按位取反:~104.变量和赋值teacher“老马的…

mysql核心参数_MySQL技术体系之核心参数

本文主要基于MySQL 5.7版本的数据库环境,总结my.cnf文件中核心参数的配置使用,让更多的人对MySQL技术体系有更全面、更专业的深度了解。一、客户端核心参数1、port端口号,默认33062、socketSocket文件地址,默认以.sock为文件名称后…

svd降维 python案例_SVD(奇异值分解)Python实现

注: 在《SVD(异值分解)小结 》中分享了SVD原理,但其中只是利用了numpy.linalg.svd函数应用了它,并没有提到如何自己编写代码实现它,在这里,我再分享一下如何自已写一个SVD函数。但是这里会利用到SVD的原理,…

salt 启动mysql_saltsack自动化配置day03:服务部署mysql部署

一、MySQL集群需求分享1、抽象:功能模块把基础的写成通用服务部署也要抽象出来模块redis内存有的多,有的少,可以config set在线更改redis 安装、配置、启动mysql 安装、配置(my.cnf可以统一 目录默认配置可以统一)master: server_id 1111slav…

jtag引脚定义_从逆向分析的角度学习硬件调试技巧JTAG,SSD和固件提取

我想从逆向的角度做了深入了解JTAG,JTAG是许多嵌入式CPU使用的硬件级别调试机制,我希望通过这篇文章从逆向工程师的角度解释如何使用JTAG,并在此过程中提供一些实际示例。0x01 研究目标通过这篇文章,我希望做到以下几点&#xff1…

python virtualenv conda_在vscode中启动conda虚拟环境的思路详解

问题:cudatoolkit cudnn 通过conda 虚拟环境安装,先前已经使用virtualenv安装tf,需要在conda虚拟环境中启动外部python虚拟环境思路:conda prompt即将 [虚拟环境位置] 以参数形式传入 [activate.bat]VSOCDE中的设置添加以下语句{&…

python如何导入图片imread_OpenCV 使用imread()函数读取图片的六种正确姿势

经常看到有人在网上询问关于imread()函数读取图片失败的问题。今天心血来潮,经过实验,总结出imread()调用的四种正确姿势。通常我要获取一张图片的绝对路径是这样做的:在图片上右键——属性——安全——对象名称。然后复制对象名称就得到了图…

python2.7与3.7脚本转换_python 2.7 - python 3.7 升级记录

更换的模块python 3.7 模块名python 2.7 模块名python 3.7 包python 2.7包pymysqlMySQLdbPyMySQLMySQL-pythonpdfminerpdfminerpdfminer.sixpdfminerurllib.parseurlparse自带自带htmlHTMLParser自带HTMLparser语法变化1. print 修改为 print()2. except Exception, e 修改为 e…

远程过程调用失败_Java开发大型互联网RPC远程调用服务实现之问题处理方案

引言RPC(Remote Procedure Call Protocol)——远程过程调用协议,它是一种通过网络从远程计算机程序上请求服务,而不需要了解底层网络技术的协议。RPC协议假定某些传输协议的存在,如TCP或UDP,为通信程序之间携带信息数据。在OSI网络…

chrome 新的session 设置_为什么还是由这么多人搞不懂Cookie、Session、Token?

作者:不学无数的程序员链接:https://urlify.cn/Yfm6Vr# Cookie洛:大爷,楼上322住的是马冬梅家吧? 大爷:马都什么? 夏洛:马冬梅。 7大爷:什么都没啊? 夏洛…

mysql for update用处_for update的作用和用法

一、for update定义for update是一种行级锁,又叫排它锁,一旦用户对某个行施加了行级加锁,则该用户可以查询也可以更新被加锁的数据行,其它用户只能查询但不能更新被加锁的数据行.如果其它用户想更新该表中的数据行&…

python大数据零基础_零基础学习大数据人工智能,学习路线篇!

大数据处理技术怎么学习呢?首先我们要学习Python语言和Linux操作系统,这两个是学习大数据的基础,学习的顺序不分前后。Python:Python 的排名从去年开始就借助人工智能持续上升,现在它已经成为了语言排行第一名。从学习难易度来看…

python删除文件和linux删除文件区别_使用Python批量删除文件列表

使用Python批量删除文件列表环境:已知要删除的文件列表,即确定哪些文件要删除。代码如下:#!/usr/bin/env python#codingutf-8#目的:本程序主要为删除给定的文件列表import osimport shutil#引入模块,os为包含普遍的操作…

华为python有必要学吗_【华为云技术分享】这个 Python 库有必要好好学学

这里看一个最基本的例子,这里给到一个 User 的 Class 定义,再给到一个 data 数据,像这样:1 class User(object):2 def __init__(self, name, age):3 self.name name4 self.age age56 data [{7 name: Germey,8 age: 239 }, {10 nam…

python求平行四边形面积_python 已知平行四边形三个点,求第四个点的案例

我就废话不多说了,大家还是直接看代码吧!import numpy as np#已知平行四边形三个点,求第四个点#计算两点之间的距离def CalcEuclideanDistance(point1,point2):vec1 np.array(point1)vec2 np.array(point2)distance np.linalg.norm(vec1 -…

eview面板数据之混合回归模型_【视频教程】Eviews系列25|面板数据回归分析之Hausman检验及本章常见问题解答...

点击上方关注我们!本期我们学习Eviews统计建模最后一部分--面板数据回归分析Hausman检验及本章常见问题解答。实操:Hausman检验判断是固定效应模型还是随机效应模型上期我们讲到模型判断若选择模型2,需进一步通过Hausman检验判断固定效应还是随机效应,接…

python打出由边框包围的_python opencv 图像边框(填充)添加及图像混合的实现方法(末尾实现类似幻灯片渐变的效果)...

图像边框的实现图像边框设计的主要函数cv.copyMakeBorder()——实现边框填充主要参数如下:参数一:源图像——如:读取的img参数二——参数五分别是:上下左右边的宽度——单位:像素参数六:边框类型&#xff1…

mysql5.7.21备份脚本_Shell脚本使用汇总整理——mysql数据库5.7.8以后备份脚本

#!/bin/sh#db_backups_conf.txt文件路径db_backups_conf"/wocloud/shell/db_backups_conf.txt"#判断文件是否存在if [ -f "${db_backups_conf}" ];thenecho $(date %Y-%m-%d %H:%M:%S)" 数据库配置信息文件存在,开始进行数据备份"#获…

python嵌套列表操作_python基础(list列表的操作,公共方法,列表嵌套,元祖)...

list 列表索引,切片与str相同。列表的操作(增删改查)1,增加.append()  追加,增加到最后li [alex,wusir,egon,女神,taibai]li.append(ppp)print(li).insert()  中间插入,通过索引li [alex,wusir,egon,女神,taibai]li.insert(…

mybatis mysql selectkey_Mybatis示例之SelectKey的应用

SelectKey在Mybatis中是为了解决Insert数据时不支持主键自动生成的问题,他可以很随意的设置生成主键的方式。不管SelectKey有多好,尽量不要遇到这种情况吧,毕竟很麻烦。SelectKey需要注意order属性,像Mysql一类支持自动增长类型的…