日期:2012-12-16  浏览次数:20625 次

PS:本配置文件针对Dell R710,双至强E5620、16G内存的硬件配置。CentOS 5.6 64位系统,MySQL 5.5.x 稳定版。适用于日IP 50-100w,PV 100-300w的站点,次要使用InnoDB存储引擎。其他使用环境请依据实际情况来设置优化。

# 以下选项会被MySQL客户端使用读取。
# 留意只要MySQL附带的客户端使用程序保证可以读取这段内容。
# 如果你想你本人的MySQL使用程序获取这些值。
# 需求在MySQL客户端库初始化的时候指定这些选项。

#
[client]
#password = [your_password]
port = @MYSQL_TCP_PORT@
socket = @MYSQL_UNIX_ADDR@

# *** 使用定制选项 ***

#
# MySQL 服务端
#
[mysqld]

# 普通配置选项
port = @MYSQL_TCP_PORT@
socket = @MYSQL_UNIX_ADDR@

# back_log 是操作系统在监听队列中所能保持的连接数,
# 队列保存了在MySQL连接管理器线程处理之前的连接.
# 如果你有非常高的连接率并且出现”connection refused” 报错,
# 你就应该添加此处的值.
# 检查你的操作系统文档来获取这个变量的最大值.
# 如果将back_log设定到比你操作系统限制更高的值,将会没无效果
back_log = 300

# 不在TCP/IP端口上进行监听.
# 如果所有的进程都是在同一台服务器连接到本地的mysqld,
# 这样设置将是加强安全的方法
# 所有mysqld的连接都是通过Unix sockets 或者命名管道进行的.
# 留意在windows下如果没有打开命名管道选项而只是用此项
# (通过 “enable-named-pipe” 选项) 将会导致mysql服务没有任何作用!
#skip-networking

# MySQL 服务所允许的同时会话数的上限
# 其中一个连接将被SUPER权限保留作为管理员登录.
# 即便曾经达到了连接数的上限.
max_connections = 3000
# 每个客户端连接最大的错误允许数量,如果达到了此限制.
# 这个客户端将会被MySQL服务阻止直到执行了”FLUSH HOSTS” 或者服务重启
# 非法的密码以及其他在链接时的错误会添加此值.
# 查看 “Aborted_connects” 形状来获取全局计数器.
max_connect_errors = 30

# 所有线程所打开表的数量.
# 添加此值就添加了mysqld所需求的文件描述符的数量
# 这样你需求确认在[mysqld_safe]中 “open-files-limit” 变量设置打开文件数量允许至少4096
table_cache = 4096

# 允许外部文件级别的锁. 打开文件锁会对功用形成负面影响
# 所以只要在你在同样的文件上运转多个数据库实例时才使用此选项(留意仍会有其他约束!)
# 或者你在文件层面上使用了其他一些软件依赖来锁定MyISAM表
#external-locking

# 服务所能处理的请求包的最大大小以及服务所能处理的最大的请求大小(当与大的BLOB字段一同任务时相当必要)
# 每个连接独立的大小.大小动态添加
max_allowed_packet = 32M

# 在一个事务中binlog为了记录SQL形状所持有的cache大小
# 如果你经常使用大的,多声明的事务,你可以添加此值来获取更大的功用.
# 所有从事务来的形状都将被缓冲在binlog缓冲中然后在提交后一次性写入到binlog中
# 如果事务比此值大, 会使用磁盘上的临时文件来替代.
# 此缓冲在每个连接的事务第一次更新形状时被创建
binlog_cache_size = 4M

# 独立的内存表所允许的最大容量.
# 此选项为了防止不测创建一个超大的内存表导致永尽所有的内存资源.
max_heap_table_size = 128M

# 排序缓冲被用来处理类似ORDER BY以及GROUP BY队列所惹起的排序
# 如果排序后的数据无法放入排序缓冲,
# 一个用来替代的基于磁盘的合并分类会被使用
# 查看 “Sort_merge_passes” 形状变量.
# 在排序发生时由每个线程分配
sort_buffer_size = 16M

# 此缓冲被使用来优化全联合(full JOINs 不带索引的联合).
# 类似的联合在极大多数情况下有非常蹩脚的功用表现,
# 但是将此值设大能够减轻功用影响.
# 通过 “Select_full_join” 形状变量查看全联合的数量
# 当全联合发生时,在每个线程中分配
join_buffer_size = 16M

# 我们在cache中保留多少线程用于重用
# 当一个客户端断开连接后,如果cache中的线程还少于thread_cache_size,
# 则客户端线程被放入cache中.
# 这可以在你需求大量新连接的时候极大的减少线程创建的开销
# (普通来说如果你有好的线程模型的话,这不会有明显的功用提升.)
thread_cache_size = 16

# 此允许使用程序给予线程系统一个提示在同一时间给予渴望被运转的线程的数量.
# 此值只对于支持 thread_concurrency() 函数的系统有意义( 例如Sun Solaris).
# 你可可以尝试使用 [CPU数量]*(2..4) 来作为thread_concurrency的值
thread_concurrency = 8

# 查询缓冲常被用来缓冲 SELECT 的结果并且在下一次同样查询的时候不再执行直接前往结果.
# 打开查询缓冲可以极大的提高服务器速度, 如果你有大量的相反的查询并且很少修正表.
# 查看 “Qcache_lowmem_prunes” 形状变量来检查能否当前值对于你的负载来说能否足够高.
# 留意: 在你表经常变化的情况下或者如果你的查询原文每次都不同,
# 查询缓冲也许惹起功用下降而不是功用提升.
query_cache_size = 128M

# 只要小于此设定值的结果才会被缓冲
# 此设置用来保护查询缓冲,防止一个极大的结果集将其他所有的查询结果都覆盖.
query_cache_limit = 4M

# 被全文检索索引的最小的字长.
# 你也许希望减少它,如果你需求搜索更短字的时候.
# 留意在你修正此值之后,
# 你需求重建你的 FULLTEXT 索引
ft_min_word_len = 8

# 如果你的系统支持 memlock() 函数,你也许希望打开此选项用以让运转中的mysql在在内存高度紧张的时候,数据在内存中保持锁定并且防止可能被swapping out
# 此选项对于功用无益
#memlock

# 当创建新表时作为默认使用的表类型,
# 如果在创建表示没有特别执行表类型,将会使用此值
default_table_type = MYISAM

# 线程使用的堆大小. 此容量的内存在每次连接时被预留.
# MySQL 本身常不会需求超过64K的内存
# 如果你使用你本人的需求大量堆的UDF函数
# 或者你的操作系统对于某些操作需求更多的堆,
# 你也许需求将其设置的更高一点.
thread_stack = 512K

# 设定默认的事务隔离级别.可用的级别如下:
# READ-UNCOMMITTED, READ-COMMITTED, REPEATABLE-READ, SERIALIZABLE
transaction_isolation = REPEATABLE-READ

# 内部(内存中)临时表的最大大小
# 如果一个表增长到比此值更大,将会自动转换为基于磁盘的表.
# 此限制是针对单个表的,而不是总和.
tmp_table_