linux下查看mysql的配置文件 - 知乎 (zhihu.com)
首先先看看你的mysql在哪,通过which命令
which mysql
显示出目录比如我的是下面这个
/usr/local/mysql/bin/mysql
接下来就可以针对这个目录通过一些命令查看配置文件在哪了,如下
# 查看 mysql 配置文件加载顺序 /usr/local/mysql/bin/mysql --verbose --help | grep -A 1 'Default options'
然后在下面会出现一些信息比如我的
Default options are read from the following files in the given order: /etc/my.cnf /etc/mysql/my.cnf /usr/local/mysql/etc/my.cnf ~/.my.cnf
这个信息的意思是:
服务器首先读取的是 /etc/my.cnf 文件,如果前一个文件不存在则继续读 /etc/mysql/my.cnf 文件,依此类推,如若还不存在便会去读~/.my.cnf文件。
如果以上文件都不存在,则说明在对mysql编译完成之后你没有对mysql进行配置,需要你自己复制一份mysql提供的默认配置文件到上面提到的目录中,然后改名为my.cnf,修改文件的所有者和所属组并赋予执行权限。
mkdir /usr/local/mysql/etc cp /usr/local/mysql/support-files/my-default.cnf /usr/local/mysql/etc/my.cnf chown -R mysql:mysql /usr/local/mysql/etc/ chmod 755 /usr/local/mysql/etc/my.cnf
完成以上操作之后,需要对my.cnf进行基本配置
vi /usr/local/mysql/etc/my.cnf
例如:
basedir = /usr/local/mysql # 指mysql的安装目录 datadir = /usr/local/mysql/data # 指mysql的数据存放目录 port = 3306 # 指mysql的监听端口
最后重启mysql使配置生效
/usr/local/mysql/support-files/mysql.server restart
如果修改my.cnf后mysql启动不了,可以通过如下方式查看错误信息
/usr/local/mysql/bin/mysqld --verbose --help | grep -A 1 'Default options'