centos8中的MySQL卸载和安装

前言

前几天在自己的服务器上安装了一个NDB集群【而且还没有成功】

放弃治疗后用一台没有mysql的服务器实现了单机版本的集群。

本来以为这事到这就结束了,结果意外发现自己服务器上的MySQL被玩坏了……

本着修一修还能用的思想怒砸一个下午去修复,结果只发现了自己菜,没有发现mysql故障怎么解决……

所以就卸载重来吧……

卸载

mysql卸载主要分为三步:

  1. 卸载已安装的mysql程序;
  2. 删除相关的文件夹;
  3. 删除my.cnf文件。
卸载已安装的程序
# 查看已安装的mysql程序
shell> rpm -qa | grep -i mysql
mysql-errmsg-8.0.21-1.module_el8.2.0+493+63b41e36.x86_64
mysql-8.0.21-1.module_el8.2.0+493+63b41e36.x86_64
mysql-common-8.0.21-1.module_el8.2.0+493+63b41e36.x86_64
mysql-server-8.0.21-1.module_el8.2.0+493+63b41e36.x86_64 # 按照查询结果一一删除,可能会有顺序要求,因为部分文件存在依赖关系
shell> rpm -ev mysql-server-8.0.21-1.module_el8.2.0+493+63b41e36.x86_64
shell> rpm -ev mysql-errmsg-8.0.21-1.module_el8.2.0+493+63b41e36.x86_64
shell> rpm -ev mysql-8.0.21-1.module_el8.2.0+493+63b41e36.x86_64
shell> rpm -ev mysql-common-8.0.21-1.module_el8.2.0+493+63b41e36.x86_64 # rpm -qa | grep -i mariadb(删除centos默认系统自带的)
shell> rpm -qa | grep -i mariadb
shell> rpm -ev mariadb-connector-c-config-3.0.7-1.el8.noarch
删除相关的文件夹
# 查看对应的MySQL目录
find / -name mysql
# 结果:
/var/lib/docker/volumes/wp_db_data/_data/mysql
/var/lib/docker/volumes/94f2988e2ff63103c8c14f2bd69df6a4579e16bc2e5fd364b366878cd1e2fdc3/_data/mysql
... ... # 删除对应目录文件[和docker有关的不删,那是另外的东西]:
rm -rf /var/log/mysql
rm -rf /usr/share/selinux/packages/mysql
rm -rf /lanblue/conf/mysql
... ...
删除配置文件
# 最后删除配置文件
shell> rm -rf /etc/my.cnf

安装

这应该是我第三次在服务器上安装mysql,但是完全不记得之前怎么装的了,只记得简单【我明明觉得自己记过笔记的】。

网上找了一百个教程都没有看到特别喜欢的,尝试yum安装但是有点问题,最后还是在官网上下的包。

因为没有my.cnf,决定去官网说明文档里找一个。

等一等……

既然我都去官网了,为什么我不按照官网的教程来,明明学NDB集群的时候就是这样做的呀,果然还是吃了有经验的亏啊……

于是按照官网安装。

还是踩坑了,有配置需求的时候要看完官网教程,不要边看边学QAQ

