- 清理原来mysql数据
rpm -qa | grep mariadb
查看是否存在mariadb,若存在,则使用rpm -e 文件名 --nodeps卸载软件。
rpm -qa|grep mysql
查看是否已经安装mysql,如果已经安装则使用命令rpm -e 文件名 --nodeps卸载软件。
find / -name mysql
/etc/logrotate.d/mysql
/etc/selinux/targeted/active/modules/100/mysql
/etc/selinux/targeted/tmp/modules/100/mysql
/var/lib/mysql
/var/lib/mysql/mysql
/usr/bin/mysql
/usr/lib64/mysql
/usr/local/mysql
删除对应的文件
- 下载安装包,按照如下顺序安装,因为存在依赖关系
rpm -ivh mysql-community-common-8.0.11-1.el7.x86_64.rpm
rpm -ivh mysql-community-libs-8.0.11-1.el7.x86_64.rpm #依赖于common
rpm -ivh mysql-community-client-8.0.11-1.el7.x86_64.rpm #依赖于libs
rpm -ivh mysql-community-server-8.0.11-1.el7.x86_64.rpm #依赖于client & common
- 初始化mysql,找到初始密码
mysqld --initialize #该命令会在/var/log/mysqld.log生成随机密码
cat /var/log/mysqld.log |grep pass #查看初始密码
- 启动数据库并登录
sudo service mysqld start
此时,数据库已经安装完毕,启动mysql服务
netstat -tlunp
查看服务所需端口
mysql -u root -p
输入初始密码即可
- 添加用户并修改密码
ALTER USER 'root'@'localhost' IDENTIFIED BY '密码';
flush privileges;#
刷新数据库
exit;#
退出数据库
- 防火墙
sudo systemctl stop firewalld.service
sudo systemctl disable firewalld.service
- 远程登录
GRANT ALL ON *.* TO 'root'@'%';为root用户
ERROR 1410 (42000): You are not allowed to create a user with GRANT
然后进行下面的操作
select host,user,authentication_string,plugin from user;
update user set host = "%" where user = "root";
flush privileges;#
刷新数据库
在另一台可以访问数据库服务器的主机使用navicat工具连接数据库,若能访问则代表成功。
- 报错2059
2059:Authentication plugin 'caching_sha2_password' cannot be loaded
原因如下
mysql8 之前的版本中加密规则是mysql_native_password,而在mysql8之后,加密规则是caching_sha2_password, 解决问题方法有两种:
升级navicat驱动
mysql用户登录密码加密规则还原成mysql_native_password
修改加密规则
ALTER USER 'root' IDENTIFIED WITH mysql_native_password BY '密码';
然后远程登录