一些常见的MySQL配置

目录

配置

[mysqld]
port = 3306
socket = /mysql/log/mysql_3306.sock

# mysql的目录(即mysql的文件所在目录)
# basedir = /mysql/mysql_basedir
# mysql中存放数据的目录
datadir = /mysql/data
# mysql的日志目录
log_error = /mysql/log/error.log
# pid文件所在目录
pid-file = /mysql/log/mysql_3306.pid
# mysqld程序在启动后将在给定UNIX/Linux账户下执行; mysqld必须从root账户启动才能在启动后切换到另一个账户下执行; mysqld_safe脚本将默认使用–user=mysql选项来启动mysqld程序。
# user = root

# 配置mysql绑定地址,配置为0.0.0.0可以使该机器所有IP访问
bind-address = 0.0.0.0

# mysql标记,一般使用IP最后一位,不可重复
server-id = 1

# 打开binlog
log-bin = mysql-bin

# binlog的前缀名
log-bin-index = master-bin.index

# 更改服务器的校验规则,默认为utf8mb4_general_ci,不区分大小写(数据),修改为utf8mb4_bin数据区分大小写
collation_server=utf8mb4_bin

# InnoDB为独立表空间模式,每个数据库的每个表都会生成一个数据空间
# 独立表空间优点:
# 1.每个表都有自己独立的表空间。
# 2.每个表的数据和索引都会存在自已的表空间中。
# 3.可以实现单表在不同的数据库中移动。
# 4.空间可以回收(除drop table操作处,表空不能自已回收)
# 缺点:
# 单表增加过大,如超过100G
# 结论:
# 共享表空间在Insert操作上少有优势。其它都没独立表空间表现好。
# 当启用独立表空间时,请合理调整:innodb_open_files
innodb_file_per_table = 1

# InnoDB使用一个缓冲池来保存索引和原始数据, 不像MyISAM.
# 这里你设置越大,你在存取表里面数据时所需要的磁盘I/O越少.
# 在一个独立使用的数据库服务器上,你可以设置这个变量到服务器物理内存大小的80%
# 不要设置过大,否则,由于物理内存的竞争可能导致操作系统的换页颠簸.
# 注意在32位系统上你每个进程可能被限制在 2-3.5G 用户层面内存限制,
# 所以不要设置的太高.
innodb_buffer_pool_size = 8G

# innodb使用后台线程处理数据页上的读写 I/O(输入输出)请求,根据你的 CPU 核数来更改,默认是4
# 注:这两个参数不支持动态改变,需要把该参数加入到my.cnf里,修改完后重启MySQL服务,允许值的范围从 1-64
# innodb_read_io_threads = 16
innodb_write_io_threads = 16

#connection
# 服务器关闭交互式连接前等待活动的秒数。交互式客户端定义为在mysql_real_connect()中使用CLIENT_INTERACTIVE选项的客户端。默认值:28800秒(8小时)
interactive_timeout = 1800

# 服务器关闭非交互连接之前等待活动的秒数。在线程启动时,根据全局wait_timeout值或全局interactive_timeout值初始化会话wait_timeout值,
# 取决于客户端类型(由mysql_real_connect()的连接选项CLIENT_INTERACTIVE定义)。参数默认值:28800秒(8小时)
# MySQL服务器所支持的最大连接数是有上限的,因为每个连接的建立都会消耗内存,因此我们希望客户端在连接到MySQL Server处理完相应的操作后,
# 应该断开连接并释放占用的内存。如果你的MySQL Server有大量的闲置连接,他们不仅会白白消耗内存,而且如果连接一直在累加而不断开,
# 最终肯定会达到MySQL Server的连接上限数,这会报'too many connections'的错误。对于wait_timeout的值设定,应该根据系统的运行情况来判断。
# 在系统运行一段时间后,可以通过show processlist命令查看当前系统的连接状态,如果发现有大量的sleep状态的连接进程,则说明该参数设置的过大,
# 可以进行适当的调整小些。要同时设置interactive_timeout和wait_timeout才会生效。
wait_timeout = 1800

