MySQL5.7.31性能优化记录

一、配置优化

1、innodb_buffer_pool_instances

范围是 1 (the default) up to 64 (the maximum).

可以将 innodb_buffer_pool_instances 的个数设置为 buffer pool size 的 十分之一, 比如 innodb_buffer_pool_size 是 30g ,那 innodb_buffer_pool_instances 就设置为 3;

2、innodb_buffer_pool_size 

因为有额外内存的使用,如果指定 innodb_buffer_pool_size 为 12g 实际占用内存可能是 14g +

二、事务日志配置

innodb_log_file_size

默认值 48MB
设置的太小:比如用默认值48MB,当一个日志文件写满后,innodb会自动切换到另外一个日志文件,而且会触发数据库的检查点(Checkpoint),这会导致innodb缓存脏页的小批量刷新,会明显降低innodb的性能。

设置的太大:设置很大以后减少了checkpoint,并且由于redo log是顺序I/O,大大提高了I/O性能。但是如果数据库意外出现了问题,比如意外宕机,那么需要重放日志并且恢复已经提交的事务,如果日志很大,那么将会导致恢复时间很长。甚至到我们不能接受的程度。

总结: innodb_log_file_size设置得太小无法释放数据库性能,设置得太大,会增加宕机后日志重放恢复的时间。

innodb_log_files_in_group

重做日志组中的日志数量,默认值是2 ,一般用默认值也可以。

innodb_log_buffer_size

将日志写入磁盘日志文件前的缓冲大小,默认值 8MB,一般用默认值也可以。

三、读写线程增加

innodb_write_io_threads
innodb_read_io_threads
innodb_thread_concurrency

四、示例

[mysql]
# 设置mysql客户端默认字符集
default-character-set=utf8
[mysqld]

bind-address = 193.193.193.41

skip-name-resolve
#设置3306端口
port = 3306
# 设置mysql的安装目录
basedir=/opt/soft/mysql57
# 设置mysql数据库的数据的存放目录
datadir=/opt/soft/mysql57/data
# 允许最大连接数
max_connections=1000
# 服务端使用的字符集默认为8比特编码的latin1字符集
character-set-server=utf8
# 创建新表时将使用的默认存储引擎
default-storage-engine=INNODB
lower_case_table_names=1
max_allowed_packet=16M

# 优化配置参数,实际物理内存:8G
innodb_buffer_pool_size=4096M
innodb_log_file_size = 512M
innodb_flush_log_at_trx_commit = 2

# 禁用ssl
skip-ssl

# 慢日志
slow_query_log=ON
slow_query_log_file=/var/log/mysql/slow_query2.log
long_query_time=0.2 #单位秒

注意:如果配置重启mysql后慢sql不生效,也可以临时命令启用如下:

mysql> set global slow_query_log=1;
# 查看设置的参数是否生效
mysql> show variables  like '%query%';

 

你可能感兴趣的:(mysql)