《MYSQL教程详解腾讯云CentOS7.0使用yum安装mysql及使用遇到的问题》要点:
本文介绍了MYSQL教程详解腾讯云CentOS7.0使用yum安装mysql及使用遇到的问题,希望对您有用。如果有疑问,可以联系我们。
MYSQL应用背景:
MYSQL应用今天才申请了腾讯云+校园计划的1元服务器,安装了Centos7.0,在安装MySQL的时候,使用yum list | grep mysql 来查找yum源中是否有mysql,结果如下:
MYSQL应用
[root@VM_47_56_centos ~]# yum list | grep mysql
akonadi-mysql.x86_64 1.9.2-4.el7 base
apr-util-mysql.x86_64 1.5.2-6.el7 base
mysql-proxy.x86_64 0.8.5-2.el7 epel
mysql-proxy-devel.x86_64 0.8.5-2.el7 epel
mysql-router.x86_64 2.0.2-1.el7 mysql-tools-community
mysql-router-debuginfo.x86_64 2.0.2-1.el7 mysql-tools-community
mysql-utilities.noarch 1.5.6-1.el7 mysql-tools-community
mysql-utilities-extra.noarch 1.5.6-1.el7 mysql-tools
mysqlreport.noarch 3.5-11.el7 epel
mysqltuner.noarch 1.2.0-7.el7 epel
省略部分内容....
[root@VM_47_56_centos ~]#
MYSQL应用总之是看不到mysql-server的影子,(PS:据说Centos7.0的源中暂时还没有mysql,但是相同版本的Centos在阿里云是可以直接使用yum install mysql-server 来直接安装mysql的)
MYSQL应用于是找了一些mysql的安装源,安装过程如下:
MYSQL应用安装过程:
MYSQL应用为了解决这个问题,我们要先下载mysql的repo源.
MYSQL应用1、下载mysql的repo源
MYSQL应用
$ wget http://repo.mysql.com/mysql-community-release-el7-5.noarch.rpm
MYSQL应用2、安装mysql-community-release-el7-5.noarch.rpm包
MYSQL应用
$ sudo rpm -ivh mysql-community-release-el7-5.noarch.rpm
MYSQL应用安装这个包后,会获得两个mysql的yum repo源:
MYSQL应用/etc/yum.repos.d/mysql-community.repo和/etc/yum.repos.d/mysql-community-source.repo.
MYSQL应用3、安装mysql
MYSQL应用
$ sudo yum install mysql-server
MYSQL应用这个过程中就会看到有mysql的软件包存在:
MYSQL应用
[root@VM_47_56_centos ~]# sudo yum install mysql-server
已加载插件:fastestmirror, langpacks
| 2.5 kB 00:00:00
mysql-tools-community | 2.5 kB 00:00:00
mysql56-community | 2.5 kB 00:00:00
(1/3): mysql-connectors-community/x86_64/primary_db | 8.6 kB 00:00:00
(2/3): mysql-tools-community/x86_64/primary_db | 22 kB 00:00:00
(3/3): mysql56-community/x86_64/primary_db | 109 kB 00:00:01
Loading mirror speeds from cached hostfile
* base: mirrors.sina.cn
* extras: mirrors.sina.cn
* updates: mirrors.sina.cn
正在解决依赖关系
--> 正在检查事务
省略内容...
依赖关系解决
=================================================================================================================
Package 架构 版本 源 大小
=================================================================================================================
正在安装:
mysql-community-libs x86_64 5.6.27-2.el7 mysql56-community 2.0 M
替换 mariadb-libs.x86_64 1:5.5.44-1.el7_1
mysql-community-server x86_64 5.6.27-2.el7 mysql56-community 58 M
为依赖而安装:
mysql-community-client x86_64 5.6.27-2.el7 mysql56-community 19 M
mysql-community-common x86_64 5.6.27-2.el7 mysql56-community 256 k
numactl-libs x86_64 2.0.9-5.el7_1
事务概要
=================================================================================================================
安装 2 软件包 (+9 依赖软件包)
总下载量:80 M
Is this ok [y/d/N]: y
MYSQL应用下边的安装和其他安装一样,
MYSQL应用根据步骤安装就可以了,不过安装完成后,没有密码,需要重置密码.
MYSQL应用4、重置密码
MYSQL应用重置密码前,首先要登录
MYSQL应用
$ mysql -u root
MYSQL应用登录时有可能报这样的错:ERROR 2002 (HY000): Can‘t connect to local MySQL server through socket ‘/var/lib/mysql/mysql.sock‘ (2),原因是/var/lib/mysql的访问权限问题.下面的命令把/var/lib/mysql的拥有者改为当前用户:
MYSQL应用
$ sudo chown -R mysql:mysql /var/lib/mysql #这里的mysql是用户名(需要设置用户组合用户)
MYSQL应用然后,重启服务:
MYSQL应用
$ service mysqld restart
MYSQL应用接下来登录重置密码:
MYSQL应用
$ mysql -u root
mysql > use mysql;
mysql > update user set password=password('xu827928') where user='root';
mysql > exit;
MYSQL应用5、开放3306端口(可以不用设置)
MYSQL应用
$ sudo vim /etc/sysconfig/iptables
MYSQL应用添加以下内容:
MYSQL应用
-A INPUT -p tcp -m state --state NEW -m tcp --dport 3306 -j ACCEPT
MYSQL应用保存后重启防火墙:
MYSQL应用
$ sudo service iptables restart
MYSQL应用这样从其它客户机也可以连接上mysql服务了.
MYSQL应用6、修改权限可以使其他机器登录:
MYSQL应用
mysql>mysql -h localhost -u root //这样应该可以进入MySQL服务器
mysql>GRANT ALL PRIVILEGES ON *.* TO 'root'@'%' WITH GRANT OPTION //赋予任何主机访问数据的权限
mysql>FLUSH PRIVILEGES //修改生效
mysql>EXIT //退出MySQL服务器
MYSQL应用使用时遇到的问题
MYSQL应用(1)Java.sql.SQLException: Access denied for user ‘root'@'localhost' (using password:YES)
MYSQL应用
java.sql.SQLException: Access denied for user 'root'@'localhost' (using password: YES)
at com.mysql.jdbc.SQLError.createSQLException(SQLError.java:946)
at com.mysql.jdbc.MysqlIO.checkErrorPacket(MysqlIO.java:2870)
at com.mysql.jdbc.MysqlIO.checkErrorPacket(MysqlIO.java:812)
at com.mysql.jdbc.MysqlIO.secureAuth411(MysqlIO.java:3269)
at com.mysql.jdbc.MysqlIO.doHandshake(MysqlIO.java:1182)
MYSQL应用问题的场景是:在命令行模式下用户名和密码都是正确的但是就是出现登陆不了授权失败的问题.
MYSQL应用解决方法:
MYSQL应用进入MySQL命令台:
MYSQL应用
mysql> select user,password,host from mysql.user;
MYSQL应用
MYSQL应用可以看出该表显示的倒数第二行为:
MYSQL应用
+--------+-------------------------------------------+--------------------+
| user | password | host |
+--------+-------------------------------------------+--------------------+
| root | | % |
MYSQL应用可以看出在root用户下的任何主机是没有password的,因此可以采取两种方式,在远端使用的时候没有密码,显然是不安全的,然后就是为其在远端访问的时候设置密码.步骤如下:
MYSQL应用
mysql> grant all privileges on *.* to root@"%" identified by "your password";
Query OK, 0 rows affected (0.00 sec)
mysql> flush privileges;
Query OK, 0 rows affected (0.00 sec)
MYSQL应用这相当于是给IP-xxx.xxx.xxx.xxx赋予了所有的权限,包括远程访问权限.
MYSQL应用这样就可以为其设置密码,然后就可以使用密码进行登录.
MYSQL应用以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持维易PHP.
转载请注明本页网址:
http://www.vephp.com/jiaocheng/3830.html