量体裁衣是为了做出更加合身的衣服,把脉查问病情是为了更好的对症下药合理医治。对于MySQL数据库维护排错也是这个道理,我们需要清楚地了解MySQL的内部处于何种什么运行状态,判断出现的是哪一类问题,然后寻根纠源将其问题解决。在MySQL中我们可以通过两种方式去查看它的各种状态各项参数指标:一种方法是查看默认的INFORMATION_SCHEMA数据库、另一种就是通过SHOW的各种参数的命令组合去查看。
2. SHOW
下面我们再来看看show带给我们的方便快捷的各项显示结果。在进行下面的讨论之前,先来看两个单词variables 和status, 他们出来的结果截然不同的,前者是系统参数,就是系统启动的时候从配置文件或是选项中获得的参数,是read-only的,修改后必须重启数据库服务才能生效;而或者是个状态参数,也就是说随着数据库系统的不断运行,它是在时刻变化的,而我们正是通过观察这些参数值的波动情况来判断分析系统的运行状况,进而更加优化MySQL数据库。
mysql> show variables;
+———————————+———————————+
| Variable_name | Value |
+———————————+———————————+
| auto_increment_increment | 1 |
| auto_increment_offset | 1 |
| autocommit | ON |
| automatic_sp_privileges | ON |
| back_log | 50 |
| basedir | /opt/mysql2/ |
| big_tables | OFF |
| binlog_cache_size | 32768 |
| binlog_format | MIXED |
| bulk_insert_buffer_size | 8388608 |
| character_set_client | latin1 | | - - - omit - - - |
| tmpdir | /tmp |
| transaction_alloc_block_size | 8192 |
| transaction_prealloc_size | 4096 |
| tx_isolation | REPEATABLE-READ |
| unique_checks | ON |
| updatable_views_with_limit | YES |
| version | 5.1.32-log |
| version_comment | MySQL Community Server (GPL) |
| version_compile_machine | i686 |
| version_compile_os | pc-linux-gnu |
| wait_timeout | 28800 |
| warning_count | 0 |
+———————————+———————————+
269 rows in set (0.00 sec)
mysql> show status;
+———————————–+———–+
| Variable_name | Value |
+———————————–+———–+
| Aborted_clients | 1 |
| Aborted_connects | 2 |
| Binlog_cache_disk_use | 0 |
| Binlog_cache_use | 0 |
| Bytes_received | 322 |
| Bytes_sent | 48107 |
| Com_admin_commands | 0 |
| Com_assign_to_keycache | 0 |
| Com_alter_db | 0 |
| Com_alter_db_upgrade | 0 |
| Com_alter_event | 0 |
| Com_alter_function | 0 |
| Com_alter_procedure | 0 |
| Com_alter_server | 0 || - - - omit - - - |
| Ssl_verify_mode | 0 |
| Ssl_version | |
| Table_locks_immediate | 57 |
| Table_locks_waited | 0 |
| Tc_log_max_pages_used | 0 |
| Tc_log_page_size | 0 |
| Tc_log_page_waits | 0 |
| Threads_cached | 2 |
| Threads_connected | 1 |
| Threads_created | 3 |
| Threads_running | 1 |
| Uptime | 968978 |
| Uptime_since_flush_status | 968978 |
+———————————–+———–+
291 rows in set (0.01 sec)
(一)上面show status有291条输出,我们将对它们进行大致的归类,以便在实际中做到有的放矢,可通过show status like ”的方法逐一显示想要的参数变量。
1>.显示当前的连接与线程的状态,关注以下参数:
• Connections(尝试连接数), Max_used_connections, Threads_connected(最近一次连接上来的线程id)
• Aborted_clients, Aborted_connects (相关失败的连接信息)
• Bytes_received, Bytes_sent (传输流量)
• Slow_launch_threads, Threads_cached, Threads_created, Threads_running
(Note: 各项参数的具体解释请参看手册)
2>. 二进制日志的状态
• Binlog_cache_use
• Binlog_cache_disk_use
3>. 各种命令以及操作的执行次数
• Com_*
例如:Com_alter_db、Com_delete、Com_select、Com_show_status等,大概有100多个类似状态变量。
4>. 显示MySQL目前为止产生过多少了临时的文件以及表
• Created_tmp*
5>. 记录了MySQL数据库与存储引擎之间的handler的交互次数
• Handler_*
6>. MyISAM关注的参数:
• Key_*
• Open_*
7>. 查询缓存
• Qcache_*
Status展示给我们的很多,还有很多的类别,Select_*、Sort_*、Table_locks_*、Ssl_*等。
(二)我们都知道innobd是一个事务型的存储引擎,是作为第三方引入的一个出色的存储引擎,对MySQL的安全性提升很大,使其更加具有商业性。自然它的各项参数的显示也就十分丰富,可以通过show engine innodb status;或者show innodb status;可以看到当前你的innodb对系统资源的使用是一个什么状态,它的显示结果由以下10部分组成,分为是:Header、SEMAPHORES、TRANSACTIONS、FILE I/O、INSERT BUFFER AND ADAPTIVE HASH INDEX、LOG、BUFFER POOL AND MEMORY和ROW OPERATIONS。
(三)show processlist; 这个语句可以显示当前连接到MySQL上的所有用户及其操作(小心安全隐患)。
(四)与复制应用相关的状态信息,比如查看master的状态show master status;查看slave的状态show slave status。