Linux平台卸载MySQL总结

本文详细介绍了在Linux系统中如何卸载MySQL数据库。包括针对RPM包安装和二进制包/源码安装的不同卸载步骤。从停止服务到删除相关文件夹,确保MySQL被完全卸载。

 如何在Linux下卸载MySQL数据库呢? 下面总结、整理了一下Linux平台下卸载MySQL的方法。 MySQL的安装主要有三种方式:二进制包安装(Using Generic Binaries)、RPM包安装、源码安装。对应不同的安装方式,卸载的步骤有些不同。文章中如有不足或不对的地方,敬请指出或补充!

 

RPM包安装方式的MySQL卸载

 

1: 检查是否安装了MySQL组件。

[root@DB-Server init.d]# rpm -qa | grep -i mysql
 
MySQL-devel-5.6.23-1.linux_glibc2.5
 
MySQL-client-5.6.23-1.linux_glibc2.5
 
MySQL-server-5.6.23-1.linux_glibc2.5
 

clip_image001

如上所示,说明安装了MySQL 5.6.23这个版本的client、server、devel三个组件。

 

2: 卸载前关闭MySQL服务

 

2.1 方法1

[root@DB-Server init.d]# service mysql status
MySQL running (25673)[  OK  ]
[root@DB-Server init.d]# service mysql stop
Shutting down MySQL..[  OK  ]
[root@DB-Server init.d]# service mysql status
MySQL is not running[FAILED]

clip_image002

 

2.2 方法2

[root@DB-Server init.d]# ./mysql status
MySQL running (26215)[  OK  ]
[root@DB-Server init.d]# ./mysql stop
Shutting down MySQL..[  OK  ]
[root@DB-Server init.d]# ./mysql status
MySQL is not running[FAILED]
[root@DB-Server init.d]#

clip_image003

[root@DB-Server init.d]# chkconfig --list | grep -i mysql
 
mysql 0:off 1:off 2:on 3:on 4:on 5:on 6:off
 
[root@DB-Server init.d]#
 

 

3. 收集MySQL对应的文件夹信息

[root@DB-Server init.d]# whereis mysql

mysql: /usr/bin/mysql /usr/include/mysql /usr/share/mysql /usr/share/man/man1/mysql.1.gz

最好实用find命令查看MySQL数据库相关的文件,方便后面彻底删除MySQL。

[root@DB-Server init.d]# find / -name mysql
/etc/rc.d/init.d/mysql
/etc/logrotate.d/mysql
/var/lock/subsys/mysql
/var/lib/mysql
/var/lib/mysql/mysql
/usr/include/mysql
/usr/include/mysql/mysql
/usr/bin/mysql
/usr/share/mysql
/usr/lib64/mysql

clip_image004

 

4: 卸载删除MySQL各类组件

[root@DB-Server init.d]#
[root@DB-Server init.d]# rpm -ev MySQL-devel-5.6.23-1.linux_glibc2.5
[root@DB-Server init.d]# rpm -ev MySQL-server-5.6.23-1.linux_glibc2.5
You have new mail in /var/spool/mail/root
[root@DB-Server init.d]# rpm -ev MySQL-client-5.6.23-1.linux_glibc2.5
[root@DB-Server init.d]#

clip_image005

 

5:删除MySQL对应的文件夹

 

检查各个MySQL文件夹是否清理删除干净。

[root@DB-Server init.d]# whereis mysql
mysql:
[root@DB-Server init.d]# find / -name mysql
/var/lib/mysql
/var/lib/mysql/mysql
/usr/lib64/mysql
[root@DB-Server init.d]# rm -rf /var/lib/mysql
[root@DB-Server init.d]# rm -rf /var/lib/mysql/mysql
[root@DB-Server init.d]# rm -rf /usr/lib64/mysql
[root@DB-Server init.d]#

6:删除mysql用户及用户组

如果有必要,删除mysql用户以及mysql用户组。

[root@DB-Server ~]# more /etc/passwd | grep mysql
mysql:x:101:501::/home/mysql:/bin/bash
[root@DB-Server ~]# more /etc/shadow | grep mysql
mysql:!!:16496::::::
[root@DB-Server ~]# more /etc/group | grep mysql
mysql:x:501:
[root@DB-Server ~]# userdel mysql
[root@DB-Server ~]# groupdel mysql
groupdel: group mysql does not exist
[root@DB-Server ~]#

 

7:确认MySQL是否卸载删除

[root@DB-Server init.d]# rpm -qa | grep -i mysql

 

二进制包/源码安装方式的MySQL卸载

如果是采用二进制包安装的MySQL,那么你用下面命令是找不到任何MySQL组件的。所以如果你不知道MySQL的安装方式,千万不要用下面命令来判别是否安装了MySQL

[root@DB-Server init.d]# rpm -qa | grep -i mysql

 

1: 检查MySQL服务并关闭服务进程

 

首先通过进程查看是否有MySQL的服务的状态, 如下所示,MySQL服务是启动的。

