如何快速查找进程PID?找不到怎么办

如何正确停止 nohup 启动的后台进程

理解 nohup 进程的特性

当使用 nohup command & 启动进程时:

  1. 忽略挂断信号:进程会忽略 SIGHUP 信号(终端关闭时发送)
  2. 脱离终端控制:即使关闭启动它的终端,进程仍继续运行
  3. 输出重定向:默认将输出保存到 nohup.out 文件

标准停止方法(推荐)

# 示例输出:
# user  12345  0.0  0.1  20250  1024 pts/0  S    Jul01  0:00 python app.py
# 2. 发送终止信号
kill -15 12345  # 发送SIGTERM信号(优雅终止)
# 3. 验证是否终止
ps -p 12345     # 无输出则表示已停止

进阶处理方案

场景1:进程未响应 SIGTERM

kill -9 12345   # 强制终止(SIGKILL信号)

⚠️ 注意:强制终止可能导致数据丢失,仅作为最后手段

场景2:批量终止同名进程

pkill -f "进程名关键词"      # 按名称终止
pkill -15 -f "python.*app"  # 优雅终止正则匹配的进程

场景3:通过端口查找终止

# 查找占用8080端口的进程
lsof -i :8080 | awk 'NR==2 {print $2}' | xargs kill -15

预防进程残留的技巧

  1. 使用进程管理工具(推荐):

    # 安装screen
    sudo apt install screen
    # 创建会话
    screen -S mysession
    # 启动进程后按 Ctrl+A+D 脱离会话
    # 恢复会话
    screen -r mysession
  2. 记录PID到文件

    nohup ./server.sh & echo $! > server.pid
    # 停止时执行
    kill -15 $(cat server.pid)

常见问题排查

Q:进程显示为僵尸(Z状态)?

  • 原因:父进程未回收子进程
  • 解决:重启父进程或重启系统

Q:nohup.out 文件持续增大?

  • 定期清理:
    cp /dev/null nohup.out  # 清空内容不删除文件

最佳实践建议

  1. 优先使用进程管理器:如 systemd/supervisor
  2. 避免直接使用 kill -9:可能导致资源未释放
  3. 日志分割:使用 logrotate 管理输出文件
  4. 权限最小化:不要用 root 运行 nohup 进程

技术原理说明
nohup 通过拦截 SIGHUP 信号实现进程持久化,但进程仍响应其他信号。SIGTERM(15)允许进程执行清理操作,而 SIGKILL(9)会立即终止进程且不可被捕获。


引用说明
本文方法基于 Linux 标准进程管理规范,参考 Linux man-pages 中关于 signal(7)、kill(1)、nohup(1) 的技术文档,并在 CentOS/Ubuntu 等主流发行版验证通过。

原创文章,发布者:酷番叔,转转请注明出处:https://cloud.kd.cn/ask/7632.html

(0)
酷番叔酷番叔
上一篇 2025年7月17日 07:13
下一篇 2025年7月17日 07:31

相关推荐

  • 为什么缩放不了?

    启动缩放命令可调整视图显示比例,不改变图形实际尺寸,常用鼠标滚轮、工具栏按钮或输入ZOOM指令操作,便于查看细节或全局。

    2025年8月8日
    11000
  • 怎么查看电脑系统cmd命令是什么意思

    电脑搜索框输入“cmd”回车打开命令提示符窗口,里面可输入各类系统

    2025年8月19日
    10300
  • 安全信息平台网站有何核心功能?

    在数字化时代,安全信息已成为个人、企业乃至国家发展的重要基石,安全信息平台网站作为整合、传播和管理安全信息的关键载体,其建设与运营对于提升社会整体安全意识、防范安全风险具有不可替代的作用,这类平台通过系统化收集权威安全资讯、提供专业安全知识、搭建互动交流社区,为不同需求的用户打造了一站式安全信息服务中心,安全信……

    2025年11月24日
    7600
  • 如何安全关闭MySQL服务?

    安全关闭MySQL是数据库管理中的重要操作,不当的关闭可能导致数据损坏、服务中断或性能问题,本文将详细介绍安全关闭MySQL的方法、注意事项及相关最佳实践,帮助管理员确保数据库的稳定性和数据完整性,安全关闭MySQL的重要性MySQL作为广泛使用的开源数据库,其正常运行依赖于正确的启动和关闭流程,直接通过系统命……

    2025年12月6日
    7800
  • mysql的命令行怎么创建表空间

    MySQL命令行中,使用CREATE TABLESPACE语句创建表空间,如:

    2025年8月17日
    11700

发表回复

您的邮箱地址不会被公开。 必填项已用 * 标注

联系我们

400-880-8834

在线咨询: QQ交谈

邮件:HI@E.KD.CN

关注微信