linux使用tar包方式安装mysql5.7详解小白教程

本文涉及的产品
云数据库 RDS MySQL,集群系列 2核4GB
推荐场景:
搭建个人博客
RDS MySQL Serverless 基础系列,0.5-2RCU 50GB
云数据库 RDS PostgreSQL,集群系列 2核4GB
简介: linux使用tar包方式安装mysql5.7详解小白教程

写在前面:目前网络上大多数的安装教程采用的是rpm的方式,此种方式是需要虚拟机联网完成的,我介绍的是使用tar包的方式安装mysql5.7的方法。

:heavy_exclamation_mark:首先要注意的一点是,在输入命令的时候你一定要注意你是在哪个文件夹下输入的命令,因为不同的文件夹下有些命令可能执行是完全错误的。

:bangbang:还需要注意的一点,我的mysql文件叫做mysql57,我的mysql57是安装在/usr/local/文件夹下的,你当然可以按照自己的喜好去选择位置,选择名字,但是最好可以和我统一一下,可以避免很多不必要的麻烦。

准备工作

要安装,必不可少的肯定是安装包了,你可以去mysql官网下载tar包,

下载完成后还有一步,就是你如果是本地下载的话是需要上传到linux虚拟机的,有些虚拟机是可以直接通过拖拽的方式将文件传输进去。但有些是不可以的。我是安装了lrzsz工具完成的上传。

最好上传到 /usr/local/ 这里面,因为我的程序就是在这个目录下安装,不统一的话可能又会导致很多问题。

:smile: 完事具备,我们就开始安装之路吧。

开始安装

1. 卸载系统自带的Mariadb

[root@ ~]# rpm -qa|grep mariadb
mariadb-libs-5.5.44-2.el7.centos.x86_64  #显示这个就意味着有mariadb你是需要卸载的。
[root@ ~]# rpm -e --nodeps mariadb-libs-5.5.44-2.el7.centos.x86_64

2.卸载etc目录下的my.cnf文件

这个文件就是mysql的配置文件,就好比Windows下的my.ini文件。

[root@ ~]# rm /etc/my.cnf   
rm: cannot remove ?etc/my.cnf? No such file or directory  #这个提示就是没有此文件,我们就可以进行接下来的操作了

3.检查mysql是否存在

[root@ ~]# rpm -qa | grep mysql   #没有内容就代表着没有安装

如果你已经安装了mysql,那就需要卸载后再考虑安装。

4. 检查mysql组和用户是否存在,如无创建

[root@ ~]# cat /etc/group | grep mysql
[root@ ~]# cat /etc/passwd | grep mysql

如果两条命令输入后没有反馈就代表不存在,就需要新建

5.创建mysql用户组

[root@ ~]# groupadd mysql

6.创建mysql用户,并加入mysql用户组

[root@ ~]# useradd -g mysql mysql

7.设置mysql用户的密码

要注意这里设置的是mysql这个用户的密码,和一会数据库的密码不是一回事。

[root@ ~]# passwd mysql

8.解压安装

:warning:这里开始就算比较重要且容易出错误的地方了。

上面不是把 mysql-5.7.46-2.7-x86_64.tar.gz 这个压缩包放到 了/usr/local/的里面了,(注意是在local里面,不是local同一级)

我们就在local文件夹下这里进行解压安装。

root@ local]# tar -zxvf mysql-5.7.46-2.7-x86_64.tar.gz   #这一步就是解压安装文件
[root@ local]# mv mysql-install/ mysql57  # 这步是把解压后的文件进行一个改名的操作

#更改所属的组和用户
[root@ local]# chown -R mysql mysql57/
[root@ local]# chgrp -R mysql mysql57/
[root@ local]# cd mysql57/

[root@ mysql57]# mkdir data  #创建一个data文件夹存放数据

[root@ mysql57]# chown -R mysql:mysql data

9.在etc下新建配置文件my.cnf

我们在第二步的时候不是删除了配置文件,此时这里我们需要重新配置一个。

touch my.cnf

