mysql部署时常用配置_一些常见的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

参考

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值