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-10-12 12:51:23

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

apache、php、mysql安装过程

apache安装过程 a. 打开安装文件,在选择典型或自定义时,选择自定义,一般就是下面那个: b.当安装完成后,在浏览器中网址栏中打上 http://localhost ,如果出现It works!即安装成功 要修改一些apache的系统文件(下面的路径只是我安装apache的路径,你修改时需要根据你的路径来修改): c.如果要添加一些域名,先修改一个文件,路径为:D:\Program Files\Apache Software Foundation\Apache2.2\conf\httpd,

MySQL安装过程中出现“APPLY security settings错误”的解决方式

***********************************************声明****************************************************** 原创作品,出自 "晓风残月xj" 博客,欢迎转载,转载时请务必注明出处(http://blog.csdn.net/xiaofengcanyuexj). 因为各种原因.可能存在诸多不足,欢迎斧正. *******************************************

cognos安装过程各种问题跟解决方法

上篇博文cognos安装配置完整教程说了cognos server在window系统下的安装过程 由于篇幅,没有把安装中可能遇到的坑具体说明,这篇博文补上 1.测试连接资源库报错 [ERROR]Content Manager failed to start because it could not load driver "oralce.jdbc.OracleDriver",具体报错如下图 分析及解决方法:很明显,是缺少连接oracle的jdbc驱动包,只要把oracle官方的驱动包(

MYSQL安装过程及报错信息

MYSQL安装步骤: #下载,解压源码包,移动到指定目录: wget http://syslab.comsenz.com/downloads/linux/mysql-5.1.40-linux-x86_64-icc-glibc23.tar.gz tar zxvf mysql-5.1.40-linux-x86_64-icc-glibc23.tar.gz mv mysql-5.1.40-linux-x86_64-icc-glibc23.tar.gz /usr/local/mysql #新建数据库存储路

Microsoft Office Enterprise 2007 在安装过程中出错的解决方法

今天笔者在使用PowerPoint 2007打开一个ppt的内嵌的excel表格时报如下错误: 无法找到 服务器应用程序.源文件.和项目,或返回的未知错误.请重新安装服务程序 然后就先把ppt文件发给同事.同事能在自己的电脑上打开ppt文件中内嵌的excel,于是判定很可能是笔者office软件的问题. 因不想在此事上花过多的时间研究,于是准备重新安装Microsoft Office 2007,但在安装的过程中进度条快完的时候又报如下错误: Microsoft Office Enterprise

MySQL安装过程中出现“APPLY security settings错误”的解决方案

***********************************************声明****************************************************** 原创作品,出自 "晓风残月xj" 博客,欢迎转载,转载时请务必注明出处(http://blog.csdn.net/xiaofengcanyuexj). 由于各种原因,可能存在诸多不足,欢迎斧正! *******************************************

个人在mysql安装过程中遇见的问题

经过8天的折腾终于将mysql安装(十足的电脑盲),期间几乎把csdn和博客园的相关文章都一一翻阅并实践,可还是没有解决问题,马克思说的对,矛盾具有特殊性,解决矛盾要结合"两点论"和"重点论".因为每个人的电脑硬.软件及所下版本的不同,所以会遇到一些因人而异的问题,以下是我这次安装mysql-5.7.24(xp32位操作系统)途中遇到的问题,供大家参考: 问题1.关于my.ini文件查找不到及设置首次免密码登录mysql 网友帖子:可在C盘子目录下输入%Progra

mysql安装过程mysql本地环境变量的配置

(10)配置环境变量 前面步骤完成后安装好MySQL,为MySQL配置环境变量.MySQL默认安装在C:\Program Files下. 1)新建MYSQL_HOME变量,并配置:C:\Program Files\MySQL\MySQL Server 5.6 MYSQL_HOME:C:\Program Files\MySQL\MySQL Server 5.6 2)编辑path系统变量,将%MYSQL_HOME%\bin添加到path变量后.配置path环境变量,也可不新建MYSQL_HOME变量

MySQL安装过程

必备工具 1:Linux系统 2:MySQL 安装包   http://www.mysql.com 3:cmake(cmake编译安装)  ncuress-devek(开发工具默认安装) 避免端口冲突检查 MySQL安装情况 rpm -q mysql-server mysql (查询是否安装) 编译安装cmake cd  cmake-2.8.6 ./configure gmake  &&  gmake  install 编译安装MySQL groupadd  mysql    (建立组)