Linux安装MySQL

本文详细介绍了如何在Linux系统中使用RPM包管理器安装MySQL,包括检查是否安装过MySQL,卸载冲突的mariadb,上传和解压安装包,按照顺序安装rpm包,启动和管理MySQL服务,获取并修改root密码,以及设置远程访问权限。最后,还提到了验证密码策略和防火墙设置。
摘要由CSDN通过智能技术生成

安装

对于MySQL数据库的安装,我们将要使用rpm进行安装。那么首先我们先了解一下什么rpm?
**RPM:**全称为 Red-Hat Package Manager,RPM软件包管理器,是红帽Linux用于管理和安装软件的工具。
我们要通过rpm,进行MySQL数据库的安装,主要的步骤如下:

1). 检测当前系统是否安装过MySQL相关数据库

需要通过rpm相关指令,来查询当前系统中是否存在已安装的mysql软件包,执行指令如下:

rpm -qa							        #查询当前系统中安装的所有软件
rpm -qa | grep mysql		  	#查询当前系统中安装的名称带mysql的软件
rpm -qa | grep mariadb			#查询当前系统中安装的名称带mariadb的软件

通过rpm -qa 查询到系统通过rpm安装的所有软件,太多了,不方便查看,所以我们可以通过管道符 | 配合着grep进行过滤查询。
image.png
通过查询,我们发现在当前系统中存在mariadb数据库,是CentOS7中自带的,而这个数据库和MySQL数据库是冲突的,所以要想保证MySQL成功安装,需要卸载mariadb数据库。

2). 卸载现有的MySQL数据库**

在rpm中,卸载软件的语法为:

rpm -e --nodeps  软件名称

那么,我们就可以通过指令,卸载 mariadb,具体指令为:

rpm -e --nodeps  mariadb-libs-5.5.68-1.el7_5.x86_64
rpm -e --nodeps  mariadb-5.5.68-1.el7.x86_64

image.png
执行完毕之后, 再次查询 mariadb,就查不到了,因为已经被成功卸载了。

3.提供的MySQL安装包上传到Linux并解压

A. 上传MySQL安装包
我们需要将该安装包上传到Linux系统
我下载的是mysql-5.7.25-1版本的,你们自便。

网址:https://mirrors.aliyun.com/mysql/
image.png
image.png
B. 解压到/usr/local/mysql
执行如下指令:

mkdir /usr/local/mysql
tar -zxvf mysql-5.7.25-1.el7.x86_64.rpm-bundle.tar.gz -C /usr/local/mysql

image.png
以上都是mysql的安装包

4). 安装顺序安装rpm安装包

一定要安装顺序执行 不然安装失败 会很麻烦!!!!!!

rpm -ivh mysql-community-common-5.7.25-1.el7.x86_64.rpm
rpm -ivh mysql-community-libs-5.7.25-1.el7.x86_64.rpm
rpm -ivh mysql-community-devel-5.7.25-1.el7.x86_64.rpm
rpm -ivh mysql-community-libs-compat-5.7.25-1.el7.x86_64.rpm
rpm -ivh mysql-community-client-5.7.25-1.el7.x86_64.rpm
yum install net-tools
rpm -ivh mysql-community-server-5.7.25-1.el7.x86_64.rpm

说明:

  • 因为rpm安装方式,是不会自动处理依赖关系的,需要我们自己处理,所以对于上面的rpm包的安装顺序不能随意修改。
  • 安装过程中提示缺少net-tools依赖,使用yum安装(yum是一种在线安装方式,需要保证联网)
  • 可以通过指令(yum update)升级现有软件及系统内核

image.png
一共是7步!!!!!!

MySQL启动

MySQL安装完成之后,会自动注册为系统的服务,服务名为mysqld。那么,我们就可以通过systemctl指令来查看mysql的状态、启动mysql、停止mysql。

systemctl status mysqld		查看mysql服务状态
systemctl start mysqld		启动mysql服务    
systemctl stop mysqld		停止mysql服务

image.png

说明:
可以设置开机时启动mysql服务,避免每次开机启动mysql。执行如下指令:
systemctl enable mysqld

我们可以通过如下两种方式,来判定mysql是否启动:

netstat -tunlp                  查看已经启动的服务
netstat -tunlp | grep mysql     查看mysql的服务信息

ps -ef|grep mysql               查看mysql进程

image.png

备注:

A. netstat命令用来打印Linux中网络系统的状态信息,可让你得知整个Linux系统的网络情况。

  参数说明:

  -l或--listening:显示监控中的服务器的Socket;<br />		-n或--numeric:直接使用ip地址,而不通过域名服务器;<br />		-p或--programs:显示正在使用Socket的程序识别码和程序名称;<br />		-t或--tcp:显示TCP传输协议的连线状况;<br />		-u或--udp:显示UDP传输协议的连线状况;

B. ps命令用于查看Linux中的进程数据。

MySQL登录

查阅临时密码

MySQL启动起来之后,我们就可以测试一下登录操作,但是我们要想登录MySQL,需要一个访问密码,而刚才在安装MySQL的过程中,并没有看到让我们设置访问密码,那这个访问密码是多少呢? 那实际上,对于rpm安装的mysql,在mysql第一次启动时,会自动帮我们生成root用户的访问密码,并且输出在mysql的日志文件 /var/log/mysqld.log中,我们可以查看这份日志文件,从而获取到访问密码。
可以执行如下指令:

cat /var/log/mysqld.log

image.png
这种方式,可以看到所有的日志数据,文件比较大时,很不方便查看数据。我们可以通过管道符 | 配合grep来对数据进行过滤。

cat /var/log/mysqld.log | grep password

我们可以通过上述指令,查询日志文件内容中包含password的行信息。
image.png
uclaX.1?Ehwo

登录MySQL

获取到root用户的临时密码之后,我们就可以登录mysql数据库,修改root的密码,为root设置一个新的密码。并且我们还需要开启root用户远程访问该数据库的权限,这样的话,我们就可以在windows上来访问这台MySQL数据库。

. 登录mysql(复制日志中的临时密码登录)
	mysql -uroot -p								

②. 修改密码
    set global validate_password_length=4;			设置密码长度最低位数
    set global validate_password_policy=LOW;		设置密码安全等级低,便于密码可以修改
    set password = password('你的密码');				设置密码为root
    
③. 开启访问权限
数据库中授予对所有数据库和表的所有权限给 'root' 用户,并且该用户可以从任何主机 '%' 进行访问,密码为 '1123'grant all on *.* to 'root'@'%' identified by '你的密码'; 表示匹配所有的ip地址 可以访问
    flush privileges; 刷新立即生效

image.png

在MySQL中,validate_password_policy 系统变量确定密码策略的执行级别。可能的取值包括:

LOW:密码必须至少包含8个字符。
MEDIUM:密码必须至少包含8个字符,并满足额外的要求,如包含大小写字母和至少一个数字。
STRONG:相比中等策略,密码必须满足更严格的要求。
通过将 validate_password_policy 设置为 LOW,选择了最不严格的策略,其中密码只需至少包含8个字符。

操作完上述的指令之后,数据库root用户的密码以及远程访问我们就配置好了,接下来,可以执行exit退出mysql,再次通过新的密码进行登录。
image.png
注意: 要想在windows上能够访问MySQL,还需要开放防火墙的3306端口,执行如下指令:

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

如果你是阿里云服务器的话也要打开3306的安全组!!!!!

  • 24
    点赞
  • 20
    收藏
    觉得还不错? 一键收藏
  • 1
    评论
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值