mysql - 无法使用 "kill -9 <pid>"终止 mysql 进程

标签 mysql macos

我在 Macbook 上,在终端上我试图找到哪个应用占用了端口 3306。我运行命令:

sudo lsof -i TCP:3306 

我得到了输出:

COMMAND   PID   USER   FD   TYPE             DEVICE SIZE/OFF NODE NAME
mysqld  47730 _mysql   19u  IPv6 0x736b0ff006adfb97      0t0  TCP *:mysql (LISTEN)

然后,我通过 sudo kill -9 47730 终止进程。它执行没有错误。

但是,我再次运行 sudo lsof -i TCP:3306,我得到:

COMMAND   PID   USER   FD   TYPE             DEVICE SIZE/OFF NODE NAME
mysqld  47759 _mysql   19u  IPv6 0x736b0ff006ae0cd7      0t0  TCP *:mysql (LISTEN)

mysql 进程再次启动,但 PID 不同,为什么?如何永久终止 Macbook 上的 MySQL 进程?

(mysql 版本 8.0.11)

最佳答案

阅读https://dev.mysql.com/doc/refman/8.0/en/osx-installation-launchd.html

MacOS 上的 MySQL 服务器配置为启动守护进程,并启用了“KeepAlive”选项。这意味着如果它停止,例如当您使用 kill -9 时,MacOS 将自动重新启动它。

您应该使用系统偏好设置小部件(显示在我链接到的手册页上)或使用 launchctl 停止它。

如果您使用 brew 或其他方式安装了 MySQL 服务器,它可能不受 launchctl 管理。

例如,有些人使用supervisord 来运行MySQL Server,在这种情况下,您可以使用supervisorctl stop mysql 停止它。

当使用非 launchctl 方法运行 MySQL 服务器时,它可能正在运行 mysqld_safe ,这是一个脚本,如果它被杀死或崩溃,它会自动重新启动 mysqld。这就是你必须正确关闭 mysqld_safe 的原因。

当我在我的 Macbook 上运行 MySQL 服务器的测试实例时,我用 dbdeployer 启动它们,它会启动一个 mysqld_safe 进程。

MacOS 对于 MySQL Server 来说可能是一个令人困惑的环境,因为有多种方法可以获取和运行它,并且每种方法都有自己的管理过程的方式。

关于mysql - 无法使用 "kill -9 <pid>"终止 mysql 进程,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/54575020/

相关文章:

HTML 资源在 Debug模式下正确加载,而不是在 Release模式下正确加载

php - 网站功能受到干扰或被黑

Python 和 MySQL 不正确的字符串值

php - 如何在php mysql中制作排名系统?

macos - 如何知道特定的 launchd.plist 文件位置?

objective-c - HUD 面板中的 subview

objective-c - NSScrollView添加内容后不显示垂直滚动条

macos - 由于在 Big Sur 中的许可,无法运行应用程序

php - 使用 where、like 和 or_like CodeIgniter 3 Active Records 进行多重连接

java - 如何根据行数删除数据库表行