开发者社区> 问答> 正文

修改MySQL的my.cnf配置文件后,却不生效?:报错

原文链接:http://bbs.landingbj.com/t-0-246411-1.html

修改了 my.cnf 配置文件后,却不生效,这是怎么回事?

我们注意到,这里只说了修改 my.cnf,并没有说清楚其绝对路径是哪个文件。也就是说,有可能修改的不是正确路径下的my.cnf文件。

在MySQL中,是允许存在多个 my.cnf 配置文件的,有的能对整个系统环境产生影响,例如:/etc/my.cnf。有的则只能影响个别用户,例如:~/.my.cnf。

MySQL读取各个my.cnf配置文件的先后顺序是:

/etc/my.cnf

 /etc/mysql/my.cnf

 /usr/local/mysql/etc/my.cnf

 ~/.my.cnf

 其他自定义路径下的my.cnf,例如:/data/mysql/yejr_3306/my.cnf

不管是mysqld服务器端程序,还是mysql客户端程序,都可以采用下面两个参数来自行指定要读取的配置文件路径:

–defaults-file=#, 只读取指定的文件(不再读取其他配置文件)

 –defaults-extra-file=#, 从其他优先级更高的配置文件中读取全局配置后,再读取指定的配置文件(有些选项可以覆盖掉全局配置从的设定值)

因此,可以看到,如果你修改的是非“著名”目录下的 my.cnf,有可能看起来是不生效的,需要自行指定,或者统一放在 /etc/my.cnf 下,采用多实例的方式来管理即可。

转自联动北方技术论坛

展开
收起
kun坤 2020-06-07 13:54:48 1470 0
1 条回答
写回答
取消 提交回答
  • 比如我把Percona Server编译到/png/percona/5.6.16
    执行/png/percona/5.6.16/bin/mysql--help|grep my.cnf就可以看到以下顺序:
    /etc/my.cnf /etc/mysql/my.cnf /png/percona/5.6.16/etc/my.cnf ~/.my.cnf
    越往后面,优先级越高.为了避免混乱,建议只保留一个配置.
    另外服务器端mysqld和客户端mysql的配置读取顺序也是如此.
    区别在于服务器端mysqld读取配置[mysqld]下的内容,客户端mysql读取配置[client]下的内容.

    2020-06-07 13:54:53
    赞同 展开评论 打赏
问答排行榜
最热
最新

相关电子书

更多
搭建电商项目架构连接MySQL 立即下载
搭建4层电商项目架构,实战连接MySQL 立即下载
PolarDB MySQL引擎重磅功能及产品能力盛大发布 立即下载

相关镜像