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

 

时间: 2024-09-23 11:23:23

Mysql安装过程问题总结及处理方法的相关文章

mysql安装过程中遇到的问题

问题描述 mysql安装过程中遇到的问题 mysql安装到最后一步,老是未响应,怎么解决呢?就是按照视频一步一步安装的,究竟什么原因,求解决方案 解决方案 之所以遇到这种情况,很有可能是因为电脑上曾经安装过MySQL,而没有彻底卸载干净(或者卸载干净却没有重启电脑)的缘故. 如果遇到这种情况,建议先卸载掉MySQL,并检查MySQL安装目录.C:/Program Files.C:/Windows等位置是否残留有MySQL的安装痕迹,再运行regedit命令,进入注册表,按Ctrl+F,输入MyS

mysql安装后添加gbk字符集的方法_Mysql

1.查看当前字符集: 复制代码 代码如下: SHOW CHARACTER SET; 2.删除mysql相关目录 复制代码 代码如下: rm -rf /usr/local/mysql/*     安装目录rm -rf /var/lib/mysql/mysql   数据库目录 3.重新编译 复制代码 代码如下: ./configure --prefix=/usr/local/mysql --sysconfdir=/etc --localstatedir=/var/lib/mysql --with-c

【MySQL 安装过程2】MySQL安装到 最后一部 未响应 的解决方案

  首先我们应该做的 是在控制面板将MySQL 卸载.再进行以下的操作:     1.在开始菜单下,点击运行,输入regedit,进入注册表编辑器目录下 2.在注册表编辑器里system下找到controlset001,controlset002,currentcontrolset下面的services文件下,找到mysql,将其删除[也可能并不能找到,找不到就算了] 3.分别清理下列注册表下的MySQL文件 HKEY_LOCAL_MACHINE\SYSTEM\ControlSet001\Ser

【MySQL 安装过程1】顺利安装MySQL完整过程

一.MySQL Sever的安装 1.开始安装: 2.这里就要开始注意,端口号我们的my SQL端口号为3306 3.下面要输入用户名和用户密码.注意,帐号密码  都是 root. 4.下面的最后一页,我们发现刚开始默认选中了两项,剩下的两项,我们不要乱动,让他自己去选择.电脑选择完整之后,我们就完成结束就好了. 5.接下来选择 6.我们现在就点开下图中的下面的注册表 7.点击我们的帮助软件,SQLyog点击新建: 8.点击确定后,需要输入密码,我们之前设置的密码:root,输入进去. 9.点击

安装解压版本的MySQL,安装过程中的常见命令,检查windows系统错误日志的方式来检查MySQL启动错误,关于Fatal error: Can't open and lock privilege

安装mysql 下载mysql-5.6.26-winx64,并解压到:D:\Installed\mysql-5.6.26-winx64\mysql-5.6.26-winx64 创建data目录 创建my.ini,内容如下: [mysql] # 设置mysql客户端默认字符集 default-character-set=utf8 [mysqld] #设置3306端口 port = 3306 # 设置mysql的安装目录 basedir=D://Installed//mysql-5.6.26-win

mysql-MySQL安装过程中遇到3个问题.菜鸟自学之路好难求大神

问题描述 MySQL安装过程中遇到3个问题.菜鸟自学之路好难求大神 我实在是没招了!求个大神给指导一下.希望可以帮我远程操作一下.按照自学的视频 2015年1月9号第一次学mysql,安装完mysql,一点finish,弹出配置的那个窗口. 可以使用了.真是激动人心. 当天按照视频又使用了SQLyogEnt.exe这个软件,当然了一切都是那么的正常. 学习完毕,我按了一下ctrl+s想保存一下,以为和java一样,一按没想到还要存储到一个目录下,于是存储到一个目录下. DOS窗口下和SQLyog

wordpress安装过程中遇到中文乱码的处理方法

  wordpress安装过程中遇到中文乱码的处理方法        这篇文章主要介绍了wordpress安装过程中遇到中文乱码的处理方法,是个人项目中遇到的一个奇葩事件,经过一番研究,终于解决,这里记录下来分享给大家,有需要的小伙伴可以参考下. 在安装wordpress的时候,按照里面的readme.html的步骤进行安装,但是在访问wp-admin/install.php的时候就出现了一行乱码: 复制代码 代码如下: 鎮ㄧ殑 PHP 浼间箮娌℃湁瀹夎杩愯 WordPress 蹇呴』鐨 M

Windows下MySQL安装配置方法图文教程_Mysql

Windows下的安装与配置MySQL详细步骤思路,分享给大家,供大家参考,具体内容如下 本文介绍Windows XP下的安装与配置. 要想在Windows中运行MySQL,需要: Ø 32位Windows操作系统,例如9x.Me.NT.2000.XP或Windows Server 2003. 基于Windows NT的操作系统(NT,2000,XP,2003),将MySQL服务器做为服务来运行.强烈建议使用基于Windows NT的操作系统. Ø TCP/IP协议支持(也许是所有数据库系统的基

mysql安装不上怎么办 mysql安装失败原因和解决方法_Mysql

mysql数据库安装不了了!mysql最后一步安装不上!mysql就是安装不上!是不是很头疼,很伤脑筋,现在大家不用着急了,小编为大家整理了mysql安装失败的原因以及mysql安装失败的解决方法,抓紧来看看吧! 困难1:MySQL 5.1 安装过程中报apply security setting错误 1.卸载MySQL. 2.删除目录 C:\Documents and Settings\All Users\Application Data\MySQL. 3.重新安装MySQL就OK啦. 困难2