# InnoDB事务在被回滚之前可以等待一个锁定的超时秒数。InnoDB在它自己的锁定表中自动检测事务死锁并且回滚事务。InnoDB用LOCK TABLES语句注意到锁定设置。默认值是50秒
lock_wait_timeout = 1800

# 禁用DNS解析,无法通过主机名连接数据库,但是可以加快访问速度
skip_name_resolve = 1

# MySQL的最大连接数,如果服务器的并发连接请求量比较大,建议调高此值,以增加并行连接数量,当然这建立在机器能支撑的情况下,因为如果连接数越多,介于MySQL会为每个连接提供连接缓冲区,就会开销越多的内存,所以要适当调整该值,不能盲目提高设值。可以过'conn%'通配符查看当前状态的连接数量,以定夺该值的大小。
max_connections = 3000

# 对于同一主机,如果有超出该参数值个数的中断错误连接,则该主机将被禁止连接。如需对该主机进行解禁,执行:FLUSH HOST。
max_connect_errors = 1000000


##table cache performance settings

# MySQL每打开一个表,都会读入一些数据到table_open_cache缓存中,当MySQL在这个缓存中找不到相应信息时,才会去磁盘上读取。默认值64
# 假定系统有200个并发连接,则需将此参数设置为200*N(N为每个连接所需的文件描述符数目);
# 当把table_open_cache设置为很大时,如果系统处理不了那么多文件描述符,那么就会出现客户端失效,连接不上
table_open_cache = 4096

# 内存中可打开的表结构数量
table_definition_cache = 4096

# 表缓存实例数,为通过减小会话间争用提高扩展性,表缓存会分区为table_open_cache/table_open_cache_instances大小的较小的缓存实例
# DML语句会话只需要锁定所在缓存实例,这样多个会话访问表缓存时就可提升性能(DDL语句仍会锁定整个缓存)。默认该值为1,当16核以上可设置为8或16。
table_open_cache_instances = 64


# session memory settings

# MySQL读入缓冲区大小。对表进行顺序扫描的请求将分配一个读入缓冲区,MySQL会为它分配一段内存缓冲区。read_buffer_size变量控制这一缓冲区的大小。
# 如果对表的顺序扫描请求非常频繁,并且你认为频繁扫描进行得太慢,可以通过增加该变量值以及内存缓冲区大小提高其性能
read_buffer_size = 16M

# MySQL的随机读缓冲区大小。当按任意顺序读取行时(例如,按照排序顺序),将分配一个随机读缓存区。进行排序查询时,
# MySQL会首先扫描一遍该缓冲,以避免磁盘搜索,提高查询速度,如果需要排序大量数据,可适当调高该值。但MySQL会为每个客户连接发放该缓冲空间,所以应尽量适当设置该值,以避免内存开销过大
read_rnd_buffer_size = 32M

# MySQL执行排序使用的缓冲大小。如果想要增加ORDER BY的速度,首先看是否可以让MySQL使用索引而不是额外的排序阶段。
# 如果不能,可以尝试增加sort_buffer_size变量的大小
sort_buffer_size = 8M

# 临时表大小
tmp_table_size = 64M

# 联合查询操作所能使用的缓冲区大小,和sort_buffer_size一样,该参数对应的分配内存也是每连接独享
join_buffer_size = 128M

# 这个值(默认8)表示可以重新利用保存在缓存中线程的数量,当断开连接时如果缓存中还有空间,那么客户端的线程将被放到缓存中,
# 如果线程重新被请求,那么请求将从缓存中读取,如果缓存中是空的或者是新的请求,那么这个线程将被重新创建,如果有很多新的线程,
# 增加这个值可以改善系统性能.通过比较Connections和Threads_created状态的变量,可以看到这个变量的作用。(–>表示要调整的值)
# 根据物理内存设置规则如下:
# 1G  —> 8
# 2G  —> 16
# 3G  —> 32
# 大于3G  —> 64
thread_cache_size = 64

# 服务器的默认字符集
character_set_server=utf8mb4

# 表名不区分大小写
lower_case_table_names=1

# mysql应该支持的sql语法,数据校验等
sql_mode = "STRICT_TRANS_TABLES,NO_ENGINE_SUBSTITUTION,NO_ZERO_DATE,NO_ZERO_IN_DATE,ERROR_FOR_DIVISION_BY_ZERO,NO_AUTO_CREATE_USER"

