linux下安装Mysql数据库

来源:互联网 发布:医生升级数据 编辑:程序博客网 时间:2024/06/11 19:34

     由于安装mysql数据库历程比价曲折,简单记录一下。声明:linux为centOS

一、在线安装Mysql

      1、查看是否安装了mysql

          rpm -qa | grep mysql 或者 rpm -qa | grep MySQL

         如:[shaohan@localhost Desktop]$ rpm -qa | grep MySQL
                 MySQL-shared-5.5.32-1.linux2.6.i386
                 MySQL-server-5.5.32-1.linux2.6.i386
                 MySQL-client-5.5.32-1.linux2.6.i386
                 MySQL-devel-5.5.32-1.linux2.6.i386
                 MySQL-shared-compat-5.5.32-1.linux2.6.i386

     2、如果有安装,就彻底删除

           yum -y remove MySQL-*.....

           还要彻底卸载:rm -rf /var/lib/mysql

   3、安装

         yum -y install mysql-server

   4、启动

       /etc/rc.d/init.d/mysqld start

   5、设置mysql服务开机自启动

  chkconfig mysqld on


---------------------------------------------------------------

手动安装

1、安装文件准备

MySQL-server-5.5.28-1.rhel5.i386.rpm

           MySQL-client-5.5.28-1.rhel5.i386.rpm

           MySQL-devel-5.5.28-1.rhel5.i386.rpm

去官网下载吧。

2、查看系统有无安装mysql

 

[root@localhost ~]# rpm -qa | grep MySQL

          MySQL-server-5.5.28-1.rhel5.i386.rpm

          MySQL-client-5.5.28-1.rhel5.i386.rpm

          MySQL-devel-5.5.28-1.rhel5.i386.rpm

说明已安装;
 
3、停止mysql服务
service mysql stop
 
4、卸载MySQL
       yum -y remove   MySQL-server-5.5.28-1.rhel5.i386.rpm        yum -y remove   MySQL-client-5.5.28-1.rhel5.i386.rpm
       yum -y remove   MySQL-devel-5.5.28-1.rhel5.i386.rpm
5、删除相关目录
默认安装一般会在:
/usr/share/mysql
/var/lib/mysql
删除mysql文件夹即可;
 
6、安装
rpm -ivh MySQL-server-5.5.28-1.rhel5.i386.rpm      MySQL-client-5.5.28-1.rhel5.i386.rpm    MySQL-devel-5.5.28-1.rhel5.i386.rpm
成功安装服务器端与客户端
 
7、启动服务
service mysql start
设置开机自启动: chkconfig mysql on
 
8、登录访问
首次安装时,默认密码为空,可以使用如下命令修改root密码
mysqladmin -u root password mypassword
mypassword 是新设定密码;
然后再次登录
mysql -u root –p
 
rpm包安装的MySQL是不会安装/etc/my.cnf文件的,解决方法,只需要复制/usr/share/mysql目录下的my-huge.cnf 文件到/etc目录,并改名为my.cnf即可
cp /usr/share/mysql/my-huge.cnf /etc/my.cnf
 
9、设置远程

//赋予任何主机访问数据的权限 mysql>GRANT ALL PRIVILEGES ON *.* TO 'root'@'%'WITH GRANT OPTION;

//使修改生效 mysql>FLUSH PRIVILEGES;

如果依然不能远程访问的话,那就很可能防火墙的原因了,可以在防火墙中开启3306端口或者干脆关掉防火墙。

关闭防火墙:service iptables stop

我在设置密码及远程访问时遇到些问题,修改密码了,也设置远程访问权限了,发现mysql无法远程;

折腾了半天发现,使用新修改的密码不能访问,使用空密码可以。为什么呢?进入mysql数据库查看了user表:

mysql> use mysql Database changed mysql> select host,user,password from user; +-----------------------+--------+-------------------------------------------+ | host                  | user   | password                                  | +-----------------------+--------+-------------------------------------------+ | localhost             | root   | *6BB4837EB74329105EE4568DDA7DC67ED2CA2AD9 | | localhost.localdomain | root   |                                           | | 127.0.0.1             | root   |                                           | | localhost             |        |                                           | | localhost.localdomain |        |                                           | | %                     | root   |                                           | +-----------------------+--------+-------------------------------------------+ 7 rows in set (0.00 sec) 不知道为什么,只有host为localhost user为root的用户,密码是改过的。其它密码仍为空,个人猜想,远程登录时应该使用的是host为%的用户。

直接update密码为“*6BB4837EB74329105EE4568DDA7DC67ED2CA2AD9 ”,修改成功,再登录,仍然无法使用新密码远程登录 。不知道这样直接修改与用命令mysql -u root 旧密码 新密码有什么区别

也不知道如何使用命令mysql -uroot -p命令修改host为%的密码;

后想到即然使用root用户,密码为空可远程登录,就在客户端里改吧。

我用的是Navicat,使用root 空密码登录后,点击菜单栏中tools->user manager->edit user

修改其它root用户密码为新密码:123456;

mysql> use mysql Database changed mysql> select host,user,password from user; +-----------------------+--------+-------------------------------------------+ | host                  | user   | password                                  | +-----------------------+--------+-------------------------------------------+ | localhost             | root   | *6BB4837EB74329105EE4568DDA7DC67ED2CA2AD9 | | localhost.localdomain | root   | *6BB4837EB74329105EE4568DDA7DC67ED2CA2AD9 | | 127.0.0.1             | root   | *6BB4837EB74329105EE4568DDA7DC67ED2CA2AD9 | | localhost             |        |                                           | | localhost.localdomain |        |                                           | | %                     | root   | *6BB4837EB74329105EE4568DDA7DC67ED2CA2AD9 | | %                     | lychee |                                           | +-----------------------+--------+-------------------------------------------+ 7 rows in set (0.00 sec)

