Linux CentOS上安装 MySQL 8.0.16

前言:

因为我需要在我新安装的Linux CentOS系统服务器中安装和配置MySQL服务器,然而对于我们这种Linux使用小白而言在Linux系统中下载,解压,配置MySQL等一系列的操作还是有些耗时间的。所以小编本次准备使用yum命令在Linux CentOS系统中安装MySQL服务器和使用其他命令配置MySQL服务器的相关配置(纯命令操作),这样子我们只需要输入一些简单的命令即可,当然你也可以下载压缩包自己完成一些初始化的配置与安装。.

第一步:查看系统中是否已存在MySQL,若存在则选择删除

这里我就不详细讲解了,大家可以看我的上一篇博客,关于如何彻底删除MySQL数据库

地址:https://www.cnblogs.com/Can-daydayup/p/10873948.html

第二步:下载并安装MySQL数据库

官网下载地址:https://dev.mysql.com/downloads/repo/yum/

选择red hat版:

Linux CentOS上安装 MySQL 8.0.16

复制下载地址:

Linux CentOS上安装 MySQL 8.0.16

1

2

3

4

5

6

7

8

9

10

11

12

13

14

1.下载镜像

wget https://dev.mysql.com/get/mysql80-community-release-el7-3.noarch.rpm

2.安装镜像

rpm -ivh mysql80-community-release-el7-3.noarch.rpm

3.升级系统上的MySQL软件包

通过以下命令升级MySQL及其相关组件:

方案一.指定更新MySQL服务器(推荐使用):

yum update mysql-server

方案二.通过更新系统上的所有内容来更新MySQL(谨慎使用):

注意,这个方法需要谨慎使用,一般是在空白服务器的时候可以使用,因为有可能会把你系统中的其他软件都给升级了

yum update

4.安装MySQL服务

yum install mysql-server

使用Yum存储库升级MySQL软件包官网概述:https://dev.mysql.com/doc/mysql-repo-excerpt/5.6/en/updating-yum-repo.html

第三步:MySQL文件权限设置

1

chown mysql:mysql -R /var/lib/mysql

第四步:初始化MySQL

1

mysqld --initialize

第五步:启动MySQL服务并设置开机自动启动

1

#启动<br>systemctl start mysqld<br><br>#设置开机自动启动

   systemctl enable mysqld

 systemctl daemon-reload

注意:我在启动MySQL服务的时候提示:

Job for mysqld.service failed because the control process exited with error code. See "systemctl status mysqld.service" and "journalctl -xe" for details.

我认为可能和我之前系统安装过MySQL有关系,解决方法:

1

2

3

chown mysql:mysql -R /var/lib/mysql

在启动:

service mysqld start

查看运行状态:

1

systemctl status mysqld

完美运行:

Linux CentOS上安装 MySQL 8.0.16

第六步:查看当前MsSQL安装版本

1

mysqladmin --version

Linux CentOS上安装 MySQL 8.0.16

第七步:设置数据库密码

原因:在安装完成MySQL后不会默认设置密码,需要我们自己设置

1

mysqladmin -u root password "你的密码"

我真是一个被老天眷顾的孩子,设置密码是遇到了一个这样的问题:

ERROR 1045 (28000): Access denied for user 'root'@'localhost' (using password: NO)

一般这个错误是由密码错误引起,解决的办法自然就是重置密码

解决方案如下:

1.停止mysql数据库:systemctl stop mysqld

2.用以下命令启动MySQL,以不检查权限的方式启动:

mysqld --skip-grant-tables &

如果上面的命令无效报错,则执行下面这段命令:

mysqld --user=root --skip-grant-tables &

3.登录mysql:mysql -u root -p或mysql

4.更新root密码:

ALTER USER 'root'@'localhost' IDENTIFIED BY '123456';

修改密码的时候提示:

ERROR 1290 (HY000): The MySQL server is running with the --skip-grant-tables option so it cannot execute this statement

解决方法:

刷新权限:flush privileges;

5.刷新权限:flush privileges;

6.退出mysql:exit或quit

7.使用root用户重新登录mysql

mysql -uroot -p

Enter password:<输入新设的密码123456>

第八步:开启MySQL远程

1.登陆数据库

1

mysql -u root -p然后输入密码按回车进入MySQL数据库中

2.创建用户用来远程连接:参考该篇博客:

https://jingyan.baidu.com/article/363872ec3263236e4ba16f07.html
3.查询数据库的用户

1

SELECT DISTINCT CONCAT('User: ''',user,'''@''',host,''';') AS query FROM mysql.user;

4. 更新用户表:(其中%的意思是允许所有的ip远程访问,如果需要指定具体的某个ip就写上具体的ip即可)

1

UPDATE user SET `Host` = '%' WHERE `User` = 'root' LIMIT 1;

5. 强制刷新权限:

1

flush privileges;

6.使用Navicat连接数据库:

Linux CentOS上安装 MySQL 8.0.16