我编写了一个 python 脚本,它使用子进程调用 robocopy 来同步来自远程主机的日志文件。
像这样:
program = 'Robocopy'
options = ['/S']
args.append(program)
args.append(options)
args.append('\\\\%s\%s' % (hostname, source_path))
args.append(local_path)
proc = subprocess.Popen(args=args, shell=True, stdout=cmd_log, stderr=error_log)
其中 source_path 是远程主机上的路径,local_path 是本地主机上的路径(两个 UNC 路径)。代码通常在守护进程中运行,每隔几个小时就会启动一次。也可以直接在命令提示符下运行此代码。似乎有时当它在守护进程中运行时,我会从 Robocopy 收到错误消息:
错误代码 6:“句柄无效”
但是当我在命令提示符下运行它时,我没有收到任何错误。根据我在网络搜索中的发现,这可能与正在传输的文件上已经打开的文件句柄有关。有没有人有关于这个错误的更多信息以及避免它的方法?