在公司调试好了服务器,装的是redhat es3。其中vsftp启动,测试都没有问题。但是放到机房在机房测试还是好的,但是回到公司就连不上了。报错如下:
在本地连接正常的时候:
正在连接到 102
已连接到 192.168.0.102 端口 21
220 (vsFTPd 1.2.0)
USER ele
331 Please specify the password.
PASS (hidden)
230 Login successful.
SYST
215 UNIX Type: L8
REST 100
350 Restart position accepted (100).
REST 0
350 Restart position accepted (0).
PWD
257 "/home/ele"
TYPE A
200 Switching to ASCII mode.
PORT 192,168,0,11,4,55
200 PORT command successful. Consider using PASV.
LIST
150 Here comes the directory listing.
226 Directory send OK.
QUIT
221 Goodbye.
已退出: 102
到机房之后出错的时候:
正在连接到 167
已连接到 218.194.134.167 端口 21
220 (vsFTPd 1.2.0)
USER elephant
331 Please specify the password.
PASS (hidden)
230 Login successful.
SYST
215 UNIX Type: L8
REST 100
350 Restart position accepted (100).
REST 0
350 Restart position accepted (0).
PWD
257 "/home/elephant"
TYPE A
200 Switching to ASCII mode.
PORT 192,168,0,11,4,60
500 Illegal PORT command.
LIST
425 Use PORT or PASV first.
421 Timeout.
连接已丢失: 167
请问各位这是为什么,怎么解决?
主动模式ftp服务端不能连接你的端口。
用被动模式试试看吧。
你防火墙/路由器上要把你设置为被动模式的端口打开的,否则外面是无法访问到你的这些端口的
如果确认你的网关没有防火墙封了tcp的除主要端口外的其它端口,你就需要查看你的
vsftp设置了
pasv_enable=YES|NO
这个应该是YES 因为有人能连上
pasv_min_port=port number
pasv_max_port=port number
这个port number 应该不是0
请核对