内容纲要
当启动实例时,MySQL数据库会去读取配置文件,根据配置文件的参数来启动数据库实例。而在MySQL数据库中,可以没有配置文件,在这种情况下,MySQL会按照编译时的默认参数设置启动实例。常常因为想看一下MySQL里面的配置my.cnf
,却苦于找不到这个文件的存放位置。下面是常用的三个查找方法,快准狠!
ps
利用ps
命令。mysql启动时往往携带很多启动参数,看看是否有启动指定的配置文件,命令如下:ps aux|grep mysql
命令ps aux|grep mysql|grep 'my.cnf'
输出
fdipzone 25174 0.0 0.0 3087244 600 ?? S 4:12下午 0:01.14
/usr/local/Cellar/mysql/5.6.24/bin/mysqld --defaults-file=/usr/local/Cellar/mysql/5.6.24/my.cnf --basedir=/usr/local/Cellar/mysql/5.6.24 --datadir=/usr/local/var/mysql --plugin-dir=/usr/local/Cellar/mysql/5.6.24/lib/plugin --bind-address=127.0.0.1 --log-error=/usr/local/var/mysql/TerrydeMacBook-Air.local.err --pid-file=/usr/local/var/mysql/TerrydeMacBook-Air.local.pidfdipzone
25064 0.0 0.0 2452824 4 ?? S 4:12下午 0:00.03
/bin/sh
/usr/local/opt/mysql/bin/mysqld_safe --defaults-file=/usr/local/Cellar/mysql/5.6.24/my.cnf --bind-address=127.0.0.1 --datadir=/usr/local/var/mysql
有输出,说明找到了,没输出,说明mysql启动时未携带该配置参数,再或者mysql还没启动。
mysql
这里是直接利用mysql的help命令来查找,命令如下:mysql --help|grep my.cnf
命令 mysql --help|grep 'my.cnf'
输出
order of preference, my.cnf, $MYSQL_TCP_PORT,/etc/my.cnf
/etc/mysql/my.cnf
/usr/local/etc/my.cnf
~/.my.cnf
/etc/my.cnf
,/etc/mysql/my.cnf
, /usr/local/etc/my.cnf
,~/.my.cnf
这些就是mysql默认会搜寻my.cnf的目录,顺序排前的优先。按照这个路径一个一个去找一下。
locate
这里是利用上了locate
命令,这个命令比较实用,它是将文件信息在本地进行了一个缓存,查找速度快,命令如下:locate my.cnf
命令 locate my.cnf
输出 /etc/my.cnf/etc/my.cnf.d
over
这里的over就是over的意思,不是命令😆。如果以上都没有找到的话,则自己创建一个把,文件存放路径可以放在mysql --help|grep my.cnf
指定的路径下即可。
文章评论