MySQL数据库参数解读-第二篇

目录

一、OS参数

1、numa=off

2、swappiness=0

3、SELINUX=disabled

4、firewalld关闭

二、server参数

1、socket

2、datadir

3、basedir

4、default_time_zone

5、character_set_server

6、lower_case_table_names

三、innodb参数

1、lock_wait_timeout

2、innodb_log_group_home_dir

3、innodb_buffer_pool_size

4、innodb_thread_concurrency

5、innodb_buffer_pool_instances

6、innodb_lock_wait_timeout

在第一篇,我们介绍了四个MySQL数据库中容易被忽略却又很重要的参数,本篇介绍MySQL数据库中的重要参数,参数分为OS参数、server参数、innodb参数。

一、OS参数

1、numa=off

作用:禁用numa架构,避免MySQL进程被绑定到特定CPU节点导致内存分配不均,防止性能抖动和swap异常使用。

2、swappiness=0

作用:关闭swap强制系统优先使用物理内存,仅在物理内存完全耗尽时才使用swap分区,避免MySQL内存页被置换到磁盘导致性能大幅下降

3、SELINUX=disabled

作用关闭selinux(安全增强型Linux)安全模块,避免其严格的访问控制策略拦截MySQL对数据文件、日志文件、端口的正常读写操作,减少权限相关的异常排查成本。

4、firewalld关闭

作用:防火墙关闭,防止其拦截MySQL客户端连接、主从复制通信请求

二、server参数

1、socket

作用:指定MySQL本地套接字文件(socket文件)的路径,本地客户端(如localhost连接)通过该文件与MySQL实例通信,比TCP/IP连接更高效。

2、datadir

作用:指定MySQL数据文件的存储目录,包含InnoDB表空间文件、MyISAM数据文件、数据库目录结构等核心数据。

3、basedir

作用:指定MySQL程序的安装目录,包含二进制文件(如mysqld、mysql客户端)、配置文件模板、共享库等。

4、default_time_zone

作用:一般设置MySQL实例的默认时区为东八区(+08:00),确保数据库中时间类型字段(如DATETIME、TIMESTAMP)的存储和查询结果与业务时区一致,避免时区转换导致的时间偏差问题。

5、character_set_server

作用:建议设置MySQL实例的默认服务器字符集为utf8mb4,支持包括Emoji表情在内的4字节Unicode字符,解决传统utf8字符集(实际为utf8mb3)无法存储4字节字符的问题,满足多语言和特殊符号的业务需求。

6、lower_case_table_names

作用:建议设置MySQL表名不区分大小写(值为1表示启用);表名在存储和查询时会自动转换为小写,避免因操作系统大小写敏感(如Linux)导致的表名匹配错误,适用于业务中表名大小写不规范的场景(需在实例初始化时设置,初始化后不可修改)。

三、innodb参数

1、lock_wait_timeout

作用:设置事务等待表级锁的超时时间,单位为秒,当一个事务请求的表锁被其他事务占用时,等待设置时间后若仍未获取锁则自动报错(ERROR 1205),避免事务无限等待导致连接堆积。

2、innodb_log_group_home_dir

作用:设置InnoDB重做日志(redo log)文件的路径。

3、innodb_buffer_pool_size

作用:设置InnoDB缓冲池大小。

4、innodb_thread_concurrency

作用:设置InnoDB的最大并发线程数。

5、innodb_buffer_pool_instances

作用:设置InnoDB缓冲池的实例数量,将缓冲池拆分为多个独立的内存区域,每个区域有自己的锁和管理结构,减少多线程并发访问缓冲池时的锁竞争,提升高并发场景下的性能(建议每个实例大小不小于1GB,如40GB缓冲池设置为8个实例,每个5GB)。

6、innodb_lock_wait_timeout

作用:设置InnoDB事务等待行锁的超时时间,单位为秒,当一个事务请求的行锁被其他事务占用时,等待指定时间后若仍未获取锁则自动回滚事务并报错(ERROR 1205),避免事务无限等待导致连接堆积和死锁。

相关推荐
宁小法2 小时前
MySQL - information_schema.COLUMNS中字段的排序原则 以及如何修改
mysql·列排序
逆境不可逃2 小时前
【用AI学Agent】Agent入门进阶:Prompt工程
大数据·数据库·人工智能
PD我是你的真爱粉2 小时前
MySQL 索引深度解析:从底层结构到实战优化
数据库·mysql
神舟之光2 小时前
Springboot+MyBatis-Plus连接MySQL初体验
spring boot·mysql·mybatis
AlickLbc2 小时前
达梦数据库使用体验记录(1-数据库安装篇)
数据库
WangJunXiang62 小时前
MySQL高可用详细解析
android·数据库·mysql
蓝之静云3 小时前
mapper执行sql报空指针,需要传入参数
数据库·python·sql
always_TT3 小时前
用位运算交换两个数(不使用临时变量)
数据库
一直都在5723 小时前
Redis(三)
数据库·redis·bootstrap