0

psftpput大约有百分之一的时间失败,例如

本地:无法打开 d:\\WorkPath\\F_56MTV56201504201707224380.csv

  1. 调用应用程序需要对文件存在的目录路径和上传文件本身的权限
  2. 上传文件所在目录路径未锁定。见第 (1) 项
  3. 要上传的 csv 文件是在 C++ 中创建的,其中 fclose() 函数在关闭文件时不返回 EOF
  4. 目录上传路径已从防病毒软件中排除
  5. 100 次上传中有 99 次按预期工作
  6. 通过调用同一批次重新上传失败的上传文件可以正常工作
  7. 解决方案是多线程

在这一点上我唯一能看到的不同之处是使用带有本地文件名的 lcd 命令而不是使用完全限定的路径,但理论上,这不应该改变任何东西,或者我错过了什么?

示例批处理文件:

"D:\\Program Files\\ApplicationPath\\psftp.exe" ^
    1.2.3.4 -l username -pw password -batch -bc ^
    -b "d:\\\\WorkPath\\\\\EXMSP35201504210946233890.script" ^ 
    > "d:\\\\WorkPath\\\\\EXMSP35201504210946233890.script.log" 2>&1

示例脚本文件:

put d:\\\\WorkPath\\\\EXMSP35201504210946233890.csv
bye

D:看起来像连接到服务器的物理磁盘,但是,服务器 2008R2 位于 VMWare 虚拟平台上。

4

1 回答 1

0

使用一些WinAPI 记录器找出底层CreateFileWinAPI 函数调用失败的原因。


或者使用具有更详细错误消息的不同 SFTP 客户端。

例如,等效的WinSCP 脚本是:

winscp.com /command ^
    "option echo on" ^
    "open sftp://username:password@1.2.3.4/" ^
    "put d:\WorkPath\EXMSP35201504210946233890.csv" ^
    "exit" > d:\WorkPath\EXMSP35201504210946233890.script.log

使用 WinSCP,您会收到如下错误:

文件或文件夹 'd:\WorkPath\EXMSP35201504210946233890.csv' 不存在。
系统错误。代码:3。

该系统找不到指定的路径。

请参阅WinSCP 脚本简介

(我是WinSCP的作者)


您不应该在路径中使用双反斜杠。尽管 Windows 可以容忍这一点。

于 2015-04-22T05:38:09.523 回答