Linux(CentOS7)安装与卸载MySQL8.0图文详解

Linux(CentOS7)安装与卸载MySQL8.0图文详解

Mysql数据库的安装对于开发者来说,是我们必然会面对的问题,它的安装过程其实并不复杂,并且网络上的安装教程也非常多,但是对于新手来说,各种不同形式的安装教程,又给新手们带来了要选择哪种方式进行安装的难题,而且很多时候按照教程也没有能够安装成功,安装过程出现各种各样的错误。

下面记录了我在Linux(Centos 7)环境下安装Mysql的完整过程,实操记录,绝非水文,如有错误或遗漏,欢迎指正。

1.下载 MySQL 所需要的安装包

​ 网址:https://dev.mysql.com/downloads/mysql/

下载 MySQL 所需要的安装包

2.Select Operating System: 选择 Red Hat ,CentOS 是基于红帽的,Select OS Version: 选择 linux 7

选择 linux 7

3.选择 RPM Bundle 点击 Download

选择 RPM Bundle 点击 Download

4.点击 No thanks, just start my download. 进行下载

下载

5.下载好后,使用xshell连接到我们的虚拟机。

使用xshell连接到我们的虚拟机

6.通过 rpm -qa | grep mariadb 命令查看 mariadb 的安装包

查看 mariadb 的安装包

7.通过 rpm -e mariadb-libs-5.5.60-1.el7_5.x86_64 —nodeps 命令装卸 mariadb

注意:mariadb-libs-5.5.60-1.el7_5.x86_64名称根据自己实际修改

装卸 mariadb

8.通过 rpm -qa | grep mariadb 命令再次查看 mariadb 的安装包

查看 mariadb 的安装包

9.通过 cd /usr/local/ 命令进入根目录下的usr目录下的local目录,这个目录是放一些本地的共享资源的

进入根目录下的usr目录下的local目录

10.通过 ll 命令查看一下当前目录下的目录结构

通过 ll 命令查看一下当前目录下的目录结构

11.通过 mkdir mysql 命令 在当前目录下创建一个名为 mysql 的目录

创建一个名为 mysql 的目录

12.通过 ll 命令查看一下当前目录下的目录结构,刚创建的 mysql 目录有了

ll 命令查看一下当前目录下的目录结构

13.通过 cd mysql 命令进入 mysql 目录

cd mysql 命令进入 mysql 目录

14.通过 ll 命令查看一下当前目录下的目录结构

通过 ll 命令查看一下当前目录下的目录结构

15.通过xftp把刚才下载好的mysql安装包上传到mysql目录

通过xftp把刚才下载好的mysql安装包上传到mysql目录

16.通过 ll 命令查看一下当前目录下的目录结构

通过 ll 命令查看一下当前目录下的目录结构

17.通过 tar -xvf mysql-8.0.23-1.el7.x86_64.rpm-bundle.tar 命令解压 tar 包

解压 tar 包

18.通过rpm -ivh mysql-community-common-8.0.23-1.el7.x86_64.rpm —nodeps —force 命令安装 common

安装 common

19.通过 rpm -ivh mysql-community-libs-8.0.23-1.el7.x86_64.rpm —nodeps —force 命令安装 libs

安装 libs

20.通过 rpm -ivh mysql-community-client-8.0.23-1.el7.x86_64.rpm —nodeps —force 命令安装 client

安装 client

21.通过 rpm -ivh mysql-community-server-8.0.23-1.el7.x86_64.rpm —nodeps —force 命令安装 server

安装 server

22.通过 rpm -qa | grep mysql 命令查看 mysql 的安装包

查看 mysql 的安装包

23.通过以下命令,完成对 mysql 数据库的初始化和相关配置

这儿特别注意:我们知道在 Linux 环境下默认是区分大小写的,如要改变这种默认方式,需要在初始化前修改 lower_case_table_names,mysql8.0 要求我们不能在initialize之后再更改 lower_case_table_names 的值,也就是说,再通过更改 my.cnf 文件是不管用的。

初始化前,linux 下修改文件 my.cnf ,在 [mysqld] 配置节点下添加 lower-case-table-names=1,然后再执行如下命令。

  1. mysqld --initialize;
  2. chown mysql:mysql /var/lib/mysql -R;
  3. systemctl start mysqld.service;
  4. systemctl enable mysqld;

mysql始化和相关配置

查看MySQL官方文档:

