CentOS中MySQL5.7安装详解

2020年06月04日 355点热度 0人点赞 0条评论
在CentOS中默认安装有MariaDB,需要卸载掉mariaDB,重新安装MySQL5.7
检查是否已经安装mysql5.7(两种方式)
[root@master ~]# rpm -qa | grep mysql
[root@master ~]# yum list installed | grep mysql

centos 7 下需要删除mariadb

检查:

[root@master ~]# rpm -qa | grep mariadb

删除如下:强制删除

如果已经安装,卸载掉原mysql
[root@master ~]# rpm -e mysql 【一般删除,如果提示依赖的其他文件,则不能删除】
[root@master ~]# rpm -e --nodeps mysql 【强力删除,包含各种依赖包】
第二种方式删除
删除 MySQL 及其依赖的包
[root@master ~]# yum remove mysql-*
查询遗留目录:
[root@master ~]# ls /etc/my.cnf(一般情况都没用这个)
/etc/my.cnf
[root@master ~]# ll /var/lib/mysql/
total 28700
-rw-rw---- 1 mysql mysql    16384 May  5 10:31 aria_log.00000001
-rw-rw---- 1 mysql mysql       52 May  5 10:31 aria_log_control
-rw-rw---- 1 mysql mysql 18874368 May  5 10:31 ibdata1
-rw-rw---- 1 mysql mysql  5242880 May  5 10:31 ib_logfile0
-rw-rw---- 1 mysql mysql  5242880 Oct  6  2017 ib_logfile1
drwx------ 2 mysql mysql     4096 Oct  6  2017 mysql
drwx------ 2 mysql mysql     4096 Oct  6  2017 performance_schema
删除遗留目录:
[root@master ~]# rm -rf /etc/my.cnf
[root@master ~]# rm -rf /var/lib/mysql/
下载 mysql57-community-release-el7-8.noarch.rpm 的 YUM 源:
[root@master ~]# wget http://mirrors.ustc.edu.cn/mysql-repo/mysql57-community-release-el7-8.noarch.rpm
安装 mysql57-community-release-el7-8.noarch.rpm:
[root@master ~]# rpm -ivh mysql57-community-release-el7-8.noarch.rpm
安装 mysql-server
[root@master ~]# yum -y install mysql-community-server
安装完毕后,运行mysql,启动mysql服务:
[root@master ~]# service mysqld start
然后在 /var/log/mysqld.log 文件中会自动生成一个随机的密码,我们需要先取得这个随机密码,以用于登录 MySQL 服务端:
[root@master ~]# grep "password" /var/log/mysqld.log
将会返回如下内容,末尾字符串就是密码,把它复制下来:
A temporary password is generated for root@localhost: hilX0U!9i3_6
关闭强密码验证:(作用:设置简单密码)
[root@master ~]# vim /etc/my.cnf
在文件的后面添加以下内容
plugin-load=validate_password.so
validate-password=OFF
重启mysql
[root@master ~]# service mysqld restart
登录到 MySQL 服务端并更新用户 root 的密码:
[root@master ~]# mysql -u root -p
hilX0U!9i3_6
更改密码
mysql> SET PASSWORD = PASSWORD('your new password');
mysql> ALTER USER 'root'@'localhost' PASSWORD EXPIRE NEVER;
mysql> flush privileges;
查询用户表
mysql> use mysql;
Reading table information for completion of table and column names
You can turn off this feature to get a quicker startup with -A

Database changed
mysql> select  User,authentication_string,Host from user;
+---------------+-------------------------------------------+-----------+
| User          | authentication_string                     | Host      |
+---------------+-------------------------------------------+-----------+
| root          | *6BB4837EB74329105EE4568DDA7DC67ED2CA2AD9 | localhost |
| mysql.session | *THISISNOTAVALIDPASSWORDTHATCANBEUSEDHERE | localhost |
| mysql.sys     | *THISISNOTAVALIDPASSWORDTHATCANBEUSEDHERE | localhost |
| root          | *6BB4837EB74329105EE4568DDA7DC67ED2CA2AD9 | %         |
+---------------+-------------------------------------------+-----------+
4 rows in set (0.00 sec)

mysql> 

设置用户 root 可以在任意 IP 下被访问:
mysql> grant all privileges on *.* to root@"%" identified by "new password";

设置用户 root 可以在本地访问
mysql> grant all privileges on *.* to root@"localhost" identified by "new password";

刷新权限列表,让以上更改生效
mysql> flush privileges;

退出MySQL:
mysql> exit

设置开机启动:
>>> systemctl enable mysqld

centos7彻底删除MySQL

centos中mysql忘记root密码详细解决方法

阿布

源自灵魂深处的自我救赎。

文章评论