`

mysql cpu占100%调优案例

 
阅读更多
解决 MYSQL CPU 占用 100% 的经验总结

    A 增加 tmp_table_size 值。mysql 的配置文件中,tmp_table_size 的默认大小是 32M。如果一张临时表超出该大小,MySQL产生一个 The table tbl_name is full 形式的错误,如果你做很多高级 GROUP BY 查询,增加 tmp_table_size 值。 这是 mysql 官方关于此选项的解释:
  tmp_table_size
  This variable determines the maximum size for a temporary table in memory. If the table becomes too large, a MYISAM table is created on disk. Try to avoid temporary tables by optimizing the queries where possible, but where this is not possible, try to ensure temporary tables are always stored in memory. Watching the processlist for queries with temporary tables that take too long to resolve can give you an early warning that tmp_table_size needs to be upped. Be aware that memory is also allocated per-thread. An example where upping this worked for more was a server where I upped this from 32MB (the default) to 64MB with immediate effect. The quicker resolution of queries resulted in less threads being active at any one time, with all-round benefits for the server, and available memory.

  B 对 WHERE, JOIN, MAX(), MIN(), ORDER BY 等子句中的条件判断中用到的字段,应该根据其建立索引 INDEX。索引被用来快速找出在一个列上用一特定值的行。没有索引,MySQL不得不首先以第一条记录开始并然后读完整个表直到它找出相关的行。表越大,花费时间越多。如果表对于查询的列有一个索引,MySQL能快速到达一个位置去搜寻到数据文件的中间,没有必要考虑所有数据。如果一个表有1000行,这比顺序读取至少快100倍。所有的MySQL索引(PRIMARY、UNIQUE和INDEX)在B树中存储。

根据 mysql 的开发文档:
  
索引 index 用于:
  1.快速找出匹配一个WHERE子句的行,
  2.当执行联结(JOIN)时,从其他表检索行,
  3.对特定的索引列找出MAX()或MIN()值,
  4.如果排序或分组在一个可用键的最左面前缀上进行(例如,ORDER BY key_part_1,key_part_2),排序或分组一个表。如果所有键值部分跟随DESC,键以倒序被读取。
  在一些情况中,一个查询能被优化来检索值,不用咨询数据文件。如果对某些表的所有使用的列是数字型的并且构成某些键的最左面前缀,为了更快,值可以从索引树被检索出来。
  假定你发出下列SELECT语句:
  
      mysql> SELECT * FROM tbl_name WHERE col1=val1 AND col2=val2;
    

  如果一个多列索引存在于col1和col2上,适当的行可以直接被取出。如果分开的单行列索引存在于col1和col2上,优化器试图通过决定哪个索引将找到更少的行并来找出更具限制性的索引并且使用该索引取行。
  开发人员做 SQL 数据表设计的时候,一定要通盘考虑清楚。

转自:http://lestang.iteye.com/blog/1683902
分享到:
评论
发表评论

文章已被作者锁定,不允许评论。

相关推荐

    MySQL管理之道 性能调优、高可用与监控.part2.rar

    《mysql管理之道:性能调优、高可用与监控》由资深mysql专家撰写,以最新的mysql版本为基础,以构建高性能mysql服务器为核心,从故障诊断、表设计、sql优化、性能参数调优、mydumper逻辑、xtrabackup热备份与恢复、...

    Mysql运维调优

    在IT领域,特别是数据库管理与优化方面,MySQL作为一种广泛使用的开源关系型数据库系统,其运维与调优一直是DBA(数据库管理员)和技术人员关注的重点。本文将基于“MySQL运维调优”的主题,深入探讨相关的核心知识...

    MySQL DBA性能调优 全攻略

    本文将详细介绍MySQL数据库性能调优的方法和技术,包括操作系统层面的优化、文件系统的选择、硬件配置建议、SQL语句优化技巧以及数据库内部配置的调整等。 #### 二、操作系统优化 1. **内核参数调整**: - 调整...

    MYSQL集群+HA高可用【MySQL性能调优】.pdf

    本文详细介绍了如何通过MySQL集群加上高可用性(HA)配置来实现MySQL性能调优的实践案例,文档中涉及到的操作步骤,适用于希望提高数据库性能与稳定性的用户。 知识点1:MySQL Cluster简介 MySQL Cluster是一种多主机...

    MySQL性能调优最佳实践

    ### MySQL性能调优最佳实践 #### 一、引言 MySQL作为全球最广泛使用的开源关系型数据库管理系统之一,在众多应用场景中扮演着至关重要的角色。随着数据量的不断增长和技术的发展,如何有效地提升MySQL的性能成为了...

    基于MySQL性能调优的推荐系统优化设计.pdf

    本文通过介绍一项研究案例——基于MySQL性能调优的推荐系统的优化设计,探讨了如何通过技术手段改善MySQL数据库的性能,从而提升整个推荐系统的运行效率。 #### MySQL性能调优的重要性 MySQL作为一款广泛使用的...

    MySQL性能调优与架构设计

    《MySQL性能调优与架构设计》是一本由阿里巴巴DBA团队编著的专业书籍,它深入探讨了MySQL数据库在实际业务中的优化策略和架构构建。本书旨在帮助读者掌握如何提升MySQL数据库的性能,确保系统的稳定性和高可用性。...

    mysql性能调优与架构设计--全册 .rar_SPF7_mysql 性能调优_架构优化

    MySQL性能调优与架构设计是数据库管理领域的重要课题,尤其在处理大数据量时,优化技巧和架构...这份"mysql性能调优与架构设计--全册 .pdf"文档将为读者提供详尽的指导和实践案例,帮助数据库管理员更好地应对挑战。

    mysql占用CPU过高的解决办法(添加索引)

    MySQL数据库在运行过程中,如果CPU使用率过高,可能会影响整个系统的性能,甚至导致服务中断。这种情况通常是由于多种因素引起的,包括但不限于不优化的查询、无索引的查询、内存配置不当等。以下是一些解决MySQL ...

    mysql高并发解决方案

    9. **硬件升级**:增加内存、使用SSD硬盘、提升CPU性能等硬件优化,可以显著提升MySQL处理高并发的能力。 10. **架构设计**:采用微服务架构,将单一应用拆分为一组小型服务,每个服务都有独立的数据库,可以独立...

    LINUX性能调优方法总结

    1. **系统监控工具**:了解并使用如`top`, `htop`, `vmstat`, `iostat`, `mpstat`, `free`, `dstat`等工具来监控系统CPU、内存、磁盘I/O和网络活动,这些都是性能调优的基础。 2. **进程管理**:分析高CPU或内存...

    linux性能调优一些整合文档打包

    CPU调优主要包括进程调度策略调整(如nice值和renice命令)、内核参数优化(比如sysctl配置)以及CPU亲和性设置。通过合理分配优先级,可以改善高负载时的系统响应。 3. **内存管理**: 内存调优关注如何高效利用...

    性能调优常规手段

    ### 性能调优常规手段详解 #### 一、引言 在当今信息化时代,无论是企业级应用还是个人软件开发项目,系统性能都是至关重要的考量因素之一。性能调优不仅关乎用户体验,也是确保业务顺利运行的关键。本文将深入探讨...

    2017最新老男孩MySQL高级专业DBA实战课程全套【清晰不加密】,看完教程月入40万没毛病

    第一部 MySQL基础入门(21节) 01-老男孩运维DBA课程开班...04-linux进程占用cpu高的解决方案案例.avi 05-数据库账户权限控制多种思路及技巧.avi 06-数据库客户端安全控制策略详解.avi 07-数据库运维的核心管理思想.avi

    高级MySQL性能优化

    8. 硬件和操作系统优化:分析硬件(CPU、内存、存储等)和操作系统对MySQL性能的影响,以及如何选择合适的硬件和操作系统参数以提高性能。 9. 现实应用问题:讨论在实际应用中遇到的性能问题,并提供解决这些问题的...

    云数据库十大经典案例.rar

    10. 监控与调优:通过监控数据库性能指标,如CPU使用率、I/O等待时间、QPS(每秒查询数)、TPS(每秒事务数)等,及时发现并解决问题,进行性能调优。 这份《云数据库十大经典案例》涵盖了从基础架构到高级应用的全...

Global site tag (gtag.js) - Google Analytics