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),避免事务无限等待导致连接堆积和死锁。

相关推荐
m0_6178814213 小时前
如何在新电脑上正确运行已部署的 Django 项目
jvm·数据库·python
u01091476013 小时前
Golang怎么计算日期差天数_Golang如何计算两个日期之间相差多少天【方法】
jvm·数据库·python
pele13 小时前
Python Tkinter如何实现组件拖拽交换位置_计算鼠标坐标重排布局
jvm·数据库·python
hua8722213 小时前
Spring Boot 中使用 @Transactional 注解配置事务管理
数据库·spring boot·sql
2301_8166602113 小时前
CSS实现盒子倒角不规则效果_利用border-radius多个值
jvm·数据库·python
为什么要做囚徒13 小时前
MongoDB 设置开机自启
数据库·mongodb
李少兄13 小时前
如何创建MySQL索引
数据库·mysql
2201_7610405913 小时前
CSS如何根据父级容器宽度调整子项_利用容器查询container选择器css
jvm·数据库·python
uNke DEPH13 小时前
Redis 安装及配置教程(Windows)【安装】
数据库·windows·redis
weixin_4585801213 小时前
如何在 Python Fabric 中正确执行 EdgeOS 配置命令
jvm·数据库·python