⑴ lower_case_table_names
● 推荐理由
GNU/Linux 平台,对数据库、表、存储过程等对象名称大小写敏感
为减少开发人员的开发成本,为此推荐大家设置该参数使对象名称都自动转换成小写
● 参数介绍
取值范围:
为0:区分大小写、Linux 平台默认值
为1:不区分大小写
Linux安装的MySQL的配置文件中(/etc/my.cnf)、是没有lower_case_table_names=1这行的
在Windows安装的MySQL的配置文件中(my.ini)、是有lower_case_table_names=1这行的
所以、特别提醒下、在 Replication 配置下、Master和Slave中该参数应当保持一致!!
⑵ max_connect_errors
● 推荐理由
一台物理服务器只要连接 MySQL 数据库服务器 异常中断累计超过10次,就再也无法连接上mysqld服务
为此建议大家设置此值至少大于等于10
处理方案有 2 :
要么重启mysqld、要么 mysqladmin flush-hosts
● 参数介绍
不过、该参数和安全相关、
某些
黑客或许会尝试失败来暴力破解密码、该值如若设置过大会留下可趁之际
⑶ interactive_timeout和wait_timeout
● 推荐理由
如果你的MySQL Server有大量的闲置连接,他们不仅会白白消耗内存,而且如果连接一直在累加
那么、最终肯定会达到MySQL Server的连接上限数,这会报'too many connections'的错误
推荐值:
inactive_timeout=172800
wait_timeout=172800
● 参数介绍
interactive_timeout
参数含义:服务器关闭交互式连接所等待的秒数
wait_timeout
参数含义:服务器关闭非交互式连接所等待的秒数
⑷ transaction-isolation和binlog-format
推荐配置
▼只读为主的业务应用场景
transaction-isolation=read-commited
binlog-format=mixed
▼非只读为主的业务应用场景
transaction-isolation=repeatabled-read
binlog-format=mixed
⑸ innodb_adaptive_hash_index
● 推荐理由
InnoDB引擎会根据数据的访问频繁度,把表的数据逐渐缓到内存,若是一张表的数据大量缓存在内存中
则使用 HASH Index 会更高效
InnoDB内有Hash Index机制,监控数据的访 问情况,可以自动创建和维护一个Hash Index
⑹ innodb_max_dirty_pages_pct
● 推荐理由
InnoDB较之MyISAM,一个重要特性是InnoDB会在内存中开辟一个Buffer Pool来存储最近访问的数据块/索引块
使得下次再次访问这个块时速度能够很快、当InnoDB对需要修改数据块的时候
会先记录修改日志,然后直接对Buffer_Pool中的数据块的操作
记录日志是顺序写,对数据块的操作是内存操作,这让InnoDB在很多场景下有这很好的速度优势
上面对内存块修改完成后,InnoDB就向客户端返回了
可这时实际磁盘上的数据块,还并没有被更新,我们把这样的page称为Dirty Page
在InnoDB的后台有一个专门的线程来做将内存数据块Flush到磁盘的工作
参数innodb_max_dirty_pages_pct可以直接控制了Dirty_Page在Buffer_Pool中所占的比率
一般范围建议设置为5%~90%
比例设置较小,有利于减少mysqld服务出现问题的时候恢复时间,缺点则是需要更多的物理I/O
● 参数介绍
innodb_max_dirty_pages_pct与检查点的关系
show innodb status\G;查看检查点位置
减小innodb_max_dirty_pages_pct、会增加检查点事件发生的频率、从而减少脏页数量
生产环境中、我们经常发现:
数据库运行一段时间后,经常导致服务器大量的swap
有可能是innodb中的脏数据太多了,因为没有free space了,
mysql通知OS,把一些脏页交换出去
那么我们可尝试减小innodb_max_dirty_pages_pct
⑺ innodb_commit_concurrency
● 推荐理由
参数含义:同一时刻,允许多少个线程同时提交InnoDB事务,默认值为0,范围0-1000
0:允许任意数量的事务在同一时间点提交
N>0:允许N个事务在同一时间点提交
不过、在mysqld提供服务时、不允许把非0改为0或者把0改为非0、但可以在两个非0值之间进行变更
⑻ innodb_fast_shutdown and innodb_force_recovery
● 推荐理由
innodb_fast_shutdown
参数含义:设置innodb引擎关闭的方式,默认值为:1,正常关闭的状态
0:mysqld服务关闭前,先进行数据完全的清理和插入缓冲区的合并操作
若是脏数据较多或者服务器性能等因素,会导致此过程需要数分钟或者更长时间
1:正常关闭mysqld服务,针对innodb引擎不做任何其他的操作
2:若是mysqld出现崩溃,立即刷事务日志到磁盘上并且冷关闭mysqld服务
没有提交的事务将会丢失,但是再启动mysqld服务的时候会进行事务回滚恢复
innodb_force_recovery
参数含义:mysqld服务出现崩溃之后,InnoDB引擎进行回滚的模式,默认值为0,可设置的值0~6
0:正常的关闭和启动,不会做任何强迫恢复操作
1:跳过错误页,让mysqld服务继续运行。跳过错误索引记录和存储页,尝试用:
SELECT * INOT OUTFILE ‘../filename’ FROM tablename;方式,完成数据备份
2:阻止InnoDB的主线程运行。清理操作时出现mysqld服务崩溃,则会阻止数据恢复操作
3:恢复的时候,不进行事务回滚
4:阻止INSERT缓冲区的合并操作。不做合并操作,为防止出现mysqld服务崩溃。不计算表的统计信息
5:mysqld服务启动的时候不检查回滚日志:InnoDB引擎对待每个不确定的事务就像提交的事务一样
6:不做事务日志前滚恢复操作
推荐的参数组合配置:
innodb_fast_shutdown = 1
#若是机房条件较好可设置为0(双路电源、UPS、RAID卡电池和供电
系统稳定性)
innodb_force_recovery =0
#至于出问题的时候,设置为何值,要视出错的原因和程度,对数据后续做的操作
⑼ innodb_additional_mem_pool_size
● 推荐理由
参数含义:开辟一片内存用于缓存InnoDB引擎的数据字典信息和内部数据结构(比如:自适应HASH索引结构)
默认值:build-in版本默认值为:1M;Plugin-innodb版本默认值为:8M;
若是mysqld服务上的表对象数量较多,InnoDB引擎数据量很大,且innodb_buffer_pool_size的值设置较大
则应该适当地调整innodb_additional_mem_pool_size的值
若是出现缓存区的内存不足,则会直接向OS申请内存分配,并且会向MySQL的error log文件写入警告信息
⑽ innodb_buffer_pool_size
● 推荐理由
参数含义:开辟一片内存用于缓存InnoDB引擎表的数据和索引
参数最大值:受限于CPU的架构,支持32位还是支持64位,另外还受限于OS为32位还是64位
innodb_buffer_pool_size的值设置合适,会节约访问表对象中数据的物理IO
InnoDB占用的内存,除innodb_buffer_pool_size用于存储页面缓存数据外,另外正常情况下还有大约8%的开销
主要用在每个缓存页帧的描述、adaptive hash等数据结构,如果不是安全关闭,启动时还要恢复的话
还要另开大约12%的内存用于恢复,两者相加就有差不多21%的开销
所以、在分配innodb_buffer_pool_size时应该多加留意
对于一个专用的DB,理论上可以分到60%-80%的内存给DB. 分到60%-80%是不是就OK了,就不用管了.当然不是了
是不是合适,可以通过show engine innodb status\G; 查看命中情况. 当命中没达到97%以上,都可以考虑加内存
在保证系统不宕机,不发生内存溢出(OOM),不发生严重内存swap,给myisam、其他应用及系统预留一定份额前提下
给innodb分配的buffer越大越好,浪费就浪费点,早晚都能用上的,谁让内存越来越便宜了呢
⑾ innodb_flush_log_at_trx_commit AND sync_binlog
● 推荐理由
innodb_flush_log_at_trx_commit = N
N=0 – 每隔一秒,把事务日志缓存区的数据写到日志文件中,以及把日志文件的数据刷新到磁盘上
N=1 – 每个事务提交时候,把事务日志从缓存区写到日志文件中,并且刷新日志文件的数据到磁盘上
N=2 – 每事务提交的时候,把事务日志数据从缓存区写到日志文件中;每隔一秒,刷新一次日志文件
但不一定刷新到磁盘上,而是取决于操作系统的调度
sync_binlog = N
N>0 — 每向二进制日志文件写入N条SQL或N个事务后,则把二进制日志文件的数据刷新到磁盘上
N=0 — 不主动刷新二进制日志文件的数据到磁盘上,而是由操作系统决定
推荐配置组合:
N=1,1 — 适合数据安全性要求非常高,而且磁盘IO写能力足够支持业务,比如充值消费系统
N=1,0 — 适合数据安全性要求高,磁盘IO写能力支持业务不富余,允许备库落后或无复制
N=2,0或2,m(0<m<100) — 适合数据安全性有要求,允许丢失一点事务日志,复制架构的延迟也能接受
N=0,0 — 磁盘IO写能力有限,无复制或允许复制延迟稍微长点能接受,例如:日志性登记业务
⑿ innodb_file_per_table
● 推荐理由
参数含义:每个表一个表空间
如果设置了便可以明确知道innodb表究竟占多大空间了
表备份方便了,删除能回收空间
如果是共享表空间, 当你的表多,表空间会撑得很大; 当然随着表的删除,也会留下不少空隙
如果是独立表空间, 在做数据维护的时候也会特别清晰,比如alter table , 结束后会把临时产生的空间释放;
而如果是共享表空间,临时扩大的空间,是不会及时收缩的、可能会存在大量碎片
共享表空间在Insert操作上稍有优势。其它都没独立表空间表现好
⒀ key_buffer_size
● 推荐理由
对于我们只使用InnoDB引擎的数据库系统而言,此参数值也不能设置过于偏小
因为临时表可能会使用到此键缓存区空间,索引缓存区推荐:64M
⒁ query_cache_type和query_cache_size
● 推荐理由
query_cache_type=N
N=0 —- 禁用查询缓存的功能
N=1 —- 启用产讯缓存的功能,缓存所有符合要求的查询结果集,除SELECT SQL_NO_CACHE..,
以及不符合查询缓存设置的结果集外
N=2 —- 仅仅缓存SELECT SQL_CACHE …子句的查询结果集,除不符合查询缓存设置的结果集外
query_cache_size
查询缓存设置多大才是合理?至少需要从四个维度考虑:
① 查询缓存区对DDL和DML语句的性能影响;
② 查询缓存区的内部维护成本;
③ 查询缓存区的命中率及内存使用率等综合考虑
④ 业务类型
query_cache_size的工作原理:
一个SELECT查询在DB中工作后,DB会把该语句缓存下来,当同样的一个SQL再次来到DB里调用时,
DB在该表没发生变化的情况下把结果从缓存中返回给Client
这里有一个关建点,就是DB在利用Query_cache工作时,要求该语句涉及的表在这段时间内没有发生变更
那如果该表在发生变更时,Query_cache里的数据又怎么处理呢?
首先要把Query_cache和该表相关的语句全部置为失效,然后在写入更新
那么如果Query_cache非常大,该表的查询结构又比较多,查询语句失效也慢,一个更新或是Insert就会很慢
所以在数据库写入量或是更新量也比较大的系统,该参数不适合分配过大。而且在高并发,写入量大的系统,建系把该功能禁掉
- 明白生产环境中的jvm参数
明白生产环境中的jvm参数 写代码的时候,程序写完了,发到线上去运行,跑一段时间后,程序变慢了,cpu负载高了--一堆问题出来了,所以了解一下生产环境的机器上的jvm配置是有必要的.比如说: JDK版 ...
- 生产环境MySQL数据库集群MHA上线实施方案
生产环境MySQL数据库集群MHA上线实施方案 一.不停库操作 1.在所有节点安装MHAnode所需的perl模块(需要有安装epel源) yum install perl-DBD-MySQL -y ...
- Windows Mysql Server重启, log-bin路径配置
Windows Mysql Server重启, log-bin路径配置 分类: mysql数据库2014-03-16 14:49 1313人阅读 评论(0) 收藏 举报 Mysqlmysql serv ...
- mysql server的安装和配置
YSQL-5.7.9.1解压版 例如我的在D:\Program Files\MySQL\MySQL Server 5.7(解压时名字mysql-installer-community-5.7.9.1可 ...
- K8S生产环境中实践高可靠的配置和技巧都有哪些?
K8S环境中实践高可靠的配置和技巧都有哪些? 磁盘类型及大小 磁盘类型: 推荐使用ssd 磁盘 对于worker节点,创建集群时推荐使用挂载数据盘.这个盘是专门给/var/lib/docker 存放本 ...
- 生产环境mysql的参数设置不一样,好好的程序,又出错
一.概述 报错信息如下: org.springframework.jdbc.BadSqlGrammarException: ### Error querying database. Cause: c ...
- 生产环境MySQL优化
a:硬件的优化: 1. 采用64位cpu,cpu至少4颗,L2缓存越大越好2. 内存要大,32-64G运行1-2个实例,96-128G运行3-4个实例3. 机械盘选用sas盘,转速15000以上,有可 ...
- 马老师 生产环境mysql主从复制、架构优化方案
Binlog日志(主服务器) => 中继日志(从服务器 运行一遍,保持一致).从服务器是否要二进制日志取决于架构设计.如果二进制保存足够稳定,从性能上来说,从服务器不需要二进制日志.默认情况下, ...
- Python 生产环境MySQL数据库增量备份脚本
MySQL数据库常用的办法是通过MySQLdump导出sql进行备份,但是不适合数据量很大的数据库,速度,锁表是两个严重的问题.前面写了一遍文章介绍xtrabackup的热备工具,见 http://w ...
随机推荐
- javascript区分电脑与手机登陆
<script language="javascript"> function checkMobile() { var pda_user_agent_list = ne ...
- Javascript个人理解
一. 生成对象的原始模式 假定我们把猫看成一个对象,它有"名字"和"颜色"两个属性. var Cat = { name : '', color : '' } 现 ...
- .net mvc结合微软提供的FormsAuthenticationTicket登陆
一.Web.config <system.web> <compilation debug="true" targetFramework="4.5&quo ...
- jquery-1.10.2 获取checkbox的checked属性总是undefined
项目中用的jquery-1.10.2 需要检测一个checkbox的选中状态,想当然的用 .attr("checked") ,结果发现,无论是否选中,这个值都是 undefined ...
- (转)centos6起/etc/syslog.conf不再有!而是/etc/rsyslog.conf代替!
centos6起/etc/syslog.conf不再有!而是/etc/rsyslog.conf代替!
- adnroid 监听收到的短信并根据短信内容进行回复短信
定义一个广播接收器 public class SMSReceiver extends BroadcastReceiver { private SmsManager smsManager; @Overr ...
- hdu 1142 A Walk Through the Forest
http://acm.hdu.edu.cn/showproblem.php?pid=1142 这道题是spfa求最短路,然后dfs()求路径数. #include <cstdio> #in ...
- bzoj 1912 巡逻(树直径)
Description Input 第一行包含两个整数 n, K(1 ≤ K ≤ 2).接下来 n – 1行,每行两个整数 a, b, 表示村庄a与b之间有一条道路(1 ≤ a, b ≤ n). Ou ...
- Qt之四方分割器QuadSplitter
在Qt经常会用到分割器QSplitter,可以对多个控件进行水平或者垂直分割,但有一些特殊的需求无法满足,比如:四方分割...QuadSplitter是qt-apps里面的一个应用,挺不错的,拿来和大 ...
- 使用OpenSSL生成证书
使用OpenSSL生成证书 下载安装openssl,进入/bin/下面,执行命令(把ssl目录下的openssl.cnf 拷贝到bin目录下)1.首先要生成服务器端的私钥(key文件):openssl ...