下载
# 在某个目录下下载包
shell> wget https://dev.mysql.com/get/Downloads/MySQL-8.0/mysql-8.0.22-linux-glibc2.12-x86_64.tar.xz
# 解压
shell> tar Jxvf mysql-8.0.22-linux-glibc2.12-x86_64.tar.xz
# 移动和重命名
# 这两步不是记得太清楚了,最后结果就是把安装目录改名为mysql8,并放在/usr/local目录下。
# 大家可以放在自己喜欢的目录下
shell> mv ./mysql-8.0.22-linux-glibc2.12-x86_64 /usr/local
shell> cd /usr/local
shell>mv ./mysql-8.0.22-linux-glibc2.12-x86_64 mysql8
授权和配置
# 创建用户和用户组,有就不用管
shell> groupadd mysql
shell> useradd -r -g mysql -s /bin/false mysql # 转到安装目录下
shell> /usr/local/mysql8
shell> mkdir mysql-files
shell> chown mysql:mysql mysql-files
shell> chmod 750 mysql-files
# 可能是安全方面的想法
shell> bin/mysql_ssl_rsa_setup
# 可选的操作,我觉得可能是设置为开机启动
shell> cp support-files/mysql.server /etc/init.d/mysql.server # 不推荐!如果安装在官方推荐的目录下使用这句话没有问题,如果是自定义的目录不要用这句话
# shell> bin/mysqld --initialize --user=mysql
# 之后会出现问题 # 初始化
# 我使用的是这个语句,主要在于配置了basedir【安装目录】和datadir【存放数据的地方,里面要空】
# 初始化最后一行会出现临时密码,要复制粘贴待会用。
# 使用--initialize-insecure会默认没有密码,但是后续也要修改,所以我只示范本命令行中的方法
shell> bin/mysqld --initialize --user=mysql --basedir=/usr/local/mysql8 --datadir=/usr/local/mysql8/data
... ...
2020-12-22T06:12:26.872936Z 6 [Note] [MY-010454] [Server] A temporary password is generated for root@localhost: &dj*3sCai3Fw # 另一种方式 使用配置文件初始化
# 【在配置文件中设置目录】配置文件可以在网上找一找格式,需要自定义很多内容的小伙伴可以使用这种方式
# bin/mysqld --defaults-file=/path/to/your/config/my.cnf --initialize --user=mysql # 启动服务
# 跳转到bin目录
shell> ./mysqld_safe --user=mysql &
[1] 26248
... ...
2020-12-22T06:16:18.543780Z mysqld_safe Starting mysqld daemon with databases from /usr/local/mysql8/data # 已经有启动的进程了,但是查看状态会报错。应该是我没有设置服务名,不管他
shell> service mysqld status
Redirecting to /bin/systemctl status mysqld.service
● mysqld.service
Loaded: not-found (Reason: Unit mysqld.service not found.)
Active: failed (Result: exit-code) since Tue 2020-12-22 09:46:34 CST; 4h 37min ago
Main PID: 28825 (code=exited, status=1/FAILURE) # 尝试登陆一下
shell> mysql -u root -p
-bash: mysql: command not found # 默认找的是usr/local/bin,所以要做个软链接
ln -s /usr/local/mysql8/bin/mysql /usr/local/bin/mysql
# 之后就成功啦~记得使用之前看到的密码
shell> mysql -uroot -p
Enter password: # 修改密码
# 选择一个新密码来替换随机密码,否则无法执行任何操作
mysql> ALTER USER 'root'@'localhost' IDENTIFIED BY 'Myp@a$w*rd'; # 创建新用户并授权
mysql> CREATE USER 'blue'@'%' IDENTIFIED BY 'p@ssWor$';
mysql> GRANT ALL ON *.* TO 'blue'@'%'; # 远程登陆如果提示 client does not support authentication protocol requested by server
mysql> ALTER USER 'blue'@'%' IDENTIFIED WITH mysql_native_password BY 'p@ssWor$'; # 远程登陆如果提示 authentication plugin 'sha256_password' cannot be loaded
# 修改加密规则
mysql> ALTER USER 'blue'@'%' IDENTIFIED BY 'p@ssWor$' PASSWORD EXPIRE NEVER;
# 更新一下用户的密码
mysql> ALTER USER 'blue'@'%' IDENTIFIED WITH mysql_native_password BY 'p@ssWor$';
# 刷新权限
mysql> FLUSH PRIVILEGES;
# 这句也要执行
mysql> ALTER USER 'blue'@'%' IDENTIFIED BY 'p@ssWor$';

好啦,可以用啦~超开心。

