本文翻译自 Percona 官方博客,适用于 MySQL 5.6 及 5.7 版本。

作者:Stephane Combaudon

原文:

https://www.percona.com/blog/2014/01/28/10-mysql-performance-tuning-settings-after-installation/

在本博客中,我们将和大家讨论下 MySQL 数据库安装后,建议调整的十个性能设置参数。

通常情况下,当我们需要进行 MySQL 性能审计时,我们将审查 MySQL 配置并提出改进建议。在大多数情况下,我们只建议安装后更改一些核心的 MySQL 性能调优参数,即使有数百个选项可用。这篇文章的目的是给你列出一些最关键的参数设置,并告诉你如何去调整它们。

在开始调整之前

即使是有经验的人也会犯一些会造成许多麻烦的错误。因此,在应用本文推荐的配置项之前,请牢记下面的几项:

  • 每次更改一个设置!这是验证设置是否有效的唯一方法。

  • 大多数配置项可以在运行时使用 SET GLOBAL 命令来修改。这种方式非常方便,并且如果修改后出现问题,还能马上恢复原设置。但到最后,仍然需要把这个改变写到配置文件中,使之永久生效。

  • 有时候即使 MySQL 重启后,配置文件中的参数也不生效。这时候你需要考虑:你使用正确的配置文件了吗?你把这个参数放在正确的地方了吗?(在这篇文章中的所有配置都属于[mysqld]部分)

  • 如在更改配置后数据库无法启动,需要检查是否使用正确的单位?例如, innodb_buffer_pool_size 的单位是 byte,而 max_connection 是没有单位的。

  • 在配置文件中不允许重复设置。如果要跟踪配置的更改,请使用版本控制。

  • 不要做天真的数学算法,比如“我的新服务器的 RAM 是旧的 2 倍,因此可以把所有的配置项的值都设置成之前的 2 倍”。

基础设置

这里主要讲解 3 个非常重要的 MySQL 性能配置项,你应该经常会看到这些参数。如果你没有调整,很可能会遇到问题。

innodb_buffer_pool_size

这是任何使用 InnoDB 存储引擎的 MySQL 在安装后第一个应该要查看的配置。Buffer pool 是用来缓存数据和索引的,应该分配尽可能大的内存,以确保在进行大多数读取操作时是读内存而不是读磁盘。典型的设置值为 5-6GB(8GB RAM),20-25G(32GB RAM),100-120GB(128GB RAM)。

innodb_log_file_size

这个选项是设置 redo 日志(重做日志)的大小。redo 日志是用来确保写入的数据能够快速地写入,并且持久化,还可以用于崩溃恢复(crash recovery)。MySQL 5.1 之前,这个选项很难去进行调整,因为你既想要加大 redo 日志来提高性能,又想要减小 redo 日志来进行快速的崩溃恢复。幸运的是,自 MySQL 5.5 之后,崩溃恢复的性能有了很大的提高,现在你可以拥有快速写入性能的同时,还能满足快速崩溃恢复。一直到 MySQL 5.5,redo 日志的总大小被限制在 4GB (默认有 2 个日志文件)。这个在 MySQL 5.6 中被增加了。

启动的时候设置 innodb_log_file_size = 512M(也就是 1GB 大小的 redo 日志),这样可以提供充足的写空间。如果你知道你的应用是频繁写入的,还可以再增大些。

max_connections

如果你经常遇到 "Too many connections" 的错误,是因为 max_connections 太小了。这个错误很常见到,因为应用程序没有正确地关闭与数据库的连接,你需要设置连接数为比默认 151 更大的值。max_connections 设置过高(如 1000 或更高)的一个主要缺点是当服务器运行 1000 个或者更多的事务时,会响应缓慢甚至没有响应。在应用程序端使用连接池或者在 MySQL 端使用线程池有助于解决这个问题。

InnoDB 设置

从 MySQL 5.5 开始,InnoDB 成为了默认的存储引擎,并且它的使用频率比其他存储引擎的要多得多。这就是要认真配置它的原因。

innodb_file_per_table

这个配置项会决定 InnoDB 是使用共享表空间(innodb_file_per_table = OFF) 来存储数据和索引,还是为每个表使用一个单独的 ibd 文件(innodb_file_per_table= ON)。对每个表使用一个文件的方式,在 drop, truncate, 或者重建表的时候,会回收这个表空间。在一些高级特性,如压缩的时候也需要开启使用独立表空间。然而这个选项却不能带来性能的提升。

在 MySQL 5.6 及之后的版本中,这个配置项是默认开启的,因此多数情况下,你无需操作。对于早期的 MySQL 版本,需要在启动前把它设置成 ON ,因为它只对新创建的表有影响。

innodb_flush_log_at_trx_commit

