博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
mysql 常用配置
阅读量:5159 次
发布时间:2019-06-13

本文共 2169 字,大约阅读时间需要 7 分钟。

innodb_buffer_pool_size 缓冲区的大小,一般为内存的70%-80%之间, 用来缓存表及索引数据,锁等级数据的最主要缓存空间。

通过查看 show status like 'innodb_buffer_pool_%';

innodb_log_file_size 日志文件大小,越大越好,可以减少 buffer pool checkpoint的频率不能超过4G,

可以设置了多个组,如3组,每组大小 300M

innodb_log_buffer_size 设置 log buffer大小,默认为1M,主要作用就是缓冲Log数据,

提高 Log 的IO性能,一般8M可以胜任 show status like 'innodb_log%'; 如果 Innodb_log_waits 为 0 ,

不用等待,缓存够大, 如果大于0,就是缓存不够大,可以适当增大innodb_file_per_table =1

可以每个表有单独的数据和索引文件数据

innodb_data_file_path 不仅指定所有 innodb数据文件的路径,

还指定初始大小分配,以下是两个硬盘

innodb_data_file_path = /disk1/local/mysql/innodb1:1000M:autoextend:8M:max:1G;

innodb_data_file_path = /disk2/local/mysql/innodb2:2000M:autoextend

如果没有指定innodb_data_home_dir的话,不然就直接用 innodb_data_home_dir的值

如果指定 innodb_data_home_dir,则: innodb_data_home_dir=/usr/local/mysql innodb_data_file_path=ibdata1:2G;ibdata2:2G;ibdata3:2G:autoextend:max:3G

则表示在/usr/local/mysql下有 ibdata1,ibdata2,ibdata3三个存放数据的文件,

最后一个可以自动扩展,就是当ibdata3大于2G时,会自动增加,增加到 最大为3G

============================

[mysqld]

#general

datadir   = /usr/local/mysql socket   = /usr/local/mysql/mysql.sock (应该与编译安装目录不在同一位置)

pid_file  =/usr/local/mysql/mysql.pid (应该与编译安装目录不在同一位置)

user   = mysql

port   =3306

default_storage_engine =innodb

expire_logs_days = 15

#innodb

innodb_buffer_pool_size = 70-80%内存值

innodb_log_file_size = 至少要有几百M

innodb_log_buffer_size = 1-8M/32-128M

innodb_file_per_table = 1

#innodb与文件系统相互作用,设置为 0_DIRECT时,需要打开 innodb_file_per_table

#默认为 fdatasync innodb_flush_method = 0_DIRECT (类unix特有,绕过操作系统的缓存)

#MYISAM

#键缓存,默认只有一个,但可以设置多个,只缓存索引,数据缓存则靠系统

#查看总大小,应该比这个值小一点点,单位为 B

# select sum(index_length) from information_schema.tables where engine='myisam';

key_buffer_size  = 32M

#设置多个时

key_buffer_1.key_buffer_size = value

key_buffer_2.key_buffer_size = value

#用key_buffer_1来缓存t1,t2表的、索引

cache index t1,t2 in key_buffer_1;

########

#LOGGING

log_error  = /usr/local/mysql/mysql-error.log

slow_query_log  = /usr/local/mysql/mysql-slow.log

#OTHER

tmp_table_size  = 32M/或更大

max_heap_table_size = 32M

query_cache_type = 0

query_cache_size = 0

max_connections  = 10000(默认为100)

open_file_limit  = 65535 (打开最大文件数目,越大会越好点)

[client]

socket   = /usr/local/mysql/mysql.sock

port   = 3306

 

转载于:https://www.cnblogs.com/lin3615/p/4783191.html

你可能感兴趣的文章
AngularJS学习之旅—AngularJS 模块(十五)
查看>>
计算机网络基础知识
查看>>
C#里如何遍历枚举所有的项
查看>>
如何在键盘出现时滚动表格,以适应输入框的显示
查看>>
超级强大的鼠标手势工具
查看>>
常用Dockerfile举例
查看>>
jquery的ajax用法
查看>>
设计模式-策略模式(Strategy)
查看>>
django orm 数据查询详解
查看>>
JarvisOJ Basic 熟悉的声音
查看>>
C# list导出Excel(二)
查看>>
CAS 单点登录模块学习
查看>>
跟着辛星用PHP的反射机制来实现插件
查看>>
Android应用开发-网络编程①
查看>>
input中的name,value以及label中的for
查看>>
静态库制作-混编(工程是oc为基础)
查看>>
jQuery 显示加载更多
查看>>
代理模式
查看>>
Confluence 6 系统运行信息中的 JVM 内存使用情况
查看>>
Confluence 6 升级以后
查看>>