欢迎光临
我们一直在努力

Windows计划任务调度Python脚本写NFS远程目录异常

问题描述

某项目场景,一台Windows服务器运行Python脚本从互联网采集数据,并将数据文件拷贝至内网的NFS。Python版本为2.7,Windows版本是2008 R2(6.1.7600.2.0.0.274.10)。Windows挂载远程NFS目录后(映射网络驱动器至本地Z盘),使用Windows资源管理器打开远程目录,拷贝文件等操作无问题。同时,单独在cmd下执行python xx_data_collect.py ,数据也能正常拷贝至远程目录。使用Windows计划任务5分钟一次调度xx_data_collect.py脚本,脚本已经调度,但数据无法拷贝,在执行os.path.exists(targetPath)的时候,抛出“Target file path: Z:\rfid\xx_data\目录不存在”的异常。此Windows运行5类数据采集脚本,脚本结构、功能一致,4类数据(频率5分钟)的计划任务调度无法识别NFS目录,1类数据(traffic,频率1月)的正常。

问题定位与验证

  1. 计划任务属性:检查计划任务属性,复制正常的1类数据(traffic)计划任务,修改调度的Python脚本,再次执行还是报目录不存在。
  2. NFS Client:检查注册表,未发现问题
  3. 计划任务调度BAT:尝试写一个bat,执行xx_data_collect.py,再由计划任务调度bat。bat内容加入 "NET USE z://192.168.1.x/data/PERSISTENT:YES"。再次执行还是报目录不存在。
  4. NFS目录的问题:将Target目录配置成操作系统本地目录,计划任务调度执行拷贝正常。将Target目录配置成其他的NFS目录,再次执行还是报目录不存在。
    到目前为止,还是未找到真正的问题,只能想其他的方式解决。

    解决方法

    将计划任务调度方式换掉,编写一个bat脚本,放入开机自启动。说明:receive脚本负责从互联网获取数据,属于常驻内存,collect脚本负责将数据文件拷贝至NFS对应目录。内容如下:

@echo off
::检测时间间隔,单位:秒
set _interval=300
set _processName="xx_data_receive"
::需要守护的进程启动命令
set _processCmd=python E:\apps\xx_data_collect.py
::需要守护的进程预估启动完毕所需时间,单位:秒
set _processTimeout=10
:LOOP
echo "xx_data_receive program keeper is working!!!!!!!"
echo %_processCmd%
::需要守护的进程ID, xx_data_receive程序启动会写入pid到文件
set /p processID=<.\ImportantPID\xx_pid.txt
tasklist /FI "pid eq %processID%" | find /C "python.exe">.\ImportantPID\xx_tmp.txt
::xx_tmp.txt 状态文件, 上面的筛选返回0或1
set /p aliveFlag=<.\ImportantPID\xx_tmp.txt
echo %aliveFlag%
::del /F .\ImportantPID\xx_tmp.txt

if "%aliveFlag%" == "0" (
start %_processCmd% | echo 启动 %_processName% 于 %time%
choice /D y /t %_processTimeout% > nul
)
goto LOOP

赞(0)
【声明】:本博客不参与任何交易,也非中介,仅记录个人感兴趣的主机测评结果和优惠活动,内容均不作直接、间接、法定、约定的保证。访问本博客请务必遵守有关互联网的相关法律、规定与规则。一旦您访问本博客,即表示您已经知晓并接受了此声明通告。