【MySQL】Linux安装MySQL

news2024/11/15 11:15:58

一、center OS环境准备

为了在Linux系统中查看MySQL5.8与8.0版本的区别
我们要准备两个虚拟机,需要的软件:VMware和CentOS7

因为博主之前在学习redis的时候已经安装过一个虚拟机了,所以我就直接克隆了一个CentOS2.0
在这里插入图片描述
修改mac地址,点击克隆出来的虚拟机,选择管理,选择网络适配器,然后选择高级,在mac地址那里点击一下生成就可以了
在这里插入图片描述

修改主机名称:进入虚拟机,修改hostname然后重启

[root@myLinux2 ~]# vim /etc/hostname
myLinux2.0
[root@myLinux2 ~]# reboot

修改网络配置,包括修改IP地址,修改UUID

[root@myLinux2 ~]# vim /etc/sysconfig/network-scripts/ifcfg-ens33
TYPE="Ethernet"
PROXY_METHOD="none"
BROWSER_ONLY="no"
BOOTPROTO="static" # 由dhcp改为static,将动态分配ip地址改为静态ip
DEFROUTE="yes"
IPV4_FAILURE_FATAL="no"
IPV6INIT="yes"
IPV6_AUTOCONF="yes"
IPV6_DEFROUTE="yes"
IPV6_FAILURE_FATAL="no"
IPV6_ADDR_GEN_MODE="stable-privacy"
NAME="ens33"
UUID="ef554f10-4835-4ec8-8af5-d2391c417d9e"  # 修改UUID,避免克隆主机和原主机网卡UUID重复,对网络通信产生影响
DEVICE="ens33"
ONBOOT="yes"
#IP_ADDRESS
IPADDR="192.168.153.180" # 静态IP地址
NETMASK="255.255.255.0"  # 虚拟机和宿主机的子网掩码都是255.255.255.0
GATEWAY="192.168.1.2" # 网关,随便填的,后面可能会改
DNS1="192.168.1.2" # DNS服务器,随便填的,后面可能会改

使用:wq!保存后,执行Systemctl restart network重启网卡

注意:IPADDR有网段要求,我们打开Windows宿主机的cmd窗口,输入ipcongif查看网络配置
查看以太网适配器 VMware Network Adapter VMnet8:下面的IPV4地址,发现他是192.168.153网段的
所以虚拟机的静态IP也要在这个网段

这样一来,环境准备就算完成了

二、软件安装

1、首先,放一个MySQL官网地址在这:https://downloads.mysql.com/archives/
然后我们依次下载5.7版本和8.0版本的,注意要下载免费的MySQL Community Server社区版本

在这里插入图片描述

在这里插入图片描述
解压后,我们使用MobaXterm终端工具将解压后的文件上传到虚拟机
MySQL5.7
在这里插入图片描述
MySQL8.0
在这里插入图片描述

2、相关检查与依赖安装

  • 因为MySQL要在/tmp下创建tmp_db工具,所以要给/tmp文件比较大的权限
    chmod -R 777 /tmp
  • 检查依赖
    rpm -qa|grep libaio
    rpm -qa|grep net-tools
    在这里插入图片描述
  • 接下来,我们按照顺序进行安装,如果执行遇到这个报错
rpm -ivh mysql-community-libs-8.0.36-1.el7.x86_64.rpm
warning: mysql-community-libs-8.0.36-1.el7.x86_64.rpm: Header V4 RSA/SHA256 Signature, key ID a8d3785c: NOKEY
error: Failed dependencies:
        mariadb-libs is obsoleted by mysql-community-libs-8.0.36-1.el7.x86_64

那就需要使用命令yum remove mysql-libs清除相关依赖

MySQL8.0

rpm -ivh mysql-community-common-8.0.36-1.el7.x86_64.rpm
rpm -ivh mysql-community-client-plugins-8.0.36-1.el7.x86_64.rpm
rpm -ivh mysql-community-libs-8.0.36-1.el7.x86_64.rpm
rpm -ivh mysql-community-client-8.0.36-1.el7.x86_64.rpm
rpm -ivh mysql-community-icu-data-files-8.0.36-1.el7.x86_64.rpm
rpm -ivh mysql-community-server-8.0.36-1.el7.x86_64.rpm

MySQL5.7

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