[root@DB-Server init.d]# ps -ef | grep mysql
root      4752  4302  0 22:55 pts/1    00:00:00 more /etc/init.d/mysql.server
root      7176     1  0 23:23 pts/1    00:00:00 /bin/sh /usr/local/mysql/bin/mysqld_safe --datadir=/usr/local/mysql/data --pid-file=/usr/local/mysql/data/DB-Server.localdomain.pid
mysql     7269  7176 15 23:23 pts/1    00:00:01 /usr/local/mysql/bin/mysqld --basedir=/usr/local/mysql --datadir=/usr/local/mysql/data --plugin-dir=/usr/local/mysql/lib/plugin --user=mysql --log-error=/usr/local/mysql/data/DB-Server.localdomain.err --pid-file=/usr/local/mysql/data/DB-Server.localdomain.pid
root      7321  4302  0 23:23 pts/1    00:00:00 grep mysql
[root@DB-Server init.d]# /etc/init.d/mysql.server status
MySQL running (7269)[  OK  ]
[root@DB-Server init.d]# /etc/init.d/mysql.server stop
Shutting down MySQL..[  OK  ]
[root@DB-Server init.d]# /etc/init.d/mysql.server status
MySQL is not running[FAILED]
[root@DB-Server init.d]#

clip_image006

 

2: 查找MySQL的安装目录并彻底删除

[root@DB-Server init.d]# whereis mysql
 
mysql: /usr/local/mysql
 
[root@DB-Server init.d]# find / -name mysql
 
/var/spool/mail/mysql
 
/usr/local/mysql-5.7.5-m15-linux-glibc2.5-x86_64/include/mysql
 
/usr/local/mysql-5.7.5-m15-linux-glibc2.5-x86_64/bin/mysql
 
/usr/local/mysql-5.7.5-m15-linux-glibc2.5-x86_64/data/mysql
 
/usr/local/mysql
 

clip_image007

[root@DB-Server init.d]# rm -rf /usr/local/mysql-5.7.5-m15-linux-glibc2.5-x86_64/
 
[root@DB-Server init.d]# rm -rf /usr/local/
 
[root@DB-Server init.d]# rm -rf /var/spool/mail/mysql
 
[root@DB-Server init.d]#
 

 

3: 删除一些配置文件

配置文件一般有/etc/my.cnf 或/etc/init.d/mysql.server,视具体安装配置情况而定。

 

4:删除MySQL用户以及用户组

[root@DB-Server ~]# id mysql
 
uid=101(mysql) gid=501(mysql) groups=501(mysql) context=root:system_r:unconfined_t:SystemLow-SystemHigh
 
[root@DB-Server ~]# userdel mysql
 

 

参考资料

http://blog.itblood.com/completely-uninstall-the-mysql-under-linux-graphic-tutorials.html

转载于:https://my.oschina.net/magicm/blog/1504610

### 如何在Linux 9系统上完全卸载MySQL 要在Linux 9(假设为CentOS 9或其他基于RHEL的发行版)上完全卸载MySQL,可以按照以下方法操作。以下是具体的操作流程: #### 卸载MySQL软件包 首先,移除所有与MySQL相关的软件包及其依赖项。可以通过以下命令完成此过程: ```bash sudo dnf remove mysql-server mysql-client mysql-common ``` 这一步会卸载核心组件,包括`mysql-server`、`mysql-client`以及通用库文件[^1]。 接着清理残留的依赖关系和缓存数据: ```bash sudo dnf autoremove sudo dnf clean all ``` #### 删除MySQL的相关文件和目录 为了确保没有任何遗留配置或数据影响新安装,需手动删除可能存在的MySQL相关路径。通常这些位置包括但不限于以下几个地方: - 数据存储目录 `/var/lib/mysql/` - 配置文件所在目录 `/etc/my.cnf` 或者整个 `/etc/mysql/` - 日志记录区域 `/var/log/mysqld.log` 执行如下指令逐一清除它们: ```bash sudo rm -rf /var/lib/mysql/ sudo rm -rf /etc/my.cnf sudo rm -rf /etc/mysql/ sudo rm -f /var/log/mysqld.log ``` 注意:务必小心处理删除动作,确认无误后再继续以免误删重要资料[^2]。 #### 清理剩余痕迹 最后再次扫描全盘寻找任何名称匹配“mysql”的条目,并酌情决定是否保留还是销毁掉那些项目。利用 `find` 命令可以帮助定位隐藏角落里的蛛丝马迹: ```bash sudo find / -name 'mysql*' -exec ls -l {} \; ``` 对于找到的结果列表中的每一项都仔细甄别其用途之后再做最终处置措施。 --- 通过上述步骤即可达成在Linux 9环境下彻底抹去原有MySQL部署的目标。当然实际场景下还可能存在其他定制化情况需要额外考虑进去才行。 ```python print("MySQL has been successfully uninstalled.") ```
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值