在mysql安装成功后在support-files目录中会看到my-small.ini、my-medium.ini、my-large.ini、my-huge.ini几种个配置文件,分别用于不同的硬件环境。
my-innodb-heavy-4G.cnf是一个用于具有4GB内存的系统,主要运行MySQL,仅使用InnoDB表,并执行复杂的查询,连接数很少。
#MySQL客户端配置
[client]
#password= [your_password]
port= 3306#客户端链接端口
socket= /tmp/mysql.sock#socket文件路径
# MySQL服务器配置
[mysqld]
port= 3306#客户端链接端口
socket= /tmp/mysql.sock#socket文件路径
back_log = 50#mysql在监听队列中所能保持的连接数
#skip-networking#关闭通过TCP/IP连接MySQL
max_connections = 100#MySQL服务所允许的同时会话数上限
max_connect_errors = 10#每个客户端最大连接的错误数
table_open_cache = 2048#允许缓存已打开表的份数
#external-locking#允许外部文件锁定
max_allowed_packet = 16M#服务器发送和接受的最大包长度
binlog_cache_size = 1M#事务中binlog记录SQL状态使用cache大小
max_heap_table_size = 64M#单个HEAP表最大容量
read_buffer_size = 2M#随机读缓冲区大小
read_rnd_buffer_size = 16M#通信时缓存数据的大小
sort_buffer_size = 8M#执行排序使用的缓冲大小
join_buffer_size = 8M#join缓冲区大小
thread_cache_size = 8在cache中保留多少线程用于重用
thread_concurrency = 8#允许的线程数量
query_cache_size = 64M#查询缓冲区大小
query_cache_limit = 2M#只有小于此值的结果才会被缓冲
ft_min_word_len = 4#被全文检索索引的最小的字长
#memlock#在内存用尽时候数据锁定
default-storage-engine = MYISAM #新建表默认使用的表类型
thread_stack = 192K#线程使用的堆大小
transaction_isolation = REPEATABLE-READ #事务隔离级别:READ-UNCOMMITTED, READ-COMMITTED, REPEATABLE-READ, SERIALIZABLE
tmp_table_size = 64M#内部(内存中)临时表的最大大小
log-bin=mysql-bin#复制二进制日志
binlog_format=mixed#二进制日志格式=混合
#log_slave_updates#如果使用链式从服务器结构的复制模式 (A->B->C),你需要在服务器B上打开此项
#log#启用完整的查询日志。
#log_warnings#将警告输出到错误log文件
slow_query_log#记录慢查询
long_query_time = 2#大于该秒数的才认为是慢查询
#*** MyISAM 相关选项 ***
key_buffer_size = 32M#关键词缓冲大小, 一般用来缓冲MyISAM表的索引块
bulk_insert_buffer_size = 64M #大量插入操作是缓冲区大小
myisam_sort_buffer_size = 128M #myisam重建索引使用的缓冲大小
myisam_max_sort_file_size = 10G #重建索引时所允许的最大临时文件大小
myisam_repair_threads = 1#myisam修正线程数
myisam_recover#自动检查和修复没有适当关闭的MyISAM表
# *** INNODB 相关选项 ***
#skip-innodb#跳过innodb功能
innodb_additional_mem_pool_size = 16M #附加内存池大小
innodb_buffer_pool_size = 2G #缓冲池(用于保存索引和原始数据)大小
innodb_data_file_path = ibdata1:10M:autoextend#InnoDB表空间文件路径
#innodb_data_home_dir = #InnoDB表空间文件目录
innodb_write_io_threads = 8#用于异步IO操作的IO线程数
innodb_read_io_threads = 8#用于异步IO操作的IO线程数
#innodb_force_recovery=1#若表空间损坏,导出表需设置此值
innodb_thread_concurrency = 16 #在InnoDb核心内的允许线程数量
innodb_flush_log_at_trx_commit = 1 #每隔几秒日志文件刷新到磁盘
#innodb_fast_shutdown#加速InnoDB的关闭,但下次启动慢
innodb_log_buffer_size = 8M#日志文件所用的buffer大小
innodb_log_file_size = 256M#日志组中每个日志文件的大小
innodb_log_files_in_group = 3 #日志组中的文件总数,通常设2-3
#innodb_log_group_home_dir#InnoDB的日志文件组所在位置
innodb_max_dirty_pages_pct = 90 #在缓冲池中最大允许的脏页面的比例
#innodb_flush_method=O_DSYNC #刷新日志的方法.可选fdatasync和O_DSYNC
innodb_lock_wait_timeout = 120 #事务在被回滚之前等待锁定的超时秒数
#mysqldump备份数据库工具配置
[mysqldump]
quick #不将内存中的整个结果写入磁盘之前缓存
max_allowed_packet = 16M #服务器发送和接受的最大包长度
#mysql是针对客户端操作相关的配置
[mysql]
no-auto-rehash #命令不自动补全
#safe-updates#仅允许使用带有键值的UPDATEs和DELETEs操作,也就是新手模式
#MyISAM表维护程序配置
[myisamchk]
key_buffer_size = 512M #关键词缓冲大小, 一般用来缓冲MyISAM表的索引块
sort_buffer_size = 512M #排序缓冲大小
read_buffer = 8M#读取缓冲大小
write_buffer = 8M#写入缓冲大小
#mysql数据备份程序配置
[mysqlhotcopy]
interactive-timeout
[mysqld_safe]
open-files-limit = 8192 #每个进程的可打开文件数量.