准备

安装环境

  • 我们先把下载的mysql-5.7.23-1.el7.x86_64.rpm-bundle.tar 上传到我们的centos系统中,最好传到/opt 文件夹中
  • 然后我们建立一个新的,用于盛放tar文件释放后文件的文件夹:
cd /opt
mkdir mysql
  • 然后运行解压命令:
tar -xf mysql-5.7.23-1.el7.x86_64.rpm-bundle.tar -C mysql
  • 这时,我们再到mysql的目录下就可以看到解压出来的rpm包:
  • 资源都准备好了,现在我们来看一下环境:
    由于CentOs7之后会在系统中自带一个免费的数据库:mariadb,并且它的驱动和mysql的驱动是有冲突的,所以我们必须先要卸载他。(ps.mariadb和mysql是同一个作者创作的数据库,由于权益等其他问题才分开的,所以有兴趣的同志可以研究一下。)

首先用rpm命令查看一下是否有mariadb,然后再删除:

rpm -qa | grep -i mariadb

可能会出现这种情况:
然后我们用rpm命令删除这个版本的mariadb:

rpm -e --nodeps mariadb-libs-5.5.52-1.el7.x86_64

这个名字在不同版本的系统上可能不一样,大家需要注意。

如果是centos7之前的版本的话,可能会自带mysql,这是我们需要按照上述步骤删除mysql,这里不再赘述。

由于mysql的server端需要perl语言的支持,因此我们还需要在系统中安装perl支持:

yum install perl -y

安装

由于我们上面解压出来的几个rpm包有依赖关系,所以我们需要按照顺序执行安装:

rpm -ivh mysql-community-common-5.7.23-1.el7.x86_64.rpm
rpm -ivh mysql-community-libs-5.7.23-1.el7.x86_64.rpm
rpm -ivh mysql-community-client-5.7.23-1.el7.x86_64.rpm
rpm -ivh mysql-community-server-5.7.23-1.el7.x86_64.rpm

有可能错误:依赖检测失败:
net-tools 被 mysql-community-server-5.7.24-1.el7.x86_64 需要
解决办法:[root@localhost local]# yum install net-tools

这几个包的安装完成之后,我们的数据库也就安装完成了,有几个需要注意的地方:

数据库目录:/var/lib/mysql/
命令配置:/usr/share/mysql  (mysql.server命令及配置文件)
相关命令:/usr/bin   (mysqladmin mysqldump等命令)
启动脚本:/etc/rc.d/init.d/   (启动脚本文件mysql的目录)
系统配置:/etc/my.conf

运行-初始化

  • 安装完成了,我们需要先把mysql运行起来,这样我们才能进行接下来的配置。
  • 强烈建议在root用户环境下进行初始化配置,方便用户和密码的创建。

现在我们可以先看一下 /var/lib/mysql/ 目录下是否有东西,我们可以发现这个目录下是没有东西的,或者是连mysql这个目录都没有,也就是说数据库还没有初始化。

注意:

这里我跳过了初始化root用户,或者是mysql用户的步骤,因为网上看在5.7.12上可以成功的步骤在5.7.23上却会在启动步骤报错,原因未知。
 现在我们来配置mysql的启动,个人比较推荐使用服务的方式启动(centos7特有):

添加服务到系统:

systemctl start mysqld.service

这样就把mysqld这个服务添加到系统中了,我们可以用service进行启动了,启动,停止,重启的命令如下:

启动:

使用 service 启动:service mysqld start
使用 mysqld 脚本启动:/etc/inint.d/mysqld start
使用 safe_mysqld 启动:safe_mysqld&

停止:

使用 service 启动:service mysqld stop
使用 mysqld 脚本启动:/etc/inint.d/mysqld stop
mysqladmin shutdown

重启:

使用 service 启动:service mysqld restart
使用 mysqld 脚本启动:/etc/inint.d/mysqld restart
  • 我们在启动了mysql之后,这个时候等待一段时间,数据库需要进行初始化,这个时候我们可以看一下数据库的日志,会发现mysql帮我们初始化了一个root用户:
cat /var/log/mysqld.log

由于服务已经启动了,所以可以用root和这个密码登陆了:

mysql -u root -p 
password 输入自己获得的密码

修改密码:

set password = password('你的密码');
如果修改密码出现:RROR 1819 (HY000): Your password does not satisfy the current policy requirements
请参考这篇博客:

设置外部远程访问权限:

GRANT ALL PRIVILEGES ON *.* TO 'root'@'%' IDENTIFIED BY '123456' WITH GRANT OPTION;

开放端口:

这里设置完之后,就可以在其他局域网内电脑上用Navicat连接一下看看能不能连接了,如果遇到带有数字的报错(非denind)的话,可以尝试开启防火墙的端口限制:

开启3306端口:

firewall-cmd --zone=public --add-port=3306/tcp --permanent

#刷新防火墙
firewall-cmd --reload
防火墙操作学习:
设置开机启动:
chkconfig mysqld on