前往小程序,Get更优阅读体验!
立即前往
首页
学习
活动
专区
圈层
工具
发布
首页
学习
活动
专区
圈层
工具
社区首页 >专栏 >MySQL初始配置调优

MySQL初始配置调优

作者头像
wangxl
发布于 2018-03-07 09:13:41
发布于 2018-03-07 09:13:41
2.6K1
举报
文章被收录于专栏:PHP在线PHP在线

随着 大量默认选项的改进, MySQL 5.6比以前版本需要调优的选项大为减少。 在本文中我将讲述需要优化的配置项。

  InnoDB设置

  innodb_buffer_pool_size -- 默认值为 128M. 这是最主要的优化选项,因为它指定 InnoDB 使用多少内存来加载数据和索引(data+indexes)。 针对专用MySQL服务器,建议指定为物理内存的 50-80%这个范围。 例如,拥有64GB物理内存的机器,缓存池应该设置为50GB左右。

  innodb_log_file_size -- 默认值为 48M. 有很高写入吞吐量的系统需要增加该值以允许后台检查点活动在更长的时间周期内平滑写入,得以改进性能。 将此值设置为4G以下是很安全的。 过去的实践表明,日志文件太大的缺点是增加了崩溃时所需的修复时间,但这在5.5和5.6中已得到重大改进。innodb_flush_method -- 默认值为 fdatasync. 如果使用 硬件RAID磁盘控制器, 可能需要设置为 O_DIRECT. 这在读取InnoDB缓冲池时可防止"双缓冲(double buffering)"效应,否则会在文件系统缓存与InnoDB缓存间形成2个副本(copy)。

  MySQL用户手册 和 Bug #54306 详细地说明了这一点。innodb_flush_neighbors -- 默认值为 1. 在SSD存储上 应设置为0(禁用) ,因为使用顺序IO没有任何性能收益。 在使用RAID的某些硬件上也应该禁用此设置,因为逻辑上连续的块在物理磁盘上并不能保证也是连续的。innodb_io_capacity and innodb_io_capacity_max -- 这些设置会影响InnoDB每秒在后台执行多少操作。 在 以前的一篇文章 里我描述了大多数写IO(除了写InnoDB日志)是后台操作的。 如果你深度了解硬件性能(如每秒可以执行多少次IO操作),则使用这些功能是很可取的,而不是让它闲着。 有一个很好的类比示例: 假如某次航班一张票也没有卖出去 -- 那么让稍后航班的一些人乘坐该次航班,有可能是很好的策略,以防后面遇到恶劣的天气。 即有机会就将后台操作顺便处理了,以减少同稍后可能的实时操作产生竞争。

  innodb_lru_scan_depth - 默认值为 1024. 这是mysql 5.6中引入的一个新选项。 Mark Callaghan 提供了 一些配置建议。 简单来说,如果增大了 innodb_io_capacity 值, 应该同时增加 innodb_lru_scan_depth.复制(Replication)

  以前的文章所说, 我建议大多数用户应该以稳定性为目标。 在这种情况下,你还需要启用: sync_binlog=1, sync_relay_log=1, relay-log-info-repository=TABLE and master-info-repository=TABLE.expire-logs-days -- 默认旧日志会一直保留。 我推荐设置为 1-10 天。 保存更长的时间并没有太多用处,因为从备份中恢复会快得多。server-id -- 在一个主从复制体系(replication topology )中的所有服务器都 必须设置唯一的 server-id.binlog_format=ROW -- 修改为基于行的复制。 我最近写的另一篇 基于行的复制 ,里面叙述了我真的很喜欢它的原因,因为它可以通过减少资源锁定提高性能。 此外还需要启用两个附加设置: transaction-isolation=READ-COMMITTED and innodb_autoinc_lock_mode = 2.其他配置(Misc)

  timezone=GMT 将时区设置为格林尼治时间。 越来越多的系统管理员建议将所有服务器都设置为 格林尼治时间(GMT)。 我个人非常喜欢这点,因为现在几乎所有的业务都是全球化的。 设置为你本地的时区似乎是有点武断的。character-set-server=utf8mb4 and collation-server=utf8mb4_general_ci 如之前的 文章所讲述的 ,utf8 编码对新应用来说是更好的默认选项。 您还可以设置 skip-character-set-client-handshake 以忽略应用程序想要设置的其他字符集(character-set)。sql-mode -- MySQL默认对不规范的数据很宽容,并且会静默地截断数据。 在我 之前的一篇文章中, 我提到新应用程序最好设置为: STRICT_TRANS_TABLES,ERROR_FOR_DIVISION_BY_ZERO, NO_AUTO_CREATE_USER,NO_AUTO_VALUE_ON_ZERO,

  skip-name-resolve -- 禁用反向域名解析DNS解析在某些系统上可能有点慢/不稳定,所以如果不需要基于主机名的授权,我建议避免这种解析。max_connect_errors -- Todd Farmer 写道 :"[这个功能]提供了没有实际意义的暴力访问攻击保护". 事实上当设置skip-name-resolve 时, max_connect_errors 甚至不起作用(见上一段所述)。 防火墙是更合适的解决方案,通常我将3306端口屏蔽,不管是公网的还是内网的端口,只有特定的应用程序可以访问和连接到MySQL.

  max_connect_errors=100000, 这样我可以避免任何"双重配置",保证它不会碍事。

  max-connections --默认值是151. 我看到很多用户将他设置得比较大,大多在 300 ~ 1000之间。 通常不可避免地这个值会被设置得更大,但让我有点紧张的是, 16核的机器在IO阻塞的情况下也只有大约 2x~10x 的连接执行能力。

  从5.5开始的另一种解决方案(在MySQL社区版和企业版之间有一些差异) 是使用 线程池插件。

  总结(Conclusion)

  可靠稳定(durable)。

  则配置可能如下所示:

  # InnoDB settings

  innodb_buffer_pool_size=50G

  innodb_log_file_size=2G

  innodb_flush_method=O_DIRECT

  innodb_io_capacity=2000

  innodb_io_capacity_max=6000

  innodb_lru_scan_depth=2000

  # Binary log/replication

  log-bin

  sync_binlog=1

  sync_relay_log=1

  relay-log-info-repository=TABLE

  master-info-repository=TABLE

  expire_logs_days=10

  binlog_format=ROW

  transaction-isolation=READ-COMMITTED

  innodb_autoinc_lock_mode = 2

  # Other

  timezone=GMT

  character-set-server=utf8

  collation-server=utf8_general_ci

  sql-mode="STRICT_TRANS_TABLES,

  ERROR_FOR_DIVISION_BY_ZERO,

  NO_AUTO_CREATE_USER,

  NO_AUTO_VALUE_ON_ZERO,

  NO_ENGINE_SUBSTITUTION,

  NO_ZERO_DATE,

  NO_ZERO_IN_DATE,

  ONLY_FULL_GROUP_BY"

  skip-name_resolve

  max-connect-errors=100000

  max-connections=500

  # Unique to this machine

  server-id=123