重新使用Navicat登录 ,root 123456 ok,登录成功。


Linux环境下 php+mysql远程连接数据库,开启3306端口发布:付亚辉 | 发布时间: 2010年11月26日这个问题在php100问了好久,也没有得到答案(或许他们觉得简单,没法回答的,但是对新手来说,摸索是一个“漫长”的过程,特别像我这种在公司里边学习边用)。后来自己不断摸索终于找到了问题的所在,因为工作比较忙,今天终于有时间把这个详细解决过程写出来了,希望对你有帮忙!有两种方法一是:改表法(这个方法我没有试)因为在linux环境下,默认是关闭3306端口远程连接的,需要开启,这个后面说!可能是你的帐号不允许从远程登陆,只能在localhost。这个时候只要在localhost的那台电脑,登入mysql后,更改 "mysql" 数据库 里的 "user"(远程数据库的名称) 表里的 "host" 项,从"localhost"改称"%"     mysql -u root -pvmwaremysql>use mysql;     mysql>update user set host = ’%’ where user = ’root’;     mysql>select host, user from user;   二是:授权法(我用的是这个方法)例如,你想myuser(远程连接的用户名)使用mypassword(远程连接的密码)从任何主机连接到mysql服务器的话。   GRANT ALL PRIVILEGES ON *.* TO ’myuser’@’%’IDENTIFIED BY ’mypassword’ WI     TH GRANT OPTION;     如果你想允许用户myuser(远程连接的用户名)从ip为192.168.1.6(你测试电脑上的IP)的主机连接到mysql服务器,并使用 mypassword(远程连接的密码)作为密码     GRANT ALL PRIVILEGES ON *.* TO ’myuser’@’192.168.1.6’IDENTIFIED BY     ’mypassword’ WITH GRANT OPTION;    开始用的第一个方法,刚开始发现不行,在网上查了一下,少执行一个语句 mysql>FLUSH RIVILEGES使修改生效,就可以了。     方法是在安装mysql的机器上运行:     1、d:\mysql\bin\>mysql -h localhost -u root   //这样应该可以进入MySQL服务器     2、mysql>GRANT ALL PRIVILEGES ON *.* TO ’root’@’%’WITH GRANT OPTION     //赋予任何主机访问数据的权限     3、mysql>FLUSH PRIVILEGES   //修改生效   4、mysql>EXIT   //退出MySQL服务器  这个时候还没结束呢,一般的服务器上安装的都有防火墙之类的东西,也需要我们开启3306端口才能用了在linux下要开启防火墙 打开3306 端口,编辑这个文件vim /etc/sysconfig/iptables输入-A RH-Firewall-1-INPUT -m state --state NEW -m tcp -p tcp --dport 3306 -j ACCEPT保存后在控制台输入 /etc/rc.d/init.d/iptables restart  重启防火墙,记得一定要重启哦,我就是因为没有重启防火墙导致一直连接不上,最后终于找到答案了

有什么不明白的地方可以留言或者加我qq:493908654,欢迎沟通交流!

 

快速让MySQL数据库服务器支持远程连接

来源:CSDN博客

 

在CentOS上安装MySQL数据库服务器后,系统出于安全性考虑,缺省不支持用户通过非本机连接上数据库服务器,如果想让用户通过另外一台机器连接上数据库服务器必须手动进行修改:

1、在控制台执行 mysql -u root -p mysql,系统提示输入数据库root用户的密码,输入完成后即进入mysql控制台,这个命令的第一个mysql是执行命令,第二个mysql是系统数据名称,不一样的。

2、在mysql控制台执行 GRANT ALL PRIVILEGES ON *.* TO 'root'@'%' IDENTIFIED BY 'MyPassword' WITH GRANT OPTION;

3、在mysql控制台执行命令中的 'root'@'%' 可以这样理解: root是用户名,%是主机名或IP地址,这里的%代表任意主机或IP地址,你也可替换成任意其它用户名或指定唯一的IP地址;'MyPassword'是给授权用户指定的登录数据库的密码;另外需要说明一点的是我这里的都是授权所有权限,可以指定部分权限

4、不放心的话可以在mysql控制台执行 select host, user from user; 检查一下用户表里的内容

 

打开MySQL远程访问权限

1.以 root 帐户登陆 MySQL

MySQL -uroot -p123456

注:123456 为 root 用户的密码。

2.创建远程登陆用户并授权

grant all PRIVILEGES on discuz.* to ted@'123.123.123.123' identified by '123456';

注:上面的语句表示将 discuz 数据库的所有权限授权给 ted 这个用户,允许 ted 用户在 123.123.123.123 这个 IP 进行远程登陆,并设置 ted 用户的密码为 123456 。

----------------

改表法

  可能是你的帐号不允许从远程登陆,只能在localhost。这个时候只要在localhost的那台电脑,登入mysql后,更改 "mysql" 数据库里的 "user" 表里的 "host" 项,从"localhost"改称"%"

mysql -u root -p

mysql>use mysql;

mysql>update user set host = '%' where user = 'root';

mysql>select host, user from user;



         

原创粉丝点击