安装完成之后
在这里插入图片描述
在这里插入图片描述

3、服务初始化

# 初始化,保证数据库目录与文件的所有者为mysql登录用户
[root@myLinux2 mysql-8.0]# mysqld --initialize --user=mysql
# 查看MySQL相关信息,包括为root用户创建的临时密码
[root@myLinux2 mysql-8.0]# cat /var/log/mysqld.log

查看MySQL是否启动,如果是dead状态,用命令启动

[root@myLinux2 mysql-8.0]# systemctl status mysqld
● mysqld.service - MySQL Server
   Loaded: loaded (/usr/lib/systemd/system/mysqld.service; enabled; vendor preset: disabled)
   Active: inactive (dead)
     Docs: man:mysqld(8)
           http://dev.mysql.com/doc/refman/en/using-systemd.html
[root@myLinux2 mysql-8.0]#
[root@myLinux2 mysql-8.0]#
[root@myLinux2 mysql-8.0]# systemctl start mysqld

使用systemctl list-unit-files|grep mysqld.service查看进程是否为自启动
如果输出的信息不是enabled,那么使用systemctl enable mysqld.service将其设置成自启动,如果不希望自启动就使用systemctl disable mysqld.service

[root@myLinux2 mysql-8.0]# systemctl list-unit-files|grep mysqld.service
mysqld.service                                enabled

4、登录MySQL,需要重置root密码,重新登录才能进行操作

[root@myLinux2 mysql-8.0]# mysql -uroot -p
Enter password: #输入之前/var/log/mysqld.log中展示的密码
Welcome to the MySQL monitor.  Commands end with ; or \g.
...
mysql>
mysql> show databases;
ERROR 1820 (HY000): You must reset your password using ALTER USER statement before executing this statement.
# 修改root用户密码
mysql> alter user 'root'@'localhost' identified by '你的密码';
Query OK, 0 rows affected (0.00 sec)

mysql> quit;
Bye
[root@myLinux2 mysql-8.0]#

5、实现远程连接

  • 测试网络是否可用
    首先确保我们telnet功能是打开的
    在这里插入图片描述
    使用ping和telnet测试之后,发现3306端口无法访问
    在这里插入图片描述

  • 放通防火墙指定端口

# 查看当前哪些端口是放通的
[root@myLinux1 ~]# firewall-cmd --list-all
# 把3306端口放通
[root@myLinux1 ~]# firewall-cmd --add-port=3306/tcp --permanent
success
# 重启防火墙
[root@myLinux1 ~]# firewall-cmd --reload
success
# 查看3306端口是否放通
[root@myLinux1 ~]#  firewall-cmd --query-port=3306/tcp
yes

在这里插入图片描述

  • 依次执行如下SQL语句,修改MySQL中root的host字段,一定要执行flush privileges;
show databases;
use mysql;
select host,user from user;
update user set host='%' where user = 'root';
flush privileges;
exit

然后使用systemctl restart mysqld重启MySQL服务,然后我们就可以连接成功了
在这里插入图片描述
但是MySQL8.0按照上面的步骤操作之后,会有一个报错,原因是是mysql登录验证的默认插件变更了,从mysql_native_password变为caching_sha2_password
在这里插入图片描述

为了解决这个问题,我们需要使用如下sql

use mysql;
alter user 'root'@'%' identified with mysql_native_password BY '你的密码';
flush privileges;

链接成功
在这里插入图片描述

三、卸载MySQL

因为前面博主改错了user表中的host,导致不管是从虚拟机还是从navicat都登不上MySQL8.0
所以只能重新安装

