首次安装、运行MySQL时,可能会遇到一些错误,使MySQL服务器不能启动。本文档的目的是帮助诊断并纠正这些错误。
首先在安装mysql时,请关闭防火墙以及杀毒软件,因为防火墙和部分杀毒软件会导致mysql安装、配置失败,从而无法启动mysql服务。
解决服务器问题时的第一资料是错误日志。MySQL服务器使用错误日志来记录服务器不能启动的信息。错误日志位于my.ini文件指定的数据目录中。默认数据目录位于C:\Program Files\MySQL\MySQL Server 5.1\dat。
另一个错误相关信息源是MySQL服务启动时控制台上显示的消息。将mysqld安装为服务后,从命令行通过NET START mysql命令来查看MySQL服务启动相关的错误消息。
下面说明首次安装并启动MySQL服务时会遇到的最常见的错误消息:
1. System error 1067 has occurred.
Fatal error: Can‘t open privilege tables: Table ‘mysql.host‘ doesn‘t exist
当MySQL服务器找不到MySQL权限数据库或关键文件时会出现这些消息。当MySQL基或数据目录没有安装在默认位置(C:\mysql和 C:\Program Files\MySQL\MySQL Server 5.1\data),而是安装到其它位置时通常会遇到该问题。
发生该问题的一种情况是对MySQL进行升级或安装到了新位置,但是没有对配置文件进行更新以对应新的安装位置。此外还可能是新旧配置文件冲突,当升级MySQL时,一定要删除或重新命名旧的配置文件。
如果你没有将MySQL安装到C:\Program Files\MySQL\MySQL Server 5.1目录下,而是安装到了其它目录下,你需要通过使用配置(my.ini)文件让MySQL服务器知道安装目录。my.ini文件应位于Windows目录下,典型为C:\WINNT或C:\WINDOWS。可以在命令提示符下输入下面的命令从WINDIR环境变量值中确定确切位置:
C:\> echo %WINDIR%
可以通过文本编辑器(例如记事本)来创建并修改选项文件。例如,如果MySQL安装在E:\mysql下,数据目录在D:\MySQLdata,你可以创建选项文件并设置[mysqld]来指定basedir和datadir参数的值:
[mysqld]
# set basedir to your installation path
basedir=E:/mysql
# set datadir to the location of your data directory
datadir=D:/MySQLdata
请注意应使用(正)斜线而不是反斜线在选项文件中指定Windows路径名。如果使用反斜线,则必须使用双斜线:
[mysqld]
# set basedir to your installation path
basedir=C:\\Program Files\\MySQL\\MySQL Server 5.1
# set datadir to the location of your data directory
datadir=D:\\MySQLdata
如果在MySQL配置文件中更改datadir值,在重新启动MySQL服务器之前,必须移动已有MySQL数据目录中的内容。
2. 安装mysql时可能产生cannot create windows service for mysql.error:0
错误,错误的原因多数由于重新安装mysql或者对mydql升级,使用MySQL Configuration Wizard而产生.
可以使用mysql以外的服务名,比如mysql11,等.但这不是最好的解决方法,我们可以使用windows的sc程序删除mysql服务.
C:>sc delete mysql
[SC] DeleteService SUCCESS
再重新使用MySQL Configuration Wizard,就不会有此错误了.
还有可能这步过了.可是无法启动.
一般我们在卸载前个mysql服务后记得服务器要重启下.
然后再安装.一般就不会出现这样的错误了l
原来只要在HKEY_LOCAL_MACHINE\SYSTEM\CurrentControlSet\Services中删除对应服务即可...
3. 在Windows中,一个root账户用来从本机连接MySQL服务器,另一个允许从任何主机连接。
可以用几种方法为root账户指定密码。以下介绍了三种方法:
·使用SET PASSWORD语句
·使用mysqladmin命令行客户端程序
·使用UPDATE语句
要想使用SET PASSWORD指定密码,用root连接服务器并执行两个SET PASSWORD语句。一定要使用PASSWORD()函数来加密密码。
在Windows中的语句:
shell> mysql -u root
mysql> SET PASSWORD FOR ‘root‘@‘localhost‘ = PASSWORD(‘newpwd‘);
mysql> SET PASSWORD FOR ‘root‘@‘%‘ = PASSWORD(‘newpwd‘);
在Unix中的语句:
shell> mysql -u root
mysql> SET PASSWORD FOR ‘root‘@‘localhost‘ = PASSWORD(‘newpwd‘);
mysql> SET PASSWORD FOR ‘root‘@‘host_name‘ = PASSWORD(‘newpwd‘);
用服务器主机名替换第二个SET PASSWORD语句中的host_name。这是指定匿名账户密码的主机名。
要想使用mysqladmin为root账户指定密码,执行下面的命令:
shell> mysqladmin -u root password "newpwd"
shell> mysqladmin -u root -h host_name password "newpwd"
上述命令适用于Windows和Unix。用服务器主机名替换第二个命令中的host_name。不一定需要将密码用双引号引起来,但是如果密码中包含空格或专用于命令解释的其它字符,则需要用双引号引起来。
还可以使用UPDATE直接修改user表。下面的UPDATE语句可以同时为两个root账户指定密码:
shell> mysql -u root
mysql> UPDATE mysql.user SET Password = PASSWORD(‘newpwd‘) WHERE User = ‘root‘;
mysql> FLUSH PRIVILEGES;
ERROR 1045 (28000): Access denied for user ‘root‘@‘localhost‘
第一步:打开开始里Mysql的MySQL Command Line Client 输入密码[就是安装时设的那个]
第二步:在mysql>后输入:UPDATE mysql.user SET Password = OLD_PASSWORD(‘密码‘) WHERE Host = ‘localhost‘ AND User = ‘用户名‘;
回车后提示:Query OK, 0 rows affected (0.16 sec)
Rows matched: 0 Changed: 0 Warnings:
第三步:在mysql>后输入:FLUSH PRIVILEGES;
回车后提示:Query OK, 0 rows affected (0.19 sec)
4. ERROR 1130:不能远程连接mysql服务器,但是可以本地连接:
远程链接mysql服务器的时候发生的这个错误:ERROR 1130:.......
User表中存在两行,其中localhost是允许本机登陆Mysql服务器的,host是允许远端客户端连接该服务器若host为“%”则表示任何远端均可登陆该mysql服务器,若host为具体IP则只允许相应的IP的PC登陆该服务器;
更改 mysql 数据库里的 user表里的 host项localhost改称%
mysql -u root –proot
mysql>use mysql;
mysql>update user set host = ‘%‘ where user =‘root‘;
mysql>flush privileges;
mysql>select ‘host‘,‘user‘ from user where user=‘root‘;
现在就可以连接了
安装完MySQL后,连接数据库的时候,出现 ERROR 1130 (HY000): Host ‘192.168.0.1‘ is not allowed to connect to this MySQL server提示信息,不能远程连接数据库。考虑可能是因为系统数据库mysql中user表中的host是localhost的原因,于是,我尝试把这个值改为自己服务器的ip,果然就好用了,不过用 mysql -u root -p命令就连不上数据库了,需要用mysql -h 服务器ip -u root -p因为默认的连接mysql数据库user表中host的值,而这个命令的默认host是localhost,就连不上了,
具体操作方法:
用localhost连接上mysql后,
use mysql;
update user set host=‘123.145.214.188‘;
\q;
退出mysql,然后重新启动mysql就可以了。
其他解决方案
2. 改表法。可能是你的帐号不允许从远程登陆,只能在localhost。这个时候只要在localhost的那台电脑,登入mysql后,更改 "mysql" 数据库里的 "user" 表里的 "host" 项,从"localhost"改称"%",与之前讲解的修改方法一致;
mysql -u root –proot
mysql>use mysql;
mysql>update user set host = ‘%‘ where user = ‘root‘;
mysql>select host, user from user;
3. 授权法。例如,想myuser使用mypassword从任何主机连接到mysql服务器的话。
GRANT ALL PRIVILEGES ON *.* TO ‘myuser‘@‘%‘ IDENTIFIED BY ‘mypassword‘ WITH GRANT OPTION;
如果想允许用户myuser从ip为192.168.1.3的主机连接到mysql服务器,并使用mypassword作为密码
GRANT ALL PRIVILEGES ON *.* TO ‘myuser‘@‘192.168.0.1‘ IDENTIFIED BY ‘mypassword‘ WITH GRANT OPTION;
备注:若出现1130错误时提示“localhost”不能登陆mysql服务器
时,此时只能将Mysql卸载,并删除相应的配置文件重新安装,否则无法解决;
5. 不能启动mysql服务,错误显示为无法启动mysql服务:
刚开始的解决办法是删除my.ini配置文件,然后重新配置mysql,但是在配置的过程中仍然会出现无法重新启动mysql服务的问题;
最后解决的办法是:卸载mysql程序,并且将安装路径下的mysql所有文件夹全部删除,然后再重新安装并且配置,则无问题。