mysql服务端客户端配置文件_mysql服务端与客户端的配置信息都在my.cnf文件中----- '/va...

本文介绍了如何修改MySQL的数据文件目录并详细解析了配置文件my.cnf在服务端和客户端的作用。在修改datadir后,通过启动命令确保服务端正常运行,但客户端因找不到配置文件导致连接错误。解决方法是使用--defaults-extra-file指定配置文件,以避免客户端使用默认路径导致的连接问题。
摘要由CSDN通过智能技术生成

修改了mysql的数据文件目录为/home/mysql,安装时默认的数据文件目录为/var/lib/mysql,配置文件为/etc/my.cnf,更改/etc/init.d/mysql文件中的datadir=/home/mysql 。 我们要知道/etc/my.cnf配置文件中包含对mysql服务端和客户端的配置。 然后进行如下操作

修改了mysql的数据文件目录为/home/mysql,安装时默认的数据文件目录为/var/lib/mysql,配置文件为/etc/my.cnf,更改/etc/init.d/mysql文件中的datadir=/home/mysql 。

我们要知道/etc/my.cnf配置文件中包含对mysql服务端和客户端的配置。

然后进行如下操作,改名my.cnf为my.cnf-bak,更改/etc/init.d/mysql文件中的datadir为默认路径datadir=,然后启动mysql服务端/usr/bin/mysqld_safe --defaults-extra-file=/etc/my.cnf-bak,成功启动mysql服务端,查看mysqld、mysql进程信息ps -ef| grep -i mysql*,显示mysql的datadir为/home/mysql,sock为/home/mysql/mysql.sock,其他信息也显示正常,然后尝试登录mysql数据库,这时报错提示说/var/lib/mysql/mysql.sock不存在。为什么呢?是因为my.cnf配置文件不存在,mysql客户端没有找到配置文件,就会去读取安装mysql时rpm包编译时指定的默认路径,而/var/lib/mysql/mysql.sock不存在,所以报错。就是说这时mysql客户端从默认参数中读取的信息

与修改后的datadir=/home/mysql的信息不一致,所以无法登录mysql服务器

1)/etc/init.d/mysql里面的datadir=/home/mysql,在mysql启动文件里面设置了数据文件目录

2)查看/etc/、basedir、datadir、~./my.cnf下面是否存在my.cnf配置文件

3)更改/etc/my.cnf为/etc/my.cnf-bak,mysql启动时会读取编译时设置的默认参数

4)此时可以正常启动mysql服务,因为在/etc/init.d/mysql中显示指定了数据文件的目录(似乎与第三条有点矛盾?其实3指的默认参数就是这里)

# service mysql start

# mysqladmin -uroot -p variables |grep -i basedir

# mysqladmin -uroot -p variables |grep -i datadir

5)现在修改/etc/init.d/mysql文件中的datadir,注释掉显示指定的datadir=/home/mysql

6)尝试关闭mysql数据库

#service mysql stop

#MySQL server PID file could not be found! [FAILED]

这是因为修改了mysql的datadir=/home/mysql,这时mysql会根据mysql的rpm包里面编译的默认路径/var/lib/mysql文件夹来读取PID文件,而/var/lib/mysql下面没有PID文件,所以提示。

7)此时可以通过mysqladmin -uroot -p shutdown 来正常关闭mysql进程。

8)因为/etc/my.cnf、basedir、datadir、~/.my.cnf都不存在,无法启动mysql。

可以通过/usr/bin/mysqld_safe --help查看mysqld_safe的参数,然后使用

# /usr/bin/mysqld_safe --defaults-extra-file=/etc/my.cnf-bak

指定mysql启动脚本,并启动mysqld进程。 这时mysqld_safe进程会占用终端(在当前终端,无法进行其他操作),使用Ctrl+Z停止mysqld进程(睡眠进程),再使用bg(fg将后台作业放到前台)把mysqld_safe进程设置为后台进程(会从睡眠状态恢复为运行状态,使用)。

###########

9)尝试连接mysql数据库,查看mysql的信息

# mysqladmin -uroot -p variables | grep -i datadir

mysqladmin: connect to server at 'localhost' failed

error: 'Can't connect to local MySQL server through socke'/var/lib/mysql/mysql.sock' (2)'

Check that mysqld is running and that the socket: '/var/lib/mysql/mysql.sock' exists!

提示无法通过/var/lib/mysql/mysql.sock连接mysql服务器

尝试连接mysql数据库,

#mysql -uroot -p

Enter password:

ERROR 2002 (HY000): Can't connect to local MySQL server through socket '/var/lib/mysql/mysql.sock' (2)

###########

查看mysql进程信息:

[root@localhost ~]# ps -ef|grep -i mysql*

root 18835 5614 0 04:10 pts/1 00:00:00 /bin/sh /usr/bin/mysqld_safe --defaults-extra-file=/etc/my.cnf-bak

mysql 19133 18835 0 04:10 pts/1 00:00:00 /usr/sbin/mysqld --defaults-extra-file=/etc/my.cnf-bak --basedir=/usr --datadir=/home/mysql --plugin-dir=/usr/lib/mysql/plugin --user=mysql --log-error=/home/mysql/localhost.localdomain.err --pid-file=/home/mysql/localhost.localdomain.pid

--socket=/home/mysql/mysql.sock --port=3306

这时会发现,mysql的进程信息显示的socket路径为修改过的my.cnf-bak中指定的路径/home/mysql/mysql.sock,而连接mysql数据库时,却说无法通过默认的socket路径连接/var/lib/mysql/mysql.sock连接。

############

这是由于/etc/my.cnf、basedir/my.cnf、datadir/my.cnf、~/.my.cnf文件都不存在,而在启动mysql服务的时候,使用/usr/bin/mysqld_safe --defaults-extra-file=/etc/my.cnf-bad 指定了启动时mysql_server读取的配置文件,这样mysql服务器进程成功启动,而在mysql_client客户端使用mysqladmin客户端工具、或mysql通过客户端尝试登陆mysql服务器 时,mysql客户端会去寻找my.cnf配置文件(my.cnf中包含了mysql服务端[mysqld]和客户端[client]的设置),因为没有找到my.cnf配置文件,无法读取用户的设置,mysql客户端会使用mysql安装时设置的默认目录,而默认数据文件目录/var/lib/mysql下没有mysql.sock,所以会报错说找不到/var/lib/mysql/mysql.sock。

my.cnf中的配置信息分类:

mysqld_safe / mysqld / mysqld_multi 属于服务器端配置

mysqldump / mysql / client / mysqladmin之类的属于客户端配置

[client]用户告诉客户端工具mysql连接数据库服务器使用的port和socket文件的路径

[mysql]用于设置客户端工具的显示信息,如在my.cnf中设置

[mysql]

#prompt="(\\u:hostname:\D)[\\d]> "

这样使用mysql -uroot -p连接到mysql服务器时,就会显示:

(root:hostname:Thu Feb 9 16:32:26 2012)[(none)]>

f68f2add0b68e4f9810432fce46917b7.png

本文原创发布php中文网,转载请注明出处,感谢您的尊重!

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值