MySQL 8.0 Release Notes - Changes in MySQL 8.0.17 (2019-07-22, General Availability) - Functionality Added or Changed有记录:

  1. In MySQL 8.0, the lower_case_table_names variable can only be configured when the MySQL server is initializ

24.通过 cat /var/log/mysqld.log | grep password 命令查看数据库的密码

数据库的密码

25.通过 mysql -uroot -p 敲回车键进入数据库登陆界面

进入数据库登陆界面

26.输入刚刚查到的密码,进行数据库的登陆,复制粘贴就行,MySQL 的登陆密码也是不显示的

image-20210406155534191

27.通过 ALTER USER ‘root’@’localhost’ IDENTIFIED WITH mysql_native_password BY ‘123456’; 命令来修改密码

修改密码

28.通过 exit; 命令退出 MySQL,然后通过新密码再次登陆

退出 MySQL,然后通过新密码再次登陆

29.通过以下命令,进行远程访问的授权

  1. create user 'root'@'%' identified with mysql_native_password by '123456';
  2. grant all privileges on *.* to 'root'@'%' with grant option;
  3. flush privileges;

远程访问的授权

30.通过 ALTER USER ‘root’@’localhost’ IDENTIFIED BY ‘123456’ PASSWORD EXPIRE NEVER; 命令修改加密规则,MySql8.0 版本 和 5.0 的加密规则不一样,而现在的可视化工具只支持旧的加密方式。

image-20210406160000057

31.通过 flush privileges; 命令刷新修该后的权限

flush privileges命令刷新修该后的权限

32.通过 exit; 命令退出 MySQL。

33.通过以下命令,关闭 firewall

  1. systemctl stop firewalld.service;
  2. systemctl disable firewalld.service;
  3. systemctl mask firewalld.service;

关闭 firewall

34.通过 yum -y install iptables-services 命令安装 iptables 防火墙

安装 iptables 防火墙

35.通过以下命令启动设置防火墙

  1. systemctl enable iptables;
  2. systemctl start iptables;

启动设置防火墙

36.通过 vim /etc/sysconfig/iptables 命令编辑防火墙,添加端口

添加端口

37.点击 i 键进入插入模式

进入插入模式

38.在相关位置,写入以下内容

-A INPUT -m state —state NEW -m tcp -p tcp —dport 80 -j ACCEPT
-A INPUT -m state —state NEW -m tcp -p tcp —dport 3306 -j ACCEPT
-A INPUT -m state —state NEW -m tcp -p tcp —dport 443 -j ACCEPT
-A INPUT -m state —state NEW -m tcp -p tcp —dport 8080 -j ACCEPT
-A INPUT -m state —state NEW -m tcp -p tcp —dport 8090 -j ACCEPT
-A INPUT -m state —state NEW -m tcp -p tcp —dport 5888 -j ACCEPT

写入以下内容

点击 ESC 键退出插入模式,点击 : 键,输入 wq 敲回车键保存退出,: 为英文状态下的

39.通过 systemctl restart iptables.service 命令重启防火墙使配置生效

重启防火墙使配置生效

40.通过 systemctl enable iptables.service 命令设置防火墙开机启动

设置防火墙开机启动

41.通过 ifconfig 命令查看 ip,得到ip后我们就可以通过mysql工具连接到我们安装好的mysql了。

通过mysql工具连接到我们安装好的mysql

1、关闭mysql

  1. service mysqld stop

2、查看安装的mysql

  1. rpm -qa|grep -i mysql

查看安装的mysql

3、卸载安装的mysql

  1. rpm -ev mysql-community-client-8.0.11-1.el7.x86_64 --nodeps
  2. rpm -ev mysql-community-common-8.0.11-1.el7.x86_64 --nodeps
  3. rpm -ev mysql-community-server-8.0.11-1.el7.x86_64 --nodeps
  4. rpm -ev mysql-community-libs-8.0.11-1.el7.x86_64 --nodeps

4、删除mysql相关目录

  1. find / -name mysql
  2. [root@niceyoohw conf]# rm -rf /var/lib/mysql/
  3. [root@niceyoohw conf]# rm -rf /usr/lib64/mysql
  4. [root@niceyoohw conf]# rm -rf /etc/selinux/targeted/active/modules/100/mysql
  5. [root@niceyoohw conf]# rm -rf /etc/selinux/targeted/tmp/modules/100/mysql

删除mysql相关目录

5、删除my.cnf

  1. rm -rf /etc/my.cnf

6、检查卸载情况

  1. rpm -qa|grep -i mysql

显示为空,卸载完毕。

