1 官网下载地址
https://downloads.mysql.com/archives/community/
第一步:查看liunx版本信息
命令:hostnamectl
[root@localhost ~]# hostnamectl
Static hostname: localhost.localdomain
Icon name: computer-vm
Chassis: vm
Machine ID: f7eb71895dc2463a9e0821752be0a67b
Boot ID: afa98f4bc55745e389c7c35215e99f9d
Virtualization: vmware
Operating System: CentOS Linux 7 (Core)
CPE OS Name: cpe:/o:centos:centos:7
Kernel: Linux 3.10.0-1160.el7.x86_64
Architecture: x86-64
命令:cat /proc/version
[root@localhost ~]# cat /proc/version
Linux version 3.10.0-1160.el7.x86_64
(mockbuild@kbuilder.bsys.centos.org)
(gcc version 4.8.5 20150623 (Red Hat 4.8.5-44) (GCC) ) #1 SMP Mon Oct 19 16:18:59 UTC 2020
由上述信息可知,操作的Linux是CentOS Linux 7,64位,Red Hat,在mysql下载页面,就可以如下图选择:
如果Linux联网了,就在如图下载按钮上,右键复制链接,然后在Linux中直接下载:(要先安装wget输入命令:yum -y install wget ,然后在可以使用下面的语句)
wget https://downloads.mysql.com/archives/get/p/23/file/mysql-8.0.22-1.el7.x86_64.rpm-bundle.tar
第二步:安装MySQL
1、查看系统是否已经安装mariadb
命令:rpm -qa | grep mariadb
[root@localhost ~]# rpm -qa | grep mariadb
mariadb-libs-5.5.68-1.el7.x86_64
2、有的话卸载mariadb:不卸载有时会遇到安装mysql会失败,卸载完成后在执行rpm -qa | grep mariadb,可以看到没有了
命令:rpm -e --nodeps ********
[root@localhost ~]# rpm -qa | grep mariadb
mariadb-libs-5.5.68-1.el7.x86_64
[root@localhost ~]# rpm -e --nodeps mariadb-libs-5.5.68-1.el7.x86_64
[root@localhost ~]# rpm -qa | grep mariadb
[root@localhost ~]#
3、安装MySQL依赖包 libaio
yum install libaio
4、分别执行下面语句,创建MySQL安装目录和数据存放目录,并授权。
mkdir /usr/local/mysql
mkdir /usr/local/mysql/mysqldb
chmod -R 777 /usr/local/mysql
chmod -R 777 /usr/local/mysql/mysqldb/
5、下载mysql包,我这边是下载到 usr/local/mysql文件里面,进到这个文件夹中然后运行下载命令: **
wget https://downloads.mysql.com/archives/get/p/23/file/mysql-8.0.22-1.el7.x86_64.rpm-bundle.tar** 等待下载完成就行了
可以清楚的看到文件夹下面有刚刚下载的mysql包了
6、解压安装包
进入mysql压缩包所在目录里面,执行下面命令,压缩包名写自己的
tar -xvf mysql-8.0.22-1.el7.x86_64.rpm-bundle.tar
可以看到解压出来多了很多压缩包,如下图:
7、按顺序安装解压后文件,要在压缩包所在目录下分别执行下面命令
-- 必须安装(注意顺序)
rpm -ivh mysql-community-common-8.0.22-1.el7.x86_64.rpm
rpm -ivh mysql-community-client-plugins-8.0.22-1.el7.x86_64.rpm
rpm -ivh mysql-community-libs-8.0.22-1.el7.x86_64.rpm
rpm -ivh mysql-community-client-8.0.22-1.el7.x86_64.rpm
rpm -ivh mysql-community-server-8.0.22-1.el7.x86_64.rpm
--非必要安装(注意顺序)
rpm -ivh mysql-community-libs-compat-8.0.22-1.el7.x86_64.rpm
rpm -ivh mysql-community-embedded-compat-8.0.22-1.el7.x86_64.rpm
rpm -ivh mysql-community-devel-8.0.22-1.el7.x86_64.rpm
rpm -ivh mysql-community-test-8.0.22-1.el7.x86_64.rpm
执行过程中遇到的问题:
可以看到执行第一句的时候没问题,执行第二句的时候rpm -ivh mysql-community-libs-8.0.22-1.el7.x86_64.rpm
报错,需要某些依赖
分别执行命令:
yum install numactl -y
yum install openssl-devel.x86_64 openssl.x86_64 -y
yum -y install autoconf
yum install perl.x86_64 perl-devel.x86_64 -y
yum install perl-JSON.noarch -y
最后执行rpm -ivh mysql-community-server-8.0.22-1.el7.x86_64.rpm 的时候又报依赖需要,那就接着装依赖,装完依赖后在执行就不会报错了:
执行命令:yum install net-tools -y
8、初始化数据库
初始化数据库前千万先别执行:mysqld --initialize --console
,
先到修改/etc文件夹下面的my.cnf配置文件,修改的时候将配置文件传输到本地编辑,不然用记事本编辑配置文件就不能用了,编辑完成在传到liunx服务器上覆盖它
重要:
主要是配置文件加上lower_case_table_names=1
,我们知道在 Linux 环境下默认是区分大小写的,所以我们需要改变这种默认方式,这一句话只能在执行初始化前加,不然初始化后加就没用了,只能重装数据库在初始化前加了
之后执行下面命令启动数据库
-- 初始化数据库
mysqld --initialize --console
-- 目录授权,不授权的话MySQL没有写入权限,会启动失败
chown -R mysql:mysql /var/lib/mysql/
-- 启动msyql服务
systemctl start mysqld 或者 service mysqld start
-- 停止MySQL命令:
service mysqld stop
-- 查看msyql服务的状态
service mysqld status
可以看到下图数据库启动成功
9、更改数据库密码
查看临时密码:cat /var/log/mysqld.log
登录mysql ,
mysql -u root -p
,输入临时密码,我这边是直接用复制的
修改密码:alter user 'root'@'localhost' identified by '自己的密码';
刷新权限或退出重登:
-- 退出
quit;
-- 刷新权限
flush privileges; # 立即生效
如下图就是改成功的
查看
lower_case_table_names
值
命令:show variables like 'lower%';
10、卸载MySQL
1、关闭mysql
service mysqld stop
2、查看安装的mysql
rpm -qa|grep -i mysql
3、卸载安装的mysql
rpm -ev mysql-community-client-8.0.22-1.el7.x86_64 --nodeps
rpm -ev mysql-community-common-8.0.22-1.el7.x86_64 --nodeps
rpm -ev mysql-community-libs-8.0.22-1.el7.x86_64 --nodeps
rpm -ev mysql-community-client-plugins-8.0.22-1.el7.x86_64 --nodeps
rpm -ev mysql-community-server-8.0.22-1.el7.x86_64 --nodeps
4、删除mysql相关目录
通过find / -name mysql
找到相关目录,在通过rm -rf
删除
5、删除my.cnf
rm -rf /etc/my.cnf
6、检查卸载情况
rpm -qa|grep -i mysql