这个是我同事的一个任务再上传日志的操作中出现了log file not found,
但是并不总是失败,偶尔成功
后来加了一段话
FTPClient.enterLocalPassiveMode();
问题解决;
这个方法的意思就是每次数据连接之前ftp client告诉ftp server开通 一个端口来传输数据。
原因是ftp每次开启不同的端口传输数据,linux上,安全限制,某些端口没有开启,出现阻塞
但是不理解他说的被动和主动方式的含义。
今天回来查资料知道:
FTP协议有两种工作方式,Port和Pasv方式,主动和被动式。
(1) PORT(主动模式)
工作的原理: FTP客户端连接到FTP服务器的21端口,发送用户名和密码登录,登录成功后要list列表或者读取数据时,客户端随机开放一个端口(1024以上),发送 PORT命令到FTP服务器,告诉服务器客户端采用主动模式并开放端口;FTP服务器收到PORT主动模式命令和端口号后,通过服务器的20端口和客户端开放的端口连接,发送数据
(2) PASV(被动模式) 这就是上面方法的作用。
工作的原理:FTP客户端连接到FTP服务器的21端口,发送用户名和密码登录,登录成功后要list列表或者读取数据时,发送PASV命令到FTP服务器, 服务器在本地随机开放一个端口(1024以上),然后把开放的端口告诉客户端, 客户端再连接到服务器开放的端口进行数据传输
下一次再请教他。
参考:
https://blog.csdn.net/huanggang028/article/details/41248663