默认值为 1,表示 InnoDB 完全支持 ACID 特性。例如在在一个主节点上,你主要关注数据安全性,这是最好的设置值。然而它会对速度缓慢的磁盘系统造成很大的开销,因为每次将改变刷新到 redo 日志的时候,都需要额外的 fsync 操作。设置为 2,可靠性会差一点,因为已提交的事务只会 1 秒钟刷新一次到 redo 日志,但在某些情况下,对一个主节点而言,这仍然是可以接受的,而且对于复制关系的从库来说,这是一个很好的值。设置为 0,速度更快,但是在遇到崩溃的时候很可能会丢失一些数据,这只对从库是一个好的设置值。

innodb_flush_method

这个设置项决定了数据和日志刷新到磁盘的方式。当服务器硬件有 RAID 控制器、断电保护、采取 write-back 缓存机制的时候,最常用的值是 O_DIRECT;其他大多数场景使用默认值 fdatasync。sysbench 是一个帮助你在这两个值之间做出选择好工具。

innodb_log_buffer_size

这个设置项用来设置缓存还没有提交的事务的缓冲区的大小。默认值(1MB) 一般是够用的,但一旦事务之中带有大 blob/text 字段,这个缓冲区会被很快填满,并引起额外的 I/O 负载。看看 innodb_log_waits 这个状态变量的值,如果不是 0 的话,需要增加 innodb_log_buffer_size。

其他设置

query_cache_size

大家都知道查询缓存是一个瓶颈,即使在并发量不高的时候也会出现。最好的设置就是在第一天使用时就禁用查询缓存(query_cache_size = 0)  ,该选项在 MySQL 5.6 后是默认禁用的,我们可以通过其他途径来提高查询速度: 设计好的索引,增长读写分离,或者使用额外的缓存 (memcache or redis for instance)。如果您的 MySQL 已经启用了查询缓存并且从没有发现过问题, 那么查询缓存可能是对你有益的,这个时候如果你想禁用它的时候应该小心操作。

log_bin

如果要让一个节点做为复制关系中的主节点,启用二进制日志(binary log)是必须的。同时需要设置全局唯一的 server_id。如果是单实例数据库,如果你要将数据恢复到之前时间点(使用最新的备份restore,然后使用binlog进行recover),那么就需要二进制日志。二进制日志一旦创建,会被永久保存,所以如果不想耗尽磁盘空间,应该使用 PURGE BINARY LOGS 清理旧的二进制日志文件,或者设置 expire_logs_days 选项指定多少天之后,自动清理过期的二进制日志。

二进制文件记录是需要消耗资源的,因此在主从复制环境中,如果备库不需要 Binlog ,就可以禁用掉。

skip_name_resolve

当一个客户端连接上来的时候,服务端会执行主机名解释操作,当 DNS 很慢时,建立的连接也会很慢。因此建议在启动的时候设置 skip-name-resolve 来禁用 DNS 查找。唯一的局限是 GRANT 语句仅且仅能使用 IP 地址,所以,在已有系统中添加这个选项时需要格外小心。

结论

当然,根据你的负载和硬件的实际情况,还有其他的设置能够起到调优的作用:例如在小内存、高速磁盘,高并发,写密集型的负载下,需要特定的调优。不过本文的目的是给出几个 MySQL 的性能调优配置项,让你快速配置一个合理的 MySQL 配置文件,并且了解哪些参数对你很重要,而不需要花费大量时候去阅读官方文档。

推荐阅读

(点击标题可跳转阅读)

关于binlog,这个参数能不能用?

推荐几款MySQL相关工具

MySQL从库维护经验分享

- End -动动手指转发、在看是对我最大的鼓励