# 事务自动提交
autocommit = 1

# MySQL支持4种事务隔离级别,他们分别是:
# READ-UNCOMMITTED, READ-COMMITTED, REPEATABLE-READ, SERIALIZABLE.
# 如没有指定,MySQL默认采用的是REPEATABLE-READ,ORACLE默认的是READ-COMMITTED
transaction_isolation = READ-COMMITTED

# 关于时间戳的设置
explicit_defaults_for_timestamp = 1

#服务器发送和接受的最大包长度
max_allowed_packet = 67108864


#innodb settings

# innodb页大小
innodb_page_size = 16384

# 这对Innodb表来说非常重要。Innodb相比MyISAM表对缓冲更为敏感。MyISAM可以在默认的 key_buffer_size 设置下运行的可以,然而Innodb在默认的innodb_buffer_pool_size 设置下却跟蜗牛似的。由于Innodb把数据和索引都缓存起来,无需留给操作系统太多的内存,因此如果只需要用Innodb的话则可以设置它高达 70-80% 的可用内存。– 如果你的数据量不大,并且不会暴增,那么无需把innodb_buffer_pool_size 设置的太大了。
innodb_buffer_pool_size = 8G

# innodb_buffer_pool_instances可以开启多个内存缓冲池,把需要缓冲的数据hash到不同的缓冲池中,这样可以并行的内存读写。
innodb_buffer_pool_instances = 8

# 在mysqld启动之后,重新加载buffer pool
innodb_buffer_pool_load_at_startup = 1

# 在关闭mysqld的时候,自动导出buffer pool
innodb_buffer_pool_dump_at_shutdown = 1

# 每个缓冲池刷脏页的能力
innodb_lru_scan_depth = 4096

# InnoDB事务在被回滚之前可以等待一个锁定的超时秒数。InnoDB在它自己的锁定表中自动检测事务死锁并且回滚事务。InnoDB用LOCK TABLES语句注意到锁定设置。默认值是50秒
innodb_lock_wait_timeout = 5

# 刷新脏页的数量
innodb_io_capacity = 10000

# 最大刷新脏页的数量,一般innodb_io_capacity是innodb_io_capacity_max的一半
innodb_io_capacity_max = 20000

# innodb数据文件及redo log的打开、刷写模式
# 默认是fdatasync,调用fsync()去刷数据文件与redo log的buffer
# 为O_DSYNC时,innodb会使用O_SYNC方式打开和刷写redo log,使用fsync()刷写数据文件
# 为O_DIRECT时,innodb使用O_DIRECT打开数据文件,使用fsync()刷写数据文件跟redo log
innodb_flush_method = O_DIRECT

#innodb_file_format = Barracuda
#innodb_file_format_max = Barracuda

# 指定回滚段的个数(早期版本该参数名字是innodb_rollback_segments),默认128个。每个回滚段可同时支持1024个在线事务。这些回滚段会平均分布到各个undo表空间中。该变量可以动态调整,但是物理上的回滚段不会减少,只是会控制用到的回滚段的个数。
innodb_undo_logs = 128

# 指定单独存放的undo表空间个数,例如如果设置为3,则undo表空间为undo001、undo002、undo003,每个文件初始大小默认为10M。该参数实例初始化之后不可改动
#innodb_undo_tablespaces = 3

# 0关闭刷新邻页
# 1打开刷新邻页功能,顺带着刷新在 buffer pool 中位于磁盘上相同的 extend 区的相邻的脏页
# 2刷新在 buffer pool 中位于磁盘上相同的 extend 区的脏页
innodb_flush_neighbors = 0

# 确定数据日志文件的大小,更大的设置可以提高性能,但也会增加恢复故障数据库所需的时间
innodb_log_file_size = 2147483648

# 为提高性能,MySQL可以以循环方式将日志文件写到多个文件
innodb_log_files_in_group = 2

# 确定写日志文件所用的内存大小。缓冲区更大能提高性能,但意外的故障将会丢失数据
innodb_log_buffer_size = 16777216