作者|国思软件

原文链接:https://www.cnblogs.com/88223100/p/Linux-CentOS7-Installation-and-Uninstallation-of-MySQL-8_0-Illustrations.html

本站文章如无特殊说明,均为本站原创,如若转载,请注明出处:Linux(CentOS7)安装与卸载MySQL8.0图文详解 - Python技术站

(0)
上一篇 2023年4月25日
下一篇 2023年4月25日

相关文章

  • 给技术新人的ODPS优化建议

    数据开发基本都是从陌生到熟悉,但是写多了就会发现各种好用的工具/函数,也会发现各种坑,本文分享了作者从拿到数据到数据开发到数据监控的一些实操经验。 写在前面 本文档是组内的一份算法ODPS离线开发分享,仅列出了这些年积累下来的一些重要经验和结论,特别是在算法日常数据处理和调度中的技巧和配置方法,至于具体为什么,建议大家去阿里云官网查看底层map reduce…

    MySQL 2023年4月17日
    00
  • Mysql ERROR 1577错误解决方法

    Mysql ERROR 1577错误是由于MySQL限制了查询结果集的最大大小。如果查询结果集的大小大于MySQL所允许的最大值,那么就会出现该错误。 解决方法如下: 1. 修改Mysql的配置文件 编辑MySQL的配置文件 /etc/my.cnf 或者 /etc/mysql/my.cnf,在 [mysqld] 下增加: max_allowed_packet…

    MySQL 2023年5月18日
    00
  • MySQL主键自增长(AUTO_INCREMENT)详解

    主键是数据库表中用于唯一标识每个记录的列,自增长是一种主键属性,指的是当插入新记录时,自动分配一个唯一的整数值作为主键,每次插入新记录时,该自增长值会自动加1。 在MySQL中,可以将主键列定义为自增长列,可以使用关键字“AUTO_INCREMENT”来实现。 具体使用方法如下: 在创建表时,定义主键列并设置为自增长: CREATE TABLE 表名 ( i…

    MySQL 2023年3月9日
    00
  • Mysql怎么指定某个字符串字段前面几位排序查询

    今天小编给大家分享一下Mysql怎么指定某个字符串字段前面几位排序查询的相关知识点,内容详细,逻辑清晰,相信大部分人都还太了解这方面的知识,所以分享这篇文章给大家参考一下,希望大家阅读完这篇文章后有所收获,下面我们一起来了解一下吧。 指定某个字符串字段前面几位排序查询 数据样例 想要结果:  每个test_value 里面都包含 ORDER 关键字, 想根据…

    MySQL 2023年4月11日
    00
  • 关于mysql varchar类型的长度

    char 定长  最多255字符  末尾的空格会被默认删除 何时选用char类型储存? 1 数据长度近似 如手机号 身份证 MD5加密后的值 2 短字符串 相对varchar可以节约一个储存长度的空间 3 频繁更新的字段  相对于varchar不会产生长度变化也就不会产生存储碎片   varchar varchar类型与char类型不同 为变长字符串 在字符…

    MySQL 2023年4月13日
    00
  • Flask中Mysql数据库的常见操作

    from flask import Flask,render_template #导入第三方链接库sql点金术 from flask_sqlalchemy import SQLAlchemy #建立对象 app = Flask(__name__) #载入配置文件 app.config.from_pyfile(“config.ini”) #指定数据库连接还有库…

    MySQL 2023年4月16日
    00
  • Mac和Windows系统下Mysql数据库的导入导出

      最近在构建数据库的过程中,需要将Mac os系统下的Mysql数据库导出成.sql文件,然后导入到windows系统下的Mysql中。经过学习总结出的步骤如下:   一、Mac os导出Mysql数据库   1.打开终端,   2.执行: cd 要导出到的目录  (如:cd /Users/Malcolm/Desktop)   3.执行:mysqldump…

    MySQL 2023年4月13日
    00
  • Mysql中基本语句优化的十个原则小结

    MySQL是当前最流行的开源关系数据库管理系统之一,为了使数据库的性能更好,我们需要对MySQL中的基本语句进行优化。下面便是讲解MySQL中基本语句优化的十个原则小结。 原则1:使用WHERE子句限制数据行的数量 在数据库操作时,尽可能使用WHERE语句来筛选数据,以减小查询所返回的行数。这样可以更快地查询到需要的数据,提高查询的效率。 示例:查询用户表中…

    MySQL 2023年5月19日
    00
合作推广
合作推广
分享本页
返回顶部