既有适合小白学习的零基础资料,也有适合3年以上经验的小伙伴深入学习提升的进阶课程,涵盖了95%以上Go语言开发知识点,真正体系化!
由于文件比较多,这里只是将部分目录截图出来,全套包含大厂面经、学习笔记、源码讲义、实战项目、大纲路线、讲解视频,并且后续会持续更新
问题定位
经过一系列的调试和分析,问题的根源被定位为Go程序设置的上下文超时时间比Python脚本调用SSH命令的超时时间短。当Go程序的上下文超时后,它并未能正确回收SSH进程,导致SSH进程成为孤儿进程,继续占用系统资源。
Go程序上下文超时解析
在Go语言中,context
包提供了上下文管理的功能,它能够帮助我们设置超时时间、取消信号等。当使用 exec.CommandContext
方法执行子进程时,可以通过传递一个设置了超时的 context
对象,来控制子进程的执行时间。下面是一个简单的示例:
ctx, cancel := context.WithTimeout(context.Background(), time.Second\*2)
defer cancel()
cmd := exec.CommandContext(ctx, "python", "script.py")
err := cmd.Run()
if err != nil {
log.Fatal(err)
}
在上述代码中,我们为 exec.CommandContext
设置了2秒的超时时间。如果2秒内 script.py
没有执行完毕,Go程序会发送取消信号,尝试终止子进程。但是,这种取消信号可能无法传递到孙子进程(即Python脚本中启动的SSH进程),导致孙子进程继续运行。
解决方案
要解决这个问题,可以从以下几个方面着手:
- 调整超时时间:确保Go程序的上下文超时时间足够长,以覆盖Python脚本和SSH命令的执行时间。
- 资源清理:在Python脚本中,添加适当的资源清理逻辑,确保所有的子进程在任务完成后都被正确终止。
- 错误处理:在Go程序和Python脚本中,添加充分的错误处理逻辑,以便在出现问题时能够及时发现和处理。
import pexpect
import sys
def run\_ssh\_command():
try:
child = pexpect.spawn('ssh user@host')
child.expect('Password:')
child.sendline('password')
# ...
# 进行一些操作
# ...
finally:
child.close(force=True)
![img](https://img-blog.csdnimg.cn/img_convert/c88f899f79adfcf6a2c1e5fa1a7678a6.png)
![img](https://img-blog.csdnimg.cn/img_convert/c83d7d32afe9b6025f97eeeac991a8d4.png)
![img](https://img-blog.csdnimg.cn/img_convert/e87e6c3e5c2e906af6bfd857796869b7.png)
**既有适合小白学习的零基础资料,也有适合3年以上经验的小伙伴深入学习提升的进阶课程,涵盖了95%以上Go语言开发知识点,真正体系化!**
**由于文件比较多,这里只是将部分目录截图出来,全套包含大厂面经、学习笔记、源码讲义、实战项目、大纲路线、讲解视频,并且后续会持续更新**
**[如果你需要这些资料,可以戳这里获取](https://bbs.csdn.net/topics/618658159)**
且后续会持续更新**
**[如果你需要这些资料,可以戳这里获取](https://bbs.csdn.net/topics/618658159)**