先新建my.cnf这个文件,然后vi进去修改内容,具体内容如下:

[mysql]
# 设置mysql客户端默认字符集
default-character-set=utf8
[mysqld]
skip-name-resolve
#设置3306端口
port = 3306
# 设置mysql的安装目录
basedir=/usr/local/mysql57
# 设置mysql数据库的数据的存放目录
datadir=/usr/local/mysql57/data
# 允许最大连接数
max_connections=200
# 服务端使用的字符集默认为8比特编码的latin1字符集
character-set-server=utf8
# 创建新表时将使用的默认存储引擎
default-storage-engine=INNODB
lower_case_table_names=1
max_allowed_packet=16M
#配置免密登录
skip-grant-tables

[mysqld_safe]
# 配置日志文件和进程文件
error-log=/usr/local/error.log
pid-file=/usr/local/mysql.pid

这个配置文件,很多都是与mysql的安装路径有关的,所以你如果和我的不统一,就需要做相应的修改。

10.安装与初始化

:heavy_exclamation_mark:要注意这些命令是在mysql57这个目录下执行的,这点尤为重要

[root@ mysql57]# bin/mysql_install_db --user=mysql --basedir=/usr/local/mysql57/ --datadir=/usr/mysql57/data/
[root@ mysql57]# cp ./support-files/mysql.server /etc/init.d/mysqld
[root@ mysql57]# chown 777 /etc/my.cnf 
[root@ mysql57]# chmod +x /etc/init.d/mysqld

11.重启

[root@ mysql57]# /etc/init.d/mysqld restart
Shutting down MySQL.. SUCCESS! 
Starting MySQL. SUCCESS! 

12.设置开机启动

[root@ mysql57]# chkconfig --level 35 mysqld on
[root@ mysql57]# chkconfig --list mysqld
[root@ mysql57]# chmod +x /etc/rc.d/init.d/mysqld
[root@ mysql57]# chkconfig --add mysqld
[root@ mysql57]# chkconfig --list mysqld
[root@ mysql57]# service mysqld status
SUCCESS! MySQL running (4475)

13.设置环境变量

在/etc/profile这个文件中,要加一句话

export PATH=$PATH:/var/mysql57/bin
[root@ mysql57]# source /etc/profile   #重启

14.获得初始密码

这个密码就是数据库的密码,其实我们在my.cnf里是设置了一个免密登录的,所以这个显得并不是特别必要要知道的。

[root@ ~]# cat /root/.mysql_secret 
# Password set for user 'root@localhost' at 2022-08-19 16:47:12 
7qa2CT1sYO_1

15. 修改密码

这里我当时一直会报一个mysql命令找不到的错误,后来发现是没有在/usr/local/mysql57/bin下面执行mysql命令,所以导致这一问题解决不了。(后面配置软链接就可以在任何目录下都可以执行mysql命令了)

[root@hdp265dnsnfs bin]# mysql -uroot -p
mysql> set PASSWORD = PASSWORD('123456');
Query OK, 0 rows affected, 1 warning (0.00 sec)

mysql> flush privileges;
Query OK, 0 rows affected (0.01 sec)

16. 添加远程访问权限

这接下来的操作就是为了本地Navicat能够远程连接Linux虚拟机上的准备。

在本机先使用root用户登录mysql: mysql -u root -p"youpassword" 进行授权操作:

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

重载授权表:

FLUSH PRIVILEGES;

退出mysql数据库:

exit

xn_2022-08-22_15-32-32

这命令我们可以看出来,root这个用户,是允许任何用户(%)登录的。

17.重启生效

/bin/systemctl restart  mysql.service

[root@ bin]# /etc/init.d/mysqld restart 
Shutting down MySQL.. SUCCESS! 
Starting MySQL. SUCCESS! 

18.可以在任何目录下登录mysql

ln -s /usr/local/mysql57/bin/mysql   /usr/bin/mysql

19. 开放外部访问数据库

  1. 开放防火墙端口
firewall -cmd --list-all
  1. 开放3306端口
