mysql优化的重要参数 key_buffer_size table_cache

本文深入探讨了MySQL服务器的关键参数调整策略,包括如何优化key_buffer_size和table_cache,以及如何通过监控状态变量来判断参数设置是否合理。文章详细解释了这些参数对服务器性能的影响,提供了实用的诊断方法和调整建议,帮助数据库管理员提升数据库性能。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

MySQL服务器端的参数有很多,但是对于大多数初学者来说,众多的参数往往使得我们不知所措,但是哪些参数是需要我们调整的,哪些对服务器的性能影响最大呢?对于使用Myisam存储引擎来说,主要key_buffer_sizetable_cache两个参数。对于InnoDB引擎来说主要还是以innodb_开始的参数,也很好辨认。
查看MySQL参数,可以使用show variablesshow status命令查看,前者查看服务器静态参数,即在数据库启动后不会动态更改的值,比如缓冲区、字符集等。后者查看服务器的动态运行状态信息,即数据库运行期间动态变化的信息,比如锁,当前连接数等。
key_buffer_size这个参数是用来设置索引块(index blocks)缓存的大小,它被所有线程共享,严格说是它决定了数据库索引处理的速度,尤其是索引读的速度。那我们怎么才能知道key_buffer_size的设置是否合理呢,一般可以检查状态值Key_read_requests和Key_reads,比例key_reads / key_read_requests应该尽可能的低,比如1:100,1:1000 ,1:10000。其值可以用以i下命令查得:
mysql> show status like 'key_read%';
+-------------------+------------+
| Variable_name     | Value      |
+-------------------+------------+
| Key_read_requests | 3916880184 | 
| Key_reads         | 1014261    | 
+-------------------+------------+
2 rows in set (0.00 sec)
3916880184/1024/1024=?M    //单位为兆
我的key_buffer_size值为:
key_buffer_size=536870912/1024/1024=512M,
key_reads / key_read_requests=1014261: 3916880184≈1:4000,照上面来看,健康状况还行。
table_cache指定表高速缓存的大小。每当MySQL访问一个表时,如果在表缓冲区中还有空间,该表就被打开并放入其中,这样可以更快地访问表内容。通过检查峰值时间的状态值Open_tables和Opened_tables,可以决定是否需要增加table_cache的值。如果你发现open_tables等于table_cache,并且opened_tables在不断增长,那么你就需要增加table_cache的值了(上述状态值可以使用SHOW STATUS LIKE ‘Open%tables’获得)。注意,不能盲目地把table_cache设置成很大的值。如果设置得太高,可能会造成文件描述符不足,从而造成性能不稳定或者连接失败。
open_tables表示当前打开的表缓存数,如果执行flush tables操作,则此系统会关闭一些当前没有使用的表缓存而使得此状态值减小;
opend_tables表示曾经打开的表缓存数,会一直进行累加,如果执行flush tables操作,值不会减小。
在mysql默认安装情况下,table_cache的值在2G内存以下的机器中的值默认时256到512,如果机器有4G内存,则默认这个值是2048,但这决意味着机器内存越大,这个值应该越大,因为table_cache加大后,使得mysql对SQL响应的速度更快了,不可避免的会产生更多的死锁(dead lock),这样反而使得数据库整个一套操作慢了下来,严重影响性能。所以平时维护中还是要根据库的实际情况去作出判断,找到最适合你维护的库的table_cache值。
就是table_cache加大后碰到文件描述符不够用的问题,在mysql的配置文件中有这么一段提示:
引用
“The number of open tables for all threads. Increasing this value increases the number of file descriptors that mysqld requires.
Therefore you have to make sure to set the amount of open files allowed to at least 4096 in the variable "open-files-limit" in” section [mysqld_safe]”
说的就是要注意这个问题,一想到这里,部分兄弟可能会用ulimit -n 作出调整,但是这个调整实际是不对的,换个终端后,这个值又会回到原始值,所以最好用sysctl或者修改/etc/sysctl.conf文件,同时还要在配置文件中把open_files_limit这个参数增大,对于4G内存服务器,相信现在购买的服务器都差不多用4G的了,那这个这个open_files_limit至少要增大到4096,如果没有什么特殊情况,设置成8192就可以了。
innodb_buffer_pool_size 这个参数和MyISAM的key_buffer_size有相似之处,但也是有差别的。这个参数主要缓存innodb表的索引,数据,插入数据时的缓冲。为Innodb加速优化首要参数。  该参数分配内存的原则:这个参数默认分配只有8M,可以说是非常小的一个值。如果是一个专用DB服务器,那么他可以占到内存的70%-80%。这个参数不能动态更改,所以分配需多考虑。分配过大,会使Swap占用过多,致使Mysql的查询特慢。如果你的数据比较小,那么可分配是你的数据大小+10%左右做为这个参数的值。
<think>好的,我需要帮助用户了解如何通过SQL语句动态修改InnoDB及MySQL的配置参数,比如innodb_buffer_pool_size和innodb_log_file_size。首先,我得回顾一下相关知识,确保自己理解正确。 用户提到了使用SET GLOBAL命令,这确实是动态调整参数的主要方法。根据引用[1]、[2]、[3]中的信息,innodb_buffer_pool_size是一个重要的参数,它影响InnoDB的性能。不过,有些参数是动态的,可以即时生效,而有些可能需要重启才能生效。例如,innodb_buffer_pool_sizeMySQL 5.7及以上版本支持动态调整,但innodb_log_file_size可能需要重启。 接下来,我需要分步骤说明如何使用SET GLOBAL命令。首先,确认当前参数值,可以用SHOW VARIABLES命令,如引用[2]中的示例。然后,使用SET GLOBAL来修改参数,但要注意权限问题,必须要有SUPER权限。例如,修改innodb_buffer_pool_size的命令是SET GLOBAL innodb_buffer_pool_size=字节数。但需要提醒用户,这个参数可能需要一些时间来调整,因为InnoDB需要重新分配内存。 另外,有些参数不能动态修改,比如innodb_log_file_size,这时候需要修改配置文件并重启MySQL。用户需要明确区分动态和静态参数,避免无效操作。 然后,生成相关问题。用户可能想知道如何确认参数是否动态,或者修改后如何验证,以及不同参数的具体影响。例如,动态调整buffer pool对性能的影响,或者如何监控参数调整后的效果。 最后,确保回答结构清晰,步骤明确,引用相关的内容,比如引用[3]提到的物理内存的80%建议,以及合并写入操作的优势。同时,提醒用户注意潜在的问题,如内存竞争或需要重启的情况。 可能还需要检查是否有遗漏的参数或特殊情况,比如某些参数的单位(字节还是其他),或者不同MySQL版本的差异。比如,在旧版本中innodb_buffer_pool_size可能不支持动态调整,需要确认用户使用的版本。 总结步骤应该是:确认参数是否动态,使用SET GLOBAL修改动态参数,处理静态参数需重启,以及注意事项和相关命令。这样用户就能清晰地进行操作了。</think>### 如何通过SQL动态修改InnoDB及MySQL配置参数 #### 1. **动态参数与静态参数的区别** - **动态参数**:可通过`SET GLOBAL`命令直接修改并立即生效,例如`innodb_buffer_pool_size`(需MySQL 5.7+)[^3]。 - **静态参数**:需修改配置文件并重启MySQL服务,例如`innodb_log_file_size`[^1]。 #### 2. **使用`SET GLOBAL`修改动态参数** **步骤**: 1. **查看当前参数值**: ```sql SHOW GLOBAL VARIABLES LIKE 'innodb_buffer_pool_size'; -- 示例输出:Value=134217728(即128MB) ``` [^2] 2. **动态修改参数**(需`SUPER`权限): ```sql SET GLOBAL innodb_buffer_pool_size = 1073741824; -- 修改为1GB ``` - **注意**:调整`innodb_buffer_pool_size`时,InnoDB会异步调整内存池大小,可能需要数秒完成。 #### 3. **静态参数的修改方法** 以`innodb_log_file_size`为例: 1. **停止MySQL服务**。 2. **修改配置文件**(如`my.cnf`): ```ini [mysqld] innodb_log_file_size = 256M ``` 3. **重启MySQL服务**。 #### 4. **关键参数示例** | 参数名 | 是否支持动态修改 | 说明 | |-------------------------|------------------|----------------------------------------------------------------------| | `innodb_buffer_pool_size` | 是(5.7+) | 控制InnoDB缓存池大小,建议设为物理内存的70-80%。 | | `innodb_flush_log_at_trx_commit` | 是 | 事务提交时日志刷新策略(0/1/2),影响数据安全性与性能。 | | `key_buffer_size` | 是 | MyISAM引擎的索引缓存,需注意与InnoDB参数的区分[^3]。 | #### 5. **注意事项** - **权限要求
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值