mysql - 缓慢的 MySQL 更新/插入/删除

标签 mysql performance

我似乎在使用 MySQL 对特定数据库的所有表进行缓慢的插入、更新和删除。这些表中的数据不多(从 2k 到 20k)。列数较少(5-10),索引(其中两个),并且没有重复索引问题。我正在使用 MyISAM 运行 MySQL 5.0.45。

我运行以下查询,大约需要 5-7 秒:

UPDATE accounts SET updated_at = '2010-10-09 11:22:53' WHERE id = 8;

选择似乎马上回来了。

解释给了我以下内容:

+----+-------------+----------+-------+---------------+---------+---------+------+------+-------------+
| id | select_type | table    | type  | possible_keys | key     | key_len | ref  | rows | Extra       |
+----+-------------+----------+-------+---------------+---------+---------+------+------+-------------+
|  1 | SIMPLE      | accounts | index | NULL          | PRIMARY | 4       | NULL | 1841 | Using index | 
+----+-------------+----------+-------+---------------+---------+---------+------+------+-------------+

除了看似大量的上下文切换之外,探查器没有显示任何重要数据:

+----------------------+----------+-------------------+---------------------+
| Status               | Duration | Context_voluntary | Context_involuntary |
+----------------------+----------+-------------------+---------------------+
| (initialization)     | 0.000057 |                 0 |                   0 | 
| checking permissions | 0.000008 |                 0 |                   0 | 
| Opening tables       | 0.000013 |                 0 |                   0 | 
| System lock          | 0.000005 |                 0 |                   0 | 
| Table lock           | 0.000005 |                 0 |                   0 | 
| init                 | 0.000061 |                 0 |                   0 | 
| Updating             | 0.000101 |                 0 |                   0 | 
| end                  | 7.957233 |              7951 |                   2 | 
| query end            | 0.000008 |                 0 |                   0 | 
| freeing items        | 0.000011 |                 0 |                   0 | 
| closing tables       | 0.000007 |                 1 |                   0 | 
| logging slow query   | 0.000002 |                 0 |                   0 | 
+----------------------+----------+-------------------+---------------------+

这也可能有帮助:

+----------------------+----------+-----------------------+---------------+-------------+
| Status               | Duration | Source_function       | Source_file   | Source_line |
+----------------------+----------+-----------------------+---------------+-------------+
| (initialization)     | 0.000057 | check_access          | sql_parse.cc  |        5306 | 
| checking permissions | 0.000008 | open_tables           | sql_base.cc   |        2629 | 
| Opening tables       | 0.000013 | mysql_lock_tables     | lock.cc       |         153 | 
| System lock          | 0.000005 | mysql_lock_tables     | lock.cc       |         162 | 
| Table lock           | 0.000005 | mysql_update          | sql_update.cc |         167 | 
| init                 | 0.000061 | mysql_update          | sql_update.cc |         429 | 
| Updating             | 0.000101 | mysql_update          | sql_update.cc |         560 | 
| end                  | 7.957233 | mysql_execute_command | sql_parse.cc  |        5122 | 
| query end            | 0.000008 | mysql_parse           | sql_parse.cc  |        6116 | 
| freeing items        | 0.000011 | dispatch_command      | sql_parse.cc  |        2146 | 
| closing tables       | 0.000007 | log_slow_statement    | sql_parse.cc  |        2204 | 
| logging slow query   | 0.000002 | dispatch_command      | sql_parse.cc  |        2169 | 
+----------------------+----------+-----------------------+---------------+-------------+

附加信息: 它在 CentOS-5 VPS 上运行,保证有 4 GB 的内存。 updated_at 列上没有索引,也不会在任何地方触发。

[我尝试的新事物]

  1. 创建了一个新表(使用 like) 运行 innodb 并插入所有 其中一位受影响者的记录 表。 (同样的问题)
  2. 备份数据库并将其恢复到 同一数据库中的不同数据库 服务器实例。 (同样的问题)
  3. 将相同的备份恢复到我的 本地机器,我没有 问题。
  4. 尝试了另一个数据库 在同一个 mysql 服务器中 有问题的实例 数据库和另一个数据库(一个 Wordpress 数据库)跑了 更新/插入/删除就好了。
  5. 昨晚重启了mysqld并重启了整个服务器(同样的问题)
  6. 将 MySQL 更新到版本 5.0.77(同样的问题)
  7. 已从其中一个受影响的表中删除所有索引(同样的问题)

任何想法接下来要看什么或可能是什么问题?似乎是最近才出现的问题,但我不能说它是什么时候开始出现的。

最佳答案

如果您有可变长度的行,您可能需要偶尔运行OPTIMIZE TABLE

关于mysql - 缓慢的 MySQL 更新/插入/删除,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/4320719/

相关文章:

java - RUNNABLE 线程在 native 方法中可能不消耗 CPU?

mysql - 在多表删除上使用动态数据库名称的过程

performance - 使用 commitWithin 的 Solr 性能没有意义

ruby - Ruby 性能中的计时器

php - 我需要介绍 MongoDB/NoSQL 数据库

c# - 应用 "Join"方法的最佳方法通常类似于 String.Join(...) 的工作方式?

css - Knockout.js 和大数据集也使下拉列表变慢

mysql - 如何在 Bluemix 中备份 MySQL 数据库?

mysql - 多列困惑

php - 性能:将 soundex 放入数据库还是在查询后翻译它?