对于自制mysql安装,my.cnf在哪里?它安装了吗?


当前回答

我相信答案是否定的。在~/.my.cnf或/usr/local/etc中安装一个似乎是首选的解决方案。

其他回答

如果您使用的是mac m1 (Apple silicon), my.cnf位于

/opt/homebrew/etc/my.cnf

也可以通过mysql——help找到

您可以找到特定包提供my.cnf文件的位置,例如。

brew list mysql # or: mariadb

除了验证文件是否被读取,你可以运行:

sudo fs_usage | grep my.cnf

它将实时显示与该文件相关的文件系统活动。

没有什么能真正帮到我——我无法覆盖/etc/my.cnf文件中的设置。 所以我搜索了约翰建议的https://stackoverflow.com/a/7974114/717251

sudo /usr/libexec/locate.updatedb
# wait a few minutes for it to finish
locate my.cnf

它发现另一个my.cnf在

/usr/local/Cellar/mysql/5.6.21/my.cnf

更改这个文件对我有用!别忘了重启启动Agent:

launchctl unload ~/Library/LaunchAgents/homebrew.mxcl.mysql.plist
launchctl load ~/Library/LaunchAgents/homebrew.mxcl.mysql.plist

更新:

如果你最近安装了homebrew,你应该使用brew services命令重新启动mysql(使用你安装的homebrew mysql版本,即mysql或mysql@5.7):

brew services stop mysql
brew services start mysql

由于mysql——help显示了一个文件列表,我发现将结果管道到ls来查看它们中的哪些存在是有用的:

$ mysql --help | grep /my.cnf | xargs ls
ls: /etc/my.cnf: No such file or directory
ls: /etc/mysql/my.cnf: No such file or directory
ls: ~/.my.cnf: No such file or directory
/usr/local/etc/my.cnf

对于我的(安装了Homebrew) MySQL 5.7,文件似乎在/usr/local/etc/my.cnf.

添加另一个答案

公认的答案是正确的。因为我们讨论的是Homebrew安装的mysql,而不是手动安装的mysql,所以有更直接的方法来查找conf。 前一个答案可能有点过时,Homebrew在M1 Mac上存储在不同的位置

Conf

在安装过程中,my.cnf会被Homebrew复制到以下位置

/usr/local/etc/my.cnf for x86 Mac /opt/homebrew/etc/my.cnf

Homebrew选择/usr/local或/opt/ Homebrew存储包,因此默认的conf文件不存储在/etc/中,而是存储在/usr/local/etc或/opt/ Homebrew /etc中。

事实上,homebrew在从源代码编译mysql时改变了-DSYSCONFDIR=(默认的conf位置)标志。

启动服务

一个简单的回答:运行brew info mysql并查看提示。

推荐使用“brew services start mysql”,使用launchd管理服务。(launchd被认为是macOS上的systemd选项)

如果有人想手动启动,请使用mysql。没有任何选项的启动就足以启动服务。(mysql。Start是mysql提供的帮助启动服务的脚本)