# 关闭MySQL服务
[root@myLinux2 ~]# systemctl status mysqld
# 查看MySQL安装状况
[root@myLinux2 ~]# rpm -qa|grep -i mysql
mysql-community-common-8.0.36-1.el7.x86_64
mysql-community-icu-data-files-8.0.36-1.el7.x86_64
mysql-community-client-plugins-8.0.36-1.el7.x86_64
mysql-community-client-8.0.36-1.el7.x86_64
mysql-community-server-8.0.36-1.el7.x86_64
mysql-community-libs-8.0.36-1.el7.x86_64
# 卸载已安装程序
[root@myLinux2 ~]# yum remove mysql-community-common-8.0.36-1.el7.x86_64
[root@myLinux2 ~]# yum remove mysql-community-icu-data-files-8.0.36-1.el7.x86_64
[root@myLinux2 ~]# yum remove mysql-community-client-plugins-8.0.36-1.el7.x86_64
# 删除MySQL相关文件
[root@myLinux2 ~]# find / -name mysql
/etc/selinux/targeted/active/modules/100/mysql
/var/lib/mysql
/var/lib/mysql/mysql
/usr/lib64/mysql
[root@myLinux2 ~]# rm -rf /etc/selinux/targeted/active/modules/100/mysql
[root@myLinux2 ~]# rm -rf /var/lib/mysql
[root@myLinux2 ~]# rm -rf /usr/lib64/mysql
# 删除my.cnf(如果存在的话)
[root@myLinux2 ~]# find / -name my.cnf
[root@myLinux2 ~]#

这样就算卸载完成啦

如有错误,欢迎指正!!!

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.coloradmin.cn/o/1793340.html

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

mysql8.0中的mysql.ibd

mysql8.0版本中多了一个mysql.ibd的文件。5.7版本则没有这个文件。 MySQL5.7: .frm文件 存放表结构信息 .opt文件,记录了每个库的一些基本 信息,包括库的字符集等信息 .TRN,.TRG文件用于存放触发器的信 息内容。 在MySQL 8.0之前&#xff0…

Windows10系统中安装与配置PyTorch(无GPU版本)

文章目录 1. 什么是PyTorch2. PyTorch的安装与配置(无GPU)2.1 创建环境2.2 安装pytorch库(无GPU)2.3 验证安装结果 1. 什么是PyTorch PyTorch 是一种用于构建深度学习模型且功能完备的开源框架,通常用于处理图像识别和…

计算机网络学习实践:模拟RIP动态路由

计算机网络学习实践:模拟RIP动态路由 模拟动态路由RIP协议 1.实验准备 实验环境:华为模拟器ENSP 实验设备: 3个路由器,3个二层交换机(不是三层的),3个PC机 5个网段 192.168.1.0 255.255.…

【C++】STL:栈和队列模拟实现

💞💞 前言 hello hello~ ,这里是大耳朵土土垚~💖💖 ,欢迎大家点赞🥳🥳关注💥💥收藏🌹🌹🌹 💥个人主页&#x…

spring boot sso

代码:https://gitee.com/forgot940629/ssov2 授权服务 登录成功后,session中会存储UsernamePasswordAuthenticationToken,之后每次请求code时都会用UsernamePasswordAuthenticationToken生成OAuth2Authentication,并将OAuth2Aut…

【远程连接服务器】—— Workbench和Xshell远程连接阿里云服务器失败和运行Xshell报错找不到 MSVCP110.d的问题分析及解决

提示:文章写完后,目录可以自动生成,如何生成可参考右边的帮助文档 文章目录 前言一、远程连接不上服务器1. Workbench远程连接失败2.Xshell也连接不上3.解决方法(1)问题描述:(2)解决: 4.再次连接服务器 二、运行Xshell…

SpringBoot 基于jedis实现Codis高可用访问

codis与redis的关系 codis与redis之间关系就是codis是基于多个redis实例做了一层路由层来进行数据的路由,每个redis实例承担一定的数据分片。 codis作为开源产品,可以很直观的展示出codis运维成本低,扩容平滑最核心的优势. 其中&#xff0…

算法第三天力扣第69题:X的平方根

69. x 的平方根 (可点击下面链接或复制网址进行做题) https://leetcode.cn/problems/sqrtx/https://leetcode.cn/problems/sqrtx/ 给你一个非负整数 x ,计算并返回 x 的 算术平方根 。 由于返回类型是整数,结果只保留 整数部分 ,小数部分将被…

【实战JVM】-实战篇-06-GC调优

文章目录 1 GC调优概述1.1 调优指标1.1.1 吞吐量1.1.2 延迟1.1.3 内存使用量 2 GC调优方法2.1 发现问题2.1.1 jstat工具2.1.2 visualvm插件2.1.3 PrometheusGrafana2.1.4 GC Viewer2.1.5 GCeasy 2.2 常见GC模式2.2.1 正常情况2.2.2 缓存对象过多2.2.3 内存泄漏2.2.4 持续FullGC…

GAT1399协议分析(六)--校时

