sunny123456

  博客园 :: 首页 :: 博问 :: 闪存 :: 新随笔 :: 联系 :: 订阅 订阅 :: 管理 ::
  1796 随笔 :: 22 文章 :: 24 评论 :: 226万 阅读
< 2025年3月 >
23 24 25 26 27 28 1
2 3 4 5 6 7 8
9 10 11 12 13 14 15
16 17 18 19 20 21 22
23 24 25 26 27 28 29
30 31 1 2 3 4 5

MySQL配置文件my.cnf与my.ini的区别

一、my.cnf与my.ini

win系统,MySQL配置文件为my.ini

其他系统(Ubuntu、CentOS、macOS)MySQL配置文件为my.cnf

二、my.cnf与my.ini的路径

2.1 默认路径

MySQL 的配置文件 my.cnf 可能位于多个位置,具体取决于安装方式和操作系统。以下是一些常见的 my.cnf 配置文件的默认路径:

默认安装路径

安装方式默认路径
macOS 使用 Homebrew 安装/usr/local/etc/my.cnf
macOS 使用官方安装包(DMG)安装/usr/local/mysql/my.cnf
Linux(如 Ubuntu、CentOS 等)/etc/mysql/my.cnf 或 /etc/my.cnf
Windows:安装路径下的 my.ini 文件

请注意,这些是常见的默认路径,实际路径可能因为安装方式、自定义配置或其他因素而有所不同。

2.2 查找my.cnf路径

2.2.1、命令行查找配置文件

如果无法在以上路径找到 my.cnf 文件,可以尝试使用命令行查找配置文件的位置: 

该命令会输出一些信息,其中包含 Default options are read from the following files in the given order: 和 my.cnf 所在的路径。

或者使用命令

1
mysql --help | grep "Default options" -A 1

2.2.2 、多个my.cnf配置文件

使用mysql --help 发现了多个my.cnf配置文件

  • /etc/my.cnf
  • /etc/mysql/my.cnf
  • /opt/homebrew/Cellar/mysql-client/8.0.33_1/etc/my.cnf
  • ~/.my.cnf

1、多个配置文件的作用顺序

MySQL 在读取配置文件时会按照以下顺序进行查找:

  • /etc/my.cnf
  • /etc/mysql/my.cnf
  • /opt/homebrew/Cellar/mysql-client/8.0.33_1/etc/my.cnf
  • ~/.my.cnf

配置文件位于这些路径下的一个或多个位置。MySQL 将按照上述顺序读取配置文件,后面的配置文件会覆盖前面的配置文件中的相同选项。

2、作用范围不同

  • /etc/my.cnf 或 /etc/mysql/my.cnf 是系统级别的配置文件,对整个系统上的 MySQL 生效。如果你希望修改全局配置,可以选择在其中一个路径下进行修改。
  • /opt/homebrew/Cellar/mysql-client/8.0.33_1/etc/my.cnf 是 Homebrew 安装的 MySQL 客户端的配置文件路径。
  • ~/.my.cnf 代表当前用户的家目录下的 .my.cnf 配置文件,只对该用户生效。

注意:

mysql --help 虽然显示了多个my.cnf的路径,但是这几个文件不一定存在。

2.2.3 my.cnf 不存在怎么办

mysql --help 虽然显示了多个my.cnf的路径,但是这几个文件不一定存在。

my.cnf 配置文件不存在时,意味着 MySQL 可能使用默认的配置参数运行。

1、新建my.cnf 文件

如果你想自定义 MySQL 的配置,可以创建一个新的 my.cnf 文件,并将其放置在适当的位置。

如:

1
sudo vim /etc/my.cnf

在打开的编辑器中,你可以添加所需的配置参数,然后保存文件并重启 MySQL 服务使配置生效。

请注意,如果 /etc/my.cnf 文件不存在,你可以通过创建一个新的文件来代替,或者使用其他可用的位置进行配置。确保在编辑前先备份原有的配置文件,以免出现问题时可以还原到先前的配置。

2、初始化my.cnf 文件配置

在新建的 /etc/my.cnf 文件中,你可以添加以下常见的初始化数据:

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
[mysqld]
datadir=/var/lib/mysql
socket=/var/lib/mysql/mysql.sock
 
# 设置字符集
character-set-server=utf8mb4
collation-server=utf8mb4_unicode_ci
 
# 设置服务器ID(如果是复制集群,确保每个节点的ID唯一)
server-id=1
 
# 启用二进制日志
log-bin=mysql-bin
 
# 指定错误日志文件路径
log-error=/var/log/mysql/error.log

这只是一个示例,具体的配置参数根据你的实际需求而定。你可以根据自己的要求来添加、修改或删除配置参数。完成修改后,保存文件并重启 MySQL 服务使配置生效。

到此这篇关于MySQL配置文件my.cnf与my.ini的区别的文章就介绍到这了,更多相关MySQL my.cnf与my.ini内容请搜索脚本之家以前的文章或继续浏览下面的相关文章希望大家以后多多支持脚本之家!

原文链接:https://www.jb51.net/database/3177887dz.htm
posted on   sunny123456  阅读(195)  评论(0编辑  收藏  举报
相关博文:
阅读排行:
· DeepSeek 开源周回顾「GitHub 热点速览」
· 物流快递公司核心技术能力-地址解析分单基础技术分享
· .NET 10首个预览版发布:重大改进与新特性概览!
· AI与.NET技术实操系列(二):开始使用ML.NET
· .NET10 - 预览版1新功能体验(一)
历史上的今天:
2022-09-05 获取指定路径文件列表 递归 C# Directory.GetDirectories(path)或Directory.GetFiles(path)获取文件时如果是根目录时有隐藏文件则报错的处理
2022-09-05 Directory.GetFiles、GetDirectories 的三个参数
2022-09-05 java获取目路下所有文件及子目录_Java编程获取文件列表及子文件目录的方法(非递归)... File dir = new File(path); dir.listFiles() 获取指定路径下文件列表
2022-09-05 VMware启动centos蓝屏 打开控制面板,点击程序,启用或关闭Windows功能,找到虚拟机平台
2022-09-05 Linux 入门就电脑蓝屏,终止代码 PAGE_FAULT_IN_NONPAGED AREA Linux 命令
2022-09-05 【Linux】一步一步学Linux——ps命令(119)
2022-09-05 Docker学习总结
点击右上角即可分享
微信分享提示