zoukankan      html  css  js  c++  java
  • 【转】生产环境MySQL Server核心参数的配置

     
       ⑴ 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 statusG;查看检查点位置
             减小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 statusG; 查看命中情况. 当命中没达到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就会很慢
             
             所以在数据库写入量或是更新量也比较大的系统,该参数不适合分配过大。而且在高并发,写入量大的系统,建系把该功能禁掉
     
    [星空刺] |-->一颗星辰一闪即逝,支撑它的唯有方向和目的
  • 相关阅读:
    java持续添加内容至本地文件
    ArrayList与LinkedList的区别,如何减少嵌套循环的使用
    linux系统设置允许密码登录
    postgreSQL格式化时间的函数详解
    POSTGRESQL日期函数大全
    RESTful API规范
    ASP.NET Core实践:ABP模块化&统一返回结果
    ASP.NET Core实践:中间件
    Salesforce经历
    Git常用命令整理
  • 原文地址:https://www.cnblogs.com/aaa103439/p/3300500.html
Copyright © 2011-2022 走看看