centos8中的MySQL卸载和安装的更多相关文章

  1. linux mysql 卸载与安装及配置命令

    1.RPM包安装方式的MySQL卸载 1) 检查是否安装了MySQL组件. # rpm -qa | grep -i mysql 2)卸载前关闭MySQL服务 # service mysql statu ...

  2. linux mysql 卸载,安装,測试全过程

    Mysql卸载 yum remove mysql mysql-server mysql-libs compat-mysql51 rm -rf /var/lib/mysql rm /etc/my.cnf ...

  3. Linux_CentOS中的MySQL 数据库的安装调试、远程管理

    官网查看最新 MySQL 安装包 https://dev.mysql.com/downloads/repo/yum/ 下载 MySQL 源的安装包 wget http://dev.mysql.com/ ...

  4. Debian MySQL 卸载和安装 PHP安装

    如果是apt-get安装的 sudo apt-get --purge remove mysql-serversudo apt-get --purge remove mysql-clientsudo a ...

  5. CentOS7中Docker-ce的卸载和安装

    一.查看是否已安装了Docker软件包: #查看是否已经安装的Docker软件包sudo yum list installed | grep docker 二.如果已安装不想要的docker/dock ...

  6. 大数据之路week06--day07(Linux中的mysql的离线安装)

    这里我提供 服务端和客户端的两个jar包的百度云,也是我使用的 链接:https://pan.baidu.com/s/11a3LT-ENZ8n9IF19-VjmWA 提取码:bdls 离线安装Mysq ...

  7. mysql集群安装(centos)

    mysql cluster : 1. 基于NDB Cluster 的分布式数据库系统 2. mysql集群中各服务器节点不共享数据 3. 在mysql cluster中节点指的是进程,区别于其他的集群 ...

  8. 为WAMP中的mysql设置密码(默认为空)

    为WAMP中的mysql设置密码 WAMP安装好后,mysql密码是为空的,那么要如何修改呢?其实很简单,通过几条指令就行了,下面我就一步步来操作. 1.首先,通过WAMP打开mysql控制台. 提示 ...

  9. LinuxMint下JDK+Tomcat+Mysql+Eclipse javaEE安装

    网上查了很多方法,总结下比较简单的做法. 本人使用的系统版本为64位LinuxMint18,cinnamon桌面环境,预装Openjdk1.8.开发使用版本为oracle的1.7版本jdk. 1 jd ...

随机推荐

  1. react-hash-calendar,移动端日期时间选择插件

    按照惯例,先上效果图 vue 版本同款日历:https://github.com/TangSY/vue-hash-calendar react-hash-calendar 支持手势滑动操作 上下滑动 ...

  2. 牛客编程巅峰赛S2第4场

    牛客编程巅峰赛S2第4场 牛牛摆玩偶 题目描述 牛牛有\(n(2 \leq n \leq 10^5)(2≤n≤105)\)个玩偶,牛牛打算把这n个玩偶摆在桌子上,桌子的形状的长条形的,可以看做一维数轴 ...

  3. 变更mysql的数据类型兼容小数测试

    来吧 我也没想到有一天要做这个测试: 想分为这几步吧: 1.先看看mysql本身支不支持数据的变更 2.再看看mybatis能不能用int接受double和decimal 先看下mysql: alte ...

  4. CentOS硬软链接

    硬软链接说明 软链接: 1.软链接,以路径的形式存在.类似于Windows操作系统中的快捷方式 2.软链接可以 跨文件系统 ,硬链接不可以 3.软链接可以对一个不存在的文件名进行链接 4.软链接可以对 ...

  5. How tomcat works(深入剖析tomcat)阅读笔记1-4章

    How tomcat works chapter 1 简单的web服务器 这一张的主要内容就是实现一个简单的静态资源服务器,socket编程,利用java提供的socket和serverSocket编 ...

  6. 【SDOI2013】JZOJ8月3日提高组T4 直径

    题目 题目描述 小 Q 最近学习了一些图论知识.根据课本,有如下定义. 树:无回路且连通的无向图,每条边都有正整数的权值来表示其长度.如果一棵树有 N 个节点,可以证明其有且仅有 N-1 条边. 路径 ...

  7. 【C++】“反转链表”相关的题目

    1.反转链表:定义一个函数,输入一个链表的头节点,反转该链表并输出反转后链表的头节点. (1)这道题是经典的题目了,用迭代的方式解决也是很容易的,代码量也不大.分享一个我个人做题的方式,我会先在题目开 ...

  8. PyQt(Python+Qt)学习随笔:QTabWidget选项卡部件添加选项卡的addTab和insertTab方法

    老猿Python博文目录 专栏:使用PyQt开发图形界面Python应用 老猿Python博客地址 QTabWidget添加选项卡的方法可用使用addTab方法和insertTab方法. 1.增加选项 ...

  9. PyQt(Python+Qt)学习随笔:Qt Designer中部件的layoutDirection属性

    layoutDirection属性保存的是部件的布局方向,有三个取值: 在部件上设置布局方向时,它将传播到部件的子级,但不会传播到作为窗口的子级,也不会传播到已显式调用setLayoutDirecti ...

  10. flask-mail 机制

    上课无聊,总结下学习的flask-mail 机制 flask-mail 了解 flask-mail 机制中可以用pip 安装也可以用pycharm里面直接安装. flask-mail是一个能调用smt ...