Windows计划任务调度Python脚本写NFS远程目录异常
2021-06-23 12:05
标签:管理 pps 获取数据 操作系统 驱动器 取数据 getpath 启动 进程id 某项目场景,一台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月)的正常。 将计划任务调度方式换掉,编写一个bat脚本,放入开机自启动。说明:receive脚本负责从互联网获取数据,属于常驻内存,collect脚本负责将数据文件拷贝至NFS对应目录。内容如下: @echo off if "%aliveFlag%" == "0" ( Windows计划任务调度Python脚本写NFS远程目录异常 标签:管理 pps 获取数据 操作系统 驱动器 取数据 getpath 启动 进程id 原文地址:http://blog.51cto.com/qiqikeke/2177005问题定位与验证
到目前为止,还是未找到真正的问题,只能想其他的方式解决。
解决方法
::检测时间间隔,单位:秒
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=<.>tasklist /FI "pid eq %processID%" | find /C "python.exe">.\ImportantPID\xx_tmp.txt
::xx_tmp.txt 状态文件, 上面的筛选返回0或1
set /p aliveFlag=<.>echo %aliveFlag%
::del /F .\ImportantPID\xx_tmp.txt
start %_processCmd% | echo 启动 %_processName% 于 %time%
choice /D y /t %_processTimeout% > nul
)
goto LOOP
文章标题:Windows计划任务调度Python脚本写NFS远程目录异常
文章链接:http://soscw.com/essay/97782.html