# InnoDB中的清除操作是一类定期回收无用数据的操作。在之前的几个版本中,清除操作是主线程的一部分,这意味着运行时它可能会堵塞其它的数据库操作。
# 从MySQL5.5.X版本开始,该操作运行于独立的线程中,并支持更多的并发数。
# 用户可通过设置innodb_purge_threads配置参数来选择清除操作是否使用单独线程
# 默认情况下参数设置为0(不使用单独线程),设置为 1 时表示使用单独的清除线程
innodb_purge_threads = 4

# 默认开启该参数 控制单列索引长度最大达到3072
innodb_large_prefix = 1

# 并发数限制,默认设置为 0,表示不限制并发数
innodb_thread_concurrency = 24

# 保存死锁日志 
innodb_print_all_deadlocks = 1

# 是否开启严格模式
innodb_strict_mode = 1

# 在创建InnoDB索引时用于指定对数据排序的排序缓冲区的大小。
# 利用这块内存把数据读进来进行内部排序然后写入磁盘。
# 这个参数只会在创建索引的过程中被使用,不会用在后面的维护操作;在索引创建完毕后innodb_sort_buffer会被释放。
innodb_sort_buffer_size = 67108864

# innodb使用后台线程处理数据页上的读写 I/O(输入输出)请求,根据你CPU 核数来更改,默认是4
# 注:这两个参数不支持动态改变,需要把该参数加入到my.cnf里,修改完后重启MySQL服务,允许值的范围从 1-64
innodb_write_io_threads = 16
innodb_read_io_threads = 16

# InnoDB为独立表空间模式,每个数据库的每个表都会生成一个数据空间
# 独立表空间优点:
# 1.每个表都有自已独立的表空间。
# 2.每个表的数据和索引都会存在自已的表空间中。
# 3.可以实现单表在不同的数据库中移动。
# 4.空间可以回收(除drop table操作外,表空不能自己回收)
# 缺点:
# 单表增加过大,如超过100G
# 结论:
# 共享表空间在Insert操作上少有优势。其它都没独立表空间表现好。当启用独立表空间时,请合理调整:innodb_open_files
innodb_file_per_table = 1

# 配置持久化统计信息采样的页数
innodb_stats_persistent_sample_pages = 64

# 在向有auto_increment 列的表插入数据时,相关锁的行为
# 0传统模式,在这一模式下,所有的insert语句("insert like") 都要在语句开始的时候得到一个表级的auto_inc锁,在语句结束的时候才释放这把锁
# 1连续模式,这一模式下去simple insert 做了优化,由于simple insert一次性插入值的个数可以立马得到确定,所以mysql可以一次生成几个连续的值,用于这个insert语句;总的来说这个对复制也是安全的(它保证了基于语句复制的安全)
# 2交错模式,由于这个模式下已经没有了auto_inc锁,所以这个模式下的性能是最好的;但是它也有一个问题,就是对于同一个语句来说它所得到的auto_incremant值可能不是连续的。
innodb_autoinc_lock_mode = 2

# 在online DDL过程中,保存delete、update、insert数据的日志的最大大小
innodb_online_alter_log_max_size=1G

# 限制Innodb能打开的表的数据,如果库里的表特别多的情况,请增加这个。这个值默认是300
innodb_open_files=4096


#new innodb settings 
# 指定每个缓冲池最近使用的页面读取和转储的百分比。 范围是1到100。默认值是25。
innodb_buffer_pool_dump_pct = 40

# innodb写脏数据的线程数
innodb_page_cleaners = 16

# 开启在线回收(收缩)undo log日志文件,支持动态设置
innodb_undo_log_truncate = 1

# 当undo log超过这个阀值(默认是1G),会触发truncate回收(收缩)动作,truncate后空间缩小到10M
innodb_max_undo_log_size = 2G

# 控制回收(收缩)undo log的频率
innodb_purge_rseg_truncate_frequency = 128


[client]
port = 3306
socket = /mysql/log/mysql_3306.sock

参考

mysql配置文件 /etc/my.cnf 详细解释

猜你喜欢

转载自www.cnblogs.com/obed/p/11600195.html