Mysql安装过程问题总结及处理方法-阿里云开发者社区

开发者社区> 数据库> 正文

Mysql安装过程问题总结及处理方法

简介:

首次安装、运行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所有文件夹全部删除,然后再重新安装并且配置,则无问题。

 

版权声明:本文内容由阿里云实名注册用户自发贡献,版权归原作者所有,阿里云开发者社区不拥有其著作权,亦不承担相应法律责任。具体规则请查看《阿里云开发者社区用户服务协议》和《阿里云开发者社区知识产权保护指引》。如果您发现本社区中有涉嫌抄袭的内容,填写侵权投诉表单进行举报,一经查实,本社区将立刻删除涉嫌侵权内容。

分享:
数据库
使用钉钉扫一扫加入圈子
+ 订阅

分享数据库前沿,解构实战干货,推动数据库技术变革

其他文章