请验证实例名称是否正确并且 sql server 已配置为允许远程连接_安装MySQL后,需要调整的10个性能配置项...相关推荐

  1. 在与SQL Server建立连接时出现与网络相关的或特定于实例的错误。未找到或无法访问服务器。请验证实例名称是否正确并且SQL Server已配置为允许远程连接。(provider:命名管道提供程序,

    无法连接到(local). 其他信息: 在与SQL Server建立连接时出现与网络相关的或特定于实例的错误.未找到或无法访问服务器.请验证实例名称是否正确并且SQL Server已配置为允许远程连接 ...

  2. 在与 SQL Server 建立连接时出现与网络相关的或特定于实例的错误。未找到或无法访问服务器。请验证实例名称是否正确并且 SQL Server 已配置为允许远程连接。

    在与 SQL Server 建立连接时出现与网络相关的或特定于实例的错误.未找到或无法访问服务器.请验证实例名称是否正确并且 SQL Server 已配置为允许远程连接. 在使用G2服务时,测试服务器 ...

  3. 在与SQL server 建立连接时出现与网络相关的或特定于实例的错误。未找到或无法访问服务器。请验证实例名称是否正确并且SQL server已配置为允许远程连接。error40 错误53

    目录 项目场景: 问题描述: 原因分析: 解决方案: 1,开启SQL server 服务 菜单-->Microsoft SQL Server 2014-->SQL Server 2014 ...

  4. 在与 SQL Server 建立连接时出现与网络相关的或特定于实例的错误。未找到 或无法访问服务器。请验证实例名称是否正确并且 SQL Server 已配置为允许 远程连接

    解决方案一 1.通过Sql Server管理器 进入网络配置 2.进入TCP/IP 3.找到ip地址为127.0.0.1 修改TCP动态接口 1433 已启用 是 4.重新启动sql server 解 ...

  5. 在与 SQL Server 建立连接时出现与网络相关的或特定于实例的错误。未找到或无法访问服务器。请验证实例名称是否正确并且 SQL Server 已配置为允许远程连接。 (provider: 命名管

    通过设备管理器,将下述服务打开即可

  6. 在与 SQL Server 建立连接时出现与网络相关的或特定于实例的错误。未找到或无法访问服务器。请验证实例名称是否正确并且 SQL Server 已配置为允许...

    *引用*/SQL Server 2000连接中的四个最常见错误: 一."SQL Server 不存在或访问被拒绝" 这个是最复杂的,错误发生的原因比较多,需要检查的方面也比较多. ...

  7. SQL server连接到服务器,无法连接到 (local)。在与 SQL Server 建立连接时出现与网络相关的或特定于实例的错误。未找到或无法访问服务器。请验证实例名称是否正确并且 SQL Se

    标题: 连接到服务器 无法连接到 (local). 其他信息: 在与 SQL Server 建立连接时出现与网络相关的或特定于实例的错误.未找到或无法访问服务器.请验证实例名称是否正确并且 SQL S ...

  8. System.Data.SqlClient.SqlException:“在与 SQL Server 建立连接时出现与网络相关的或特定于实例的错误。未找到或无法访问服务器。请验证实例名称是否正确并且 S

    文章目录 一.windows验证 服务器资源管理器 Web.config 二.SQL验证 一.windows验证 服务器资源管理器 服务器资源管理器→数据连接→添加连接 选择对应的数据库类型. 选择服 ...

  9. 解决SQLSERVER2019无法通过SQLCMD登陆找不到或无法访问服务器。请检查实例名称是否正确

    通过sqlcmd连接SQLSERVER2019时报错 [ODBC Driver 17 for SQL Server]命名管道提供程序: 无法打开与 SQL Server 的连接 [5]. [ODBC ...

最新文章

  1. Linux启动检测内存条错误,linux检测程序内存泄漏和内存错误
  2. PHP+jQuery+Ajax实现用户登录与退出
  3. python多级字典嵌套_python – 如何拆分字符串并形成多级嵌套字典?
  4. 使用存储过程(22)
  5. SMS短信的C语言代码摘抄
  6. texlive写论文源代码_Texlive 2020 编译胡伟《latex2e完全学习手册》后记字体右倾90度...
  7. windows环境下unicode编程总结
  8. html 音标显示乱码,网页显示音标/拼音显示乱码的解决办法(.net)
  9. rm -rf误删文件的恢复(extundelete工具的使用)
  10. 土地利用转移矩阵图怎么做_如何用Arcgis做土地利用转移矩阵?求教各位..._土地估价师_帮考网...
  11. 高斯滤波详解 附python和matlab高斯滤波代码
  12. SSM项目实战 —— 物流管理系统的实现
  13. 全新小说安装教程小程序源码
  14. 【WLAN】【基础知识】WIFI那些事儿之PMF
  15. 一起初学java,笔记记录的第五天:数组、排序和查找
  16. 云计算的认识和看法_关于云计算的个人理解
  17. JS.Razor.CSHtml结合使用
  18. MySQL数据库中,在读已提交和可重复读这两个不同事务隔离级别下幻读的区别
  19. 荷兰莱顿大学 计算机科学与技术,荷兰学校排名
  20. matlab 伯德图 横坐标步长_【龙腾原创】教您使用matlab画伯德图(看了你就学会了,比mathcad好用多了。谁用谁知道!)...

热门文章

  1. mysql的含义及特点_MySQL——基本概念
  2. java有var吗_java – Var和Var之间的区别
  3. 晋职称计算机过几,晋职称怎样考计算机 昨日记者采访市人事局有关负责人
  4. java环境classpath_Java开发环境配置之Path和classpath
  5. matlab波形振幅,MATLAB正交振幅调制解调仿真分析(一)
  6. android九宫格密码源码,Android九宫格解锁的实现
  7. 【常用技巧】标准模板库(STL)
  8. Linux文件系统与日志
  9. PHP学习笔记八【数组】
  10. MongoDB优化之二:常见优化方法