我在RH9上安装mysql-standard-4.0.16-pc-linux-i686.tar.gz ,过程是:
shell> groupadd mysql shell> useradd -g mysql mysql shell> cd /usr/local shell> gunzip < /path/to/mysql-VERSION-OS.tar.gz | tar xvf - shell> ln -s full-path-to-mysql-VERSION-OS mysql shell> cd mysql shell> scripts/mysql_install_db shell> chown -R root . shell> chown -R mysql data shell> chgrp -R mysql . shell> bin/mysqld_safe --user=mysql &
发现在/tmp下有一个mysql.sock文件, 不知道是怎么产生的? 它有什么用, 能删除么? 如果不能, 我能将它换个目录么? 该怎么做?
----------问题解决方法-------------------
那是通讯用的文件,不能删,这是我以前做的笔记,有点乱,但还是可以参考一下的
mysql默认安装在/var/lib/mysql目录下
Couldn't connect to engine!
Can't connect to local MySQL server through socket '/var/lib/mysql/mysql.sock'
a.表示MySQL没有启动,需要启动MySQL(使用命令:/etc/rc.d/init.d/mysql start)。
b.没有将mysql.sock指定到/var/lib/mysql目录。需要在/etc/rc.d/init.d/的mysql自动启动文件中运行safe_mysqld的时候加上以下参数:--socket=/var/lib/mysql/mysql.sock :
在/etc/rc.d/init.d/mysql中找到 $bindir/safe_mysqld --datadir=$datadir --pid-file=$pid_file,并修改成:
$bindir/safe_mysqld --datadir=$datadir --pid-file=$pid_file --socket=/var/lib/mysql/mysql.sock --default-character-set=gbk -O back_log=100 &
有时会出现即使加了�socket启动参数仍然不能连接MySQL服务器的现象,但是实际上mysql.sock这个文件是存在的(假设在/tmp目录下);这时一个快捷的方法就是在/var/lib/mysql/目录下建立一个连接:
shell> ln -s /tmp/mysql.sock /var/lib/mysql/mysql.sock
然后再次启动mysql服务器:
shell> /etc/rc.d/init.d/mysql start |