1.下载mysql5.7的rpm安装包
下载地址:https://dev.mysql.com/downloads/mysql/5.7.html#downloads
https://dev.mysql.com/downloads/mysq
2.上传mysql安装包到centos7的系统下
可以使用FTP工具即可
3.安装依赖
3.1 查看linux上是否已经安装了mysql,有则卸载。
一般centos7默认安装了mariadb,这里把它卸载。
rpm -qa |grep mysql
rpm -qa |grep postfix
rpm -qa |grep mariadb
#卸载命令
rpm -e --nodeps mariadb-libs-5.5.56-2.el7.x86_64
3.2 安装mysql5.7所需要的依赖
yum -y install libaio
yum -y install net-tools
yum -y install perl
4.安装mysql5.7
4.1 解压mysql5.7安装包
tar -xvf mysql-5.7.24-1.el7.x86_64.rpm-bundle.tar
解压完后会有很过rpm文件,这些就是我们需要安装的。
4.2 安装mysql5.7(按一下顺序安装)
rpm -ivh mysql-community-common-5.7.24-1.el7.x86_64.rpm
rpm -ivh mysql-community-libs-5.7.24-1.el7.x86_64.rpm
rpm -ivh mysql-community-client-5.7.24-1.el7.x86_64.rpm
rpm -ivh mysql-community-server-5.7.24-1.el7.x86_64.rpm
4.3 查看mysql5.7的状态,没有启动则把mysql启动
查看mysql启动状态
service mysqld status
出现下面这个death就是没有启动,新装的第一次是没有启动的。
service mysqld start
4.4 修改密码
#查看临时密码:得知临时密码
grep password /var/log/mysqld.log
#用临时密码登录mysql
mysql -uroot –p
#修改成新的密码
mysql> set password = password(“Mysql_123456”);
4.5 开启远程连接,允许远程连接数据库
mysql> GRANT ALL PRIVILEGES ON . TO ‘root’@‘%’ IDENTIFIED BY ‘Mysql_123456’ WITH GRANT OPTION;
4.6 配置mysql的配置文件my.cnf
#打开配置文件my.cnf
[root@localhost src]# vi /etc/my.cnf
#在[mysqld]下面配置几行
lower_case_table_names=1 #配置表名不区分大小写 1:不区分大小写 0:区分大小写 这行必须配置 默认表名是区分大小写的,不利于开发
character-set-server=utf8 #设置为默认编码为utf8
init_connect=‘SET NAMES utf8’
max_connections=1024 #设置最大连接数
[root@localhost src]# service mysqld restart #重启mysql 重启配置才能生效
4.7 防火墙开启端口
到这其实mysql已经安装和配置好,但是centos7的开了防火墙,外面还是访问不到mysql的,所以还要开端口3306(或者把防火墙关掉也行,生产环境勿用)
#关闭防火墙[root@localhost src]# systemctl stop firewalld
4.8 linux下mysql5.7 及以下版本忘记密码后如何更改root用户密码记录
1)vi /etc/my.cnf
2)在[mysqld]下边的某个位置增加: skip-grant-tables ,然后 :wq 保存退出
3)在 /usr/local/mysql/bin目录下执行命令: ./mysql -u root -p ,然后回车两次,进入到mysql
4)执行命令:
use mysql
SET SQL_SAFE_UPDATES = 0
5)update mysql.user set authentication_string=password(‘root’) where User=‘root’;
6)flush privileges ;
7)执行命令:SET SQL_SAFE_UPDATES = 1
8)vi /etc/my.cnf ,删除skip-grant-tables 行
9)service mysqld restart