本文参与 腾讯云自媒体同步曝光计划,分享自微信公众号。
原始发表:2015-09-16,如有侵权请联系 cloudcommunity@tencent.com 删除

本文分享自 php 微信公众号,前往查看

如有侵权,请联系 cloudcommunity@tencent.com 删除。

本文参与 腾讯云自媒体同步曝光计划  ,欢迎热爱写作的你一起参与!

评论
登录后参与评论
1 条评论
热度
最新
讲的很好,学写了!
讲的很好,学写了!
回复回复点赞举报
推荐阅读
编辑精选文章
换一批
MySQL 8.0 需要调整哪些参数
首先列出一个 8.0 my.cnf 的实例,这个只针对普通的单实例或者主从环境,对于其他环境,比如 MGR,可能有更多的一些参数需要调整。并且也不是最完整,最终要根据自己实际环境进行调整。
数据库交流
2022/06/15
1.8K0
mysql 5.7主从安装和配置
本文主要介绍mysql 5.7主从复制,转载请注明出处 下载地址 模块 版本 下载地址 mysql 5.7 https://dev.mysql.com/downloads/mysql/ libaio(可选) 0.3.110 http://ftp.altlinux.org/pub/distributions/ALTLinux/Sisyphus/x86_64/RPMS.classic//libaio-0.3.110-alt1.1.x86_64.rpm net-tools(可选) 2.0.22 htt
程序员同行者
2018/07/02
1.9K0
# client配置项
MySQL配置参数多达数百个,不过常用的并不多,很多配置我们不需要关心,只要掌握一些必要的配置项就能解决99%的问题,当遇见了那1%的问题时mysql可能已经不能满足你的需求了。
用户1175783
2020/05/09
7400
Mysql配置文件的理解
#[mysqld_multi] #mysqld=/usr/local/mysql/bin/mysqld_safe #mysqladmin=/usr/local/mysql/bin/mysqladmin #user=root #log=/data/mysqllog/multi.log [mysqld] explicit_defaults_for_timestamp=true #意思是为timestamp类型的列明确的注明default值。 # tmp for mysql load data infile,l
小俊丶Eternally
2018/05/11
8.4K2
Mysql配置文件的理解
4步搞定MySQL安装部署(附MySQL一键式部署脚本)
学习数据库技术,实际动手的第一步是安装自己的MySQL。MySQL方面也提供多样式的安装方式rpm ,tar ,源码包。当安装完投入使用之后,随着业务量,数据量的增加,往往会碰到很多意向不到的问题。如性能,安全,配置不合理等。对于最佳实践,都应该注意哪些。
数据和云
2021/01/25
2.4K0
4步搞定MySQL安装部署(附MySQL一键式部署脚本)
Linux系统下 MySQL 5.7和8.0 版本安装指南
yum -y remove mariadb-libs-5.5.44-2.el7.centos.x86_64
星哥玩云
2022/08/17
1K0
Linux系统下 MySQL 5.7和8.0 版本安装指南
MySQL配置文件配置
虚拟机环境:VirtualBox 6.0.24 操作系统:Oracle Linux Server release 6.5 x86_64 MySQL版本:5.7.33
全栈程序员站长
2022/08/22
5.8K0
Linux下MySQL多实例的安装部署
MySQL多实例就是在一台机器上开启多个不同的服务端口(如:3306,3307),运行多个MySQL服务进程,通过不同的socket监听不同的服务端口来提供各自的服务:
星哥玩云
2022/08/17
1.3K0
Linux下MySQL多实例的安装部署
开发经验|小白该如何学习MySQL配置文件
上一篇简单介绍了下MySQL的存储引擎,为什么需要存储引擎以及如何使用存储引擎。MySQL的配置文件是控制和配置 MySQL服务器行为的重要文件。对于新手开发者来说,理解掌握并运用 MySQL 配置文件是非常重要的。本篇想着重讲下MySQL的配置文件,帮助读者朋友们快速了解并上手使用,以便解决你在学习和工作中遇到的问题。
六月暴雪飞梨花
2023/11/24
7970
开发经验|小白该如何学习MySQL配置文件
MySQL配置文件及参数详解
MySQL的配置文件需要根据版本及实际情况进行相应配置,本人使用的是Percona版本,主要是用到线程池等功能,所以选择Percona版本,配置文件内容如下,大部分参数信息我参考了相关资料做了说明,如有不当之处欢迎大家来指正。
俊才
2019/08/08
1.9K0
MySQL配置文件及参数详解
MySQL之my.cnf文件常用参数
MySQL的配置文件,想必大家都不陌生,今天再来说说配置文件中的一些常用配置,并非最合理的配置,仅供参考,只有了解自己的生产环境,才能根据环境找到最适合你的配置文件参数。
AsiaYe
2020/01/15
2.7K0
MySQL之my.cnf文件常用参数
针对 MySQL/InnoDB 刷盘调优
这篇文章是讲述 InnoDB 刷盘策略系列文章的第三篇。本文主要讲述 性能调优。另外2篇文章参考
用户1278550
2022/07/30
2K0
Mysql优化系列(1)--Innodb引擎下mysql自身配置优化
1.简单介绍 InnoDB给MySQL提供了具有提交,回滚和崩溃恢复能力的事务安全(ACID兼容)存储引擎。InnoDB锁定在行级并且也在SELECT语句提供一个Oracle风格一致的非锁定读。这些特色增加了多用户部署和性能。没有在InnoDB中扩大锁定的需要,因为在InnoDB中行级锁定适合非常小的空间。InnoDB也支持FOREIGN KEY强制。在SQL查询中,你可以自由地将InnoDB类型的表与其它MySQL的表的类型混合起来,甚至在同一个查询中也可以混合。 2.之所以选用innodb作为存储引擎的
洗尽了浮华
2018/01/23
2.5K0
MySQL安装以及配置主从复制
实际中是三台实体机上分别部署,这里为了演示截图,采用虚拟机中部署了三个Linux环境,网络设置为桥接模式
Diuut
2022/11/22
5200
MySQL安装以及配置主从复制
MySQL两主(多主)多从架构配置
一、角色划分 1、MySQL数据库规划 我现在的环境是:zhdy04和zhdy05已经做好了主主架构配置,现在需要的是把两台或者多台从服务器与主一一同步。 如果搭建主主环境,参照此链接! 主机名 IP 地址 角色 Mysql_server_id zhdy04 192.168.230.145 masterA 145 zhdy05 192.168.230.146 masterB 146 zhdy06 192.168.230.147 slaveA 147 zhdy07 192.168.230.148 slaveB
老七Linux
2018/05/09
7.2K3
MySQL性能调优 – 你必须了解的15个重要变量
1.DEFAULT_STORAGE_ENGINE 如果你已经在用MySQL 5.6或者5.7,并且你的数据表都是InnoDB,那么表示你已经设置好了。如果没有,确保把你的表转换为InnoDB并且设置default_storage_engine为InnoDB。 为什么?简而言之,因为InnoDB是MySQL(包括Percona Server和MariaDB)最好的存储引擎 – 它支持事务,高并发,有着非常好的性能表现(当配置正确时)。 2.INNODB_BUFFER_POOL_SIZE 这个是InnoDB最
老七Linux
2018/05/31
4.1K0
MySQL 8.0.19 Linux平台安装 Part 2
cat /data/mysql/data/mysql-error.log |grep password
bsbforever
2020/08/18
4410
MySQL5.7基于GTID的主从配置
从MySQL 5.6.5 开始新增了一种基于 GTID 的复制方式。通过 GTID 保证了每个在主库上提交的事务在集群中有一个唯一的ID。这种方式强化了数据库的主备一致性,故障恢复以及容错能力。 GTID (Global Transaction ID)是全局事务ID,当在主库上提交事务或者被从库应用时,可以定位和追踪每一个事务,对DBA来说意义就很大了,我们可以适当的解放出来,不用手工去可以找偏移量的值了,而是通过CHANGE MASTER TO MASTER_HOST='xxx', MASTER_AUTO_POSITION=1的即可方便的搭建从库,在故障修复中也可以采用MASTER_AUTO_POSITION=‘X’的方式。
陳斯托洛夫斯記
2022/10/27
5120
MySQL5.7基于GTID的主从配置
配置MySQL主从/双主引发的反思 原
使用innobackupex工具进行备份(因本次涉及到的数据库实例较多,所以编写shell脚本,减少出错,单实例同样适用):
阿dai学长
2019/04/03
9650
配置MySQL主从/双主引发的反思
                                                                            原
模拟真实环境下超简单超详细的 MySQL 5.7 安装
1999年至 2000 年,Monty 成立了MySQL AB 这个公司。 2000 年,MySQL 公布了自己的源代码,并采用了 GPL 许可协议,正式进入开源的世界,这让 MySQL 迅速发展。2005 年 10 月 MySQL 发布了一个里程碑式的版本 MySQL 5.0 。
JiekeXu之路
2019/08/15
6400
相关推荐
MySQL 8.0 需要调整哪些参数
更多 >
领券
社区富文本编辑器全新改版!诚邀体验~
全新交互,全新视觉,新增快捷键、悬浮工具栏、高亮块等功能并同时优化现有功能,全面提升创作效率和体验
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档
查看详情【社区公告】 技术创作特训营有奖征文