浅谈MySQL数据库优化
2007-11-11 13:22:01 来源:WEB开发网核心提示:我们在前面已经简单介绍了一些MySQL(和PHP搭配之最佳组合)数据库的基本操作,这一章我们将针对MySQL(和PHP搭配之最佳组合)数据库管理员详细介绍下MySQL(和PHP搭配之最佳组合)数据库的优化问题,浅谈MySQL数据库优化, 1 优化MySQL(和PHP搭配之最佳组合)服务器 1.1 MySQL(和PHP搭
我们在前面已经简单介绍了一些MySQL(和PHP搭配之最佳组合)数据库的基本操作,这一章我们将针对MySQL(和PHP搭配之最佳组合)数据库管理员详细介绍下MySQL(和PHP搭配之最佳组合)数据库的优化问题。
1 优化MySQL(和PHP搭配之最佳组合)服务器
1.1 MySQL(和PHP搭配之最佳组合)服务器系统变量
我们在前面的章节中曾经讲到过MySQL(和PHP搭配之最佳组合)服务器的一些基本管理,这里我们再对MySQL(和PHP搭配之最佳组合)服务器的服务器变量和状态变量做个简单介绍。
查询MySQL(和PHP搭配之最佳组合)服务器系统变量:
C:\Program Files\MySQL(和PHP搭配之最佳组合)\MySQL(和PHP搭配之最佳组合) Server 5.0\bin> MySQL(和PHP搭配之最佳组合)d --verbose –help通过MySQL(和PHP搭配之最佳组合)admin命令来查询MySQL(和PHP搭配之最佳组合)服务器系统变量:
C:\Program Files\MySQL(和PHP搭配之最佳组合)\MySQL(和PHP搭配之最佳组合) Server 5.0\bin>MySQL(和PHP搭配之最佳组合)admin -uroot -p variables > d:\init.txtEnter password: ******Init.txt部分内容:
+---------------------------------+----------------------------------------------------------------+| Variable_name | Value |+---------------------------------+----------------------------------------------------------------+| auto_increment_increment | 1 || auto_increment_offset | 1 || automatic_sp_privileges | ON || back_log | 50…………| version_compile_machine | ia32 || version_compile_os | Win32 || wait_timeout | 28800 |+---------------------------------+----------------------------------------------------------------+
获得MySQL(和PHP搭配之最佳组合)实际使用的服务器系统变量:
MySQL(和PHP搭配之最佳组合)> show variables;利用like参数来显示具体的服务器系统变量:
MySQL(和PHP搭配之最佳组合)> show variables like 'init_connect%';+---------------+-------+| Variable_name | Value |+---------------+-------+| init_connect | |+---------------+-------+1 row in set (0.00 sec)调整MySQL(和PHP搭配之最佳组合)服务器的系统变量
MySQL(和PHP搭配之最佳组合)d服务器维护两种变量。全局变量影响服务器的全局操作。会话变量影响具体客户端连接相关操作。服务器启动时,将所有全局变量初始化为默认值。可以在选项文件或命令行中指定的选项来更改这些默认值。服务器启动后,通过连接服务器并执行SET GLOBAL var_name语句可以更改动态全局变量。要想更改全局变量,必须具有SUPER权限。
方法一:
MySQL(和PHP搭配之最佳组合)> SHOW VARIABLES LIKE 'query_cache_size';+------------------+----------+| Variable_name | Value |+------------------+----------+| query_cache_size | 23068672 |+------------------+----------+1 row in set (0.01 sec)MySQL(和PHP搭配之最佳组合)> SET GLOBAL query_cache_size = 31457280;Query OK, 0 rows affected (0.00 sec)MySQL(和PHP搭配之最佳组合)> SHOW VARIABLES LIKE 'query_cache_size';+------------------+----------+| Variable_name | Value |+------------------+----------+| query_cache_size | 31457280 |+------------------+----------+1 row in set (0.00 sec)方法二:
MySQL(和PHP搭配之最佳组合)> show variables like 'query_cache_size%';+------------------+----------+| Variable_name | Value |+------------------+----------+| query_cache_size | 31457280 |+------------------+----------+1 row in set (0.00 sec)MySQL(和PHP搭配之最佳组合)> SET @@global.query_cache_size = 20971520;Query OK, 0 rows affected (0.09 sec)MySQL(和PHP搭配之最佳组合)> show variables like 'query_cache_size%';+------------------+----------+| Variable_name | Value |+------------------+----------+| query_cache_size | 20971520 |+------------------+----------+1 row in set (0.00 sec)MySQL(和PHP搭配之最佳组合)> select @@query_cache_size;+--------------------+| @@query_cache_size |+--------------------+| 20971520 |+--------------------+1 row in set (0.06 sec)MySQL(和PHP搭配之最佳组合)d服务器还为每个客户端连接维护会话变量。连接时使用相应全局变量的当前值对客户端会话变量进行初始化。客户可以通过SET [SESSION] var_name语句来更改动态会话变量。设置会话变量不需要特殊权限,但客户可以只更改自己的会话变量,而不更改其它客户的会话变量。
MySQL(和PHP搭配之最佳组合)> SET sort_buffer_size = 10 * 1024 * 1024;Query OK, 0 rows affected (0.08 sec)MySQL(和PHP搭配之最佳组合)> show variables like 'sort_buffer%';+------------------+----------+| Variable_name | Value |+------------------+----------+| sort_buffer_size | 10485760 |+------------------+----------+1 row in set (0.00 sec)注意,当使用启动选项设置变量时,变量值可以使用后缀K、M或G分别表示千字节、兆字节或gigabytes。例如,下面的命令启动服务器时的键值缓冲区大小为16 megabytes:
C:\ProgramFiles\MySQL(和PHP搭配之最佳组合)\MySQL(和PHP搭配之最佳组合) Server 5.0\bin>MySQL(和PHP搭配之最佳组合)d--key_buffer_size=16M后缀的大小写美关系;16M和16m是同样的。
运行时,使用SET语句来设置系统变量。此时,不能使用后缀,但值可以采取下列表达式:
MySQL(和PHP搭配之最佳组合)> SET sort_buffer_size = 10 * 1024 * 1024;
更多精彩
赞助商链接