firewall-cmd --permanent --add-port=3306/tcp
  1. 查看3306端口是否开放
firewall-cmd --query-port=3306/tcp
  1. 次查看现在防火墙
firewall-cmd --list-all

20. Navicat连接

xn_2022-08-22_17-01-38

xn_2022-08-22_17-02-37

:heavy_check_mark:到这里mysql的安装过程就结束了。

相关实践学习
如何快速连接云数据库RDS MySQL
本场景介绍如何通过阿里云数据管理服务DMS快速连接云数据库RDS MySQL,然后进行数据表的CRUD操作。
全面了解阿里云能为你做什么
阿里云在全球各地部署高效节能的绿色数据中心,利用清洁计算为万物互联的新世界提供源源不断的能源动力,目前开服的区域包括中国(华北、华东、华南、香港)、新加坡、美国(美东、美西)、欧洲、中东、澳大利亚、日本。目前阿里云的产品涵盖弹性计算、数据库、存储与CDN、分析与搜索、云通信、网络、管理与监控、应用服务、互联网中间件、移动服务、视频服务等。通过本课程,来了解阿里云能够为你的业务带来哪些帮助     相关的阿里云产品:云服务器ECS 云服务器 ECS(Elastic Compute Service)是一种弹性可伸缩的计算服务,助您降低 IT 成本,提升运维效率,使您更专注于核心业务创新。产品详情: https://www.aliyun.com/product/ecs
目录
相关文章
|
2天前
|
关系型数据库 MySQL 数据库
【MySQL基础篇】MySQL概述、Windows下载MySQL8.0超详细图文安装教程
在这一章节,主要介绍两个部分,数据库相关概念及MySQL数据库的介绍、下载、安装、启动及连接。接着,详细描述了MySQL 8.0的版本选择与下载,推荐使用社区版(免费)。安装过程包括自定义安装路径、配置环境变量、启动和停止服务、以及客户端连接测试。此外,还提供了在同一台电脑上安装多个MySQL版本的方法及卸载步骤。最后,解释了关系型数据库(RDBMS)的特点,即基于二维表存储数据,使用SQL语言进行操作,格式统一且便于维护。通过具体的结构图展示了MySQL的数据模型,说明了数据库服务器、数据库、表和记录之间的层次关系。
【MySQL基础篇】MySQL概述、Windows下载MySQL8.0超详细图文安装教程
|
8天前
|
关系型数据库 MySQL 数据库
docker高级篇(大厂进阶):安装mysql主从复制
docker高级篇(大厂进阶):安装mysql主从复制
66 24
|
16天前
|
NoSQL Java 关系型数据库
Liunx部署java项目Tomcat、Redis、Mysql教程
本文详细介绍了如何在 Linux 服务器上安装和配置 Tomcat、MySQL 和 Redis,并部署 Java 项目。通过这些步骤,您可以搭建一个高效稳定的 Java 应用运行环境。希望本文能为您在实际操作中提供有价值的参考。
89 26
|
2天前
|
NoSQL 关系型数据库 MySQL
Linux安装jdk、mysql、redis
Linux安装jdk、mysql、redis
58 7
|
27天前
|
关系型数据库 MySQL Java
Servlet+MySQL增删改查 原文出自[易百教程] 转载请保留原文链接: https://www.yiibai.com/geek/1391
对于任何项目开发,创建,读取,更新和删除(CRUD)记录操作是应用程序的一个最重要部分。
64 20
|
7月前
|
运维 Linux
Linux命令(66)之tar
Linux命令(66)之tar
93 6
|
7月前
|
Linux
Linux命令之tar
Linux命令之tar
56 3
|
7月前
|
算法 Linux
【Linux】常用的压缩解压缩命令之tar命令
【Linux】常用的压缩解压缩命令之tar命令
479 0
|
Linux
Linux命令之解压缩:tar、zip、rar 命令
Linux命令之解压缩:tar、zip、rar 命令
132 0
|
Linux
Linux常用命令 - tar命令详解
Linux常用命令 - tar命令详解
240 0