mysql 连接池配置 5.6_MySQL 5.6初始配置调整

原文链接: What to tune in MySQL 5.6 after installation

原文日期: 2013年09月17日

翻译日期: 2014年06月01日

翻译人员: 铁锚

随着 大量默认选项的改进, MySQL 5.6比曾经版本号须要调优的选项大为降低. 在本文中我将讲述须要优化的配置项.

InnoDB设置

innodb_buffer_pool_size—— 默认值为 128M. 这是最基本的优化选项,由于它指定 InnoDB 使用多少内存来载入数据和索引(data+indexes). 针对专用MySQL服务器,建议指定为物理内存的 50-80%这个范围. 比如,拥有64GB物理内存的机器,缓存池应该设置为50GB左右.假设将该值设置得更大可能会存在风险,比方没有足够的空暇内存留给操作系统和依赖文件系统缓存的某些MySQL子系统(subsystem),包含二进制日志(binary logs),InnoDB事务日志(transaction logs)等.

innodb_log_file_size—— 默认值为 48M. 有非常高写入吞吐量的系统须要添加该值以同意后台检查点活动在更长的时间周期内平滑写入,得以改进性能. 将此值设置为4G下面是非常安全的. 过去的实践表明,日志文件太大的缺点是添加了崩溃时所需的修复时间,但这在5.5和5.6中已得到重大改进.

—— 默认值为 fdatasync. 假设使用 硬件RAID磁盘控制器, 可能须要设置为 O_DIRECT. 这在读取InnoDB缓冲池时可防止“双缓冲(double buffering)”效应,否则会在文件系统缓存与InnoDB缓存间形成2个副本(copy).假设不使用硬件RAID控制器,或者使用SAN存储时, O_DIRECT 可能会导致性能下降.MySQL用户手冊 和 Bug #54306 具体地说明了这一点.

innodb_flush_neighbors —— 默认值为 1. 在SSD存储上应设置为0(禁用) ,由于使用顺序IO没有不论什么性能收益. 在使用RAID的某些硬件上也应该禁用此设置,由于逻辑上连续的块在物理磁盘上并不能保证也是连续的.

innodb_io_capacityand—— 这些设置会影响InnoDB每秒在后台运行多少操作. 在 曾经的一篇文章 里我描写叙述了大多数写IO(除了写InnoDB日志)是后台操作的. 假设你深度了解硬件性能(如每秒能够运行多少次IO操作),则使用这些功能是非常可取的,而不是让它闲着.有一个非常好的类比演示样例:  假如某次航班一张票也没有卖出去 —— 那么让稍后航班的一些人乘坐该次航班,有可能是非常好的策略,以防后面遇到恶劣的天气. 即有机会就将后台操作顺便处理了,以降低同稍后可能的实时操作产生竞争.

有一个非常easy的计算:  假设每一个磁盘每秒读写(IOPS)能够达到 200次, 则拥有10个磁盘的 RAID10 磁盘阵列IOPS理论上 =(10/2)* 200 = 1000. 我说它“非常easy”,是由于RAID控制器通常能够提供额外的合并,并有效提高IOPS能力. 对于SSD磁盘,IOPS能够轻松达到好几千.

将这两个值设置得太大可能会存在某些风险,你肯定不希望后台操作妨碍了前台任务IO操作的性能. 过去的经验表明,将这两个值设置的太高,InnoDB持有的内部锁会导致性能降低(按我了解到的信息,在MySQL5.6中这得到了非常大的改进).

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

假如服务器要支持主从复制,或按时间点恢复,在这样的情况下,我们须要:

expire-logs-days—— 默认旧日志会一直保留. 我推荐设置为 1-10 天. 保存更长的时间并没有太多用处,由于从备份中恢复会快得多.

server-id—— 在一个主从复制体系(replication topology )中的全部服务器都必须设置唯一的 server-id.其它配置(Misc)

timezone=GMT将时区设置为格林尼治时间. 越来越多的系统管理员建议将全部服务器都设置为 格林尼治时间(GMT). 我个人非常喜欢这点,由于如今差点儿全部的业务都是全球化的. 设置为你本地的时区似乎是有点武断的.

sql-mode—— MySQL默认对不规范的数据非常宽容,而且会静默地截断数据. 在我之前的一篇文章中, 我提到新应用程序最好设置为: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—— 禁用反向域名解析. DNS解析在某些系统上可能有点慢/不稳定,所以假设不须要基于主机名的授权,我建议避免这样的解析.

max_connect_errors——Todd Farmer 写道:“[这个功能]提供了没有实际意义的暴力訪问攻击保护”. 其实当设置skip-name-resolve 时, max_connect_errors 甚至不起作用(见上一段所述).防火墙是更合适的解决方式,通常我将3306port屏蔽,无论是公网的还是内网的port,仅仅有特定的应用程序能够訪问和连接到MySQL.

我一般会设置 max_connect_errors=100000, 这样我能够避免不论什么“双重配置”,保证它不会碍事.

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

你可能希望,很多打开的连接都是空暇并休眠的. 但假设他们都处于活跃状态的话,可能会创建大量新的线程(thread-thrash).

假设条件同意,能够为应用程序配置优化数据库连接池(connection-pools)来解决问题,而不是打开并保持大量连接;

当然那些不使用连接池(non-pooled ), 迅速打开,运行任务后又尽可能快地关闭连接的应用也是可行的.

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

总结(Conclusion)

假设MySQL服务器的配置为:

64GB物理内存

硬件RAID控制器(假设每秒IO可达 2000 IOPS)

须要主从复制(Replication)

新的应用(eg. 非遗留系统)

有防火墙保护

不须要基于域名(hostnames,主机名)的授权

全球化应用,并不想固定在某一时区.

则配置可能例如以下所看到的:

# 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

我希望明确这一基本问题. 假设你有其他的建议,请联系原作者.

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
您可以按照以下步骤来下载、安装和配置MySQL 5.6: 1. 前往MySQL官网的下载页面:https://dev.mysql.com/downloads/mysql/5.6.html#downloads 2. 在“MySQL Community Server”下拉菜单中选择您的操作系统,并下载对应的安装包。 3. 安装MySQL,双击下载的安装包,按照提示进行安装。在安装过程中,您需要设置MySQL的root用户密码。 4. 配置MySQL,您可以通过以下步骤来配置MySQL: a. 打开命令提示符,输入以下命令启动MySQL服务:net start mysql b. 登录MySQL,输入以下命令登录MySQLmysql -u root -p c. 创建一个新用户,使用以下命令:CREATE USER 'username'@'localhost' IDENTIFIED BY 'password';(其中,username是您想要创建的用户名,password是该用户的密码) d. 授予新用户权限,使用以下命令:GRANT ALL PRIVILEGES ON *.* TO 'username'@'localhost';(其中,username是您刚刚创建的用户名) e. 退出MySQL,使用以下命令:exit 5. 测试MySQL,您可以通过以下步骤来测试MySQL是否安装成功: a. 打开命令提示符,输入以下命令启动MySQL服务:net start mysql b. 登录MySQL,输入以下命令登录MySQLmysql -u username -p(其中,username是您刚刚创建的用户名) c. 如果成功登录,将显示MySQL命令行提示符。您可以尝试输入一些SQL命令来测试MySQL是否正常工作。 d. 退出MySQL,使用以下命令:exit 希望这些步骤可以帮助您成功下载、安装和配置MySQL 5.6

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值