一、官方消息定义 DeviceIDType :GA/T1400.1,采集设备、 卡口点位、 采集系统、分析系统、视图库、应用平台等设备编码规则 TimeCorrectModeType: dateTime时间格式: TimeZone:时区,GAT1400里面没有找到具体内容&…

大家都在用的4款超实用视频剪辑软件,快来码住自用吧!

随着自媒体行业的不断发展,不少小伙伴也逐渐步入了短视频的热潮。对于短视频制作来说,视频剪辑软件的选择非常重要。 如果剪辑软件不够好,整个视频就基本垮掉了。今天就给大家推荐4款好用的视频剪辑软件。 1.牛学长视频剪辑 推荐剪辑新手入门…

重复文件查找?6款电脑重复文件清理软件很靠谱!

在日常使用电脑过程中,很多人下载文件后常常会忘记它们的存在,导致同一份资料在系统中存在多个副本。虽然你可以手动删除 Windows 系统中的所有重复文件,但这样做很费时间,而且有可能会遗漏很多文件。 而且随着重复文件的不断累积…

树莓集团:引领摄影培训,打造行业人才培育高地

在当今数字化快速发展的时代,摄影技术作为文化创意产业的重要组成部分,其人才培养显得尤为重要。依托其深厚的产业背景和丰富教育资源的树莓集团,倾力打造一流的摄影培训体系,为行业输送源源不断的高素质人才。 树莓集团旗下的摄…

JAVA技术设计模式

设计模式结构图 设计原则 职责单一原则接口隔离原则 一个类对另一个类的依赖应该建立在最小的接口上 依赖倒置面向接口编程,参数或变量,依赖注入,使用父类 开闭原则 对扩展开放(对提供方),对修改关闭(对使用方) 用抽象构建框架,用实现扩展细节 里氏替换原则…

汇凯金业:贵金属交易规则有哪些

贵金属投资目前非常火热,许多投资者从中获得了可观的收益。新手投资者在进入贵金属市场及其交易之前,务必要了解清楚贵金属的交易规则。了解规则和差异能帮助新手更好地进行贵金属投资交易。下面我们以现货类贵金属为例,详细说明贵金属的交易…

【活动通知 — 线上 Meetup】:ES|QL 及 B 站 Elasticsearch 平台实践 - 6 月 19 日

会议时间 2024年6月19日 19:00 — 21:00 参与方式 线上直播:Elastic 中国社区官方博客,elasticstack B 站号。链接请参考下面的报名地址。 活动议程 19:00-19:50 主题演讲:Elasticsearch 简单而高效的管道查询语言 - ES|QL 讲师&#xff…

基于STC89C52单片机空气PM2.5系统设计资料

#include <reg52.h>#include <intrins.h>#define uint unsigned int#define uchar unsigned char //宏定义sbit RSP1^6;//液晶接口sbit ENP1^7;sbit LED P2^0;//粉尘传感器控制接口sbit ADCS P3^7;//AD0832接口sbit ADCLK P3^5;sbit ADDI P3^6;sbit ADDO P3^6;…

【已解决】Python报错 RuntimeError: No CUDA GPUs are available

本文摘要&#xff1a;本文已解决 Python FileNotFoundError 的相关报错问题&#xff0c;并总结提出了几种可用解决方案。同时结合人工智能GPT排除可能得隐患及错误。 &#x1f60e; 作者介绍&#xff1a;我是程序员洲洲&#xff0c;一个热爱写作的非著名程序员。CSDN全栈优质领…

使用cesiumLab使shp转为3dtlies

过程不做赘述&#xff0c;网上大把&#xff0c;说下注意事项。 1. 存储3DTiles 选项 若是打开则输出的文件为glb格式文件,因为glb文件好储存易传输跨平台。cesium可以使用但无法处理&#xff0c;例如改变颜色&#xff0c;改着色器等。若是不打开则输出的文件为bm3d格式文件,此…

网络运维简介

目录 1.网络运维的定义 2.诞生背景 3.网络运维的重要性 4.优点 5.缺点 6.应用场景 6.1.十个应用场景 6.2.数据中心运维 7.应用实例 8.小结 1.网络运维的定义 网络运维&#xff08;Network Operations&#xff09;是指管理、监控和维护计算机网络以确保其高效、安全和…