借宝地一用
在FTP的时候出现下面的错误:500 OOPS: cannot change directory:/home/oracle。
解决方法是再终端输入:[root@yangtk vsftpd]# setsebool ftpd_disable_trans 1
[root@yangtk vsftpd]# service vsftpd restart
Shutting down vsftpd: [ OK ]
Starting vsftpd for vsftpd: [ OK ]
[root@yangtk vsftpd]# 重启服务后,用户可以正常的登陆。D:databaseoracle>ftp 172.25.4.127
Connected to 172.25.4.127.
220 (vsFTPd 2.0.5)
User (172.25.4.127:(none)): oracle
331 Please specify the password.
Password:
230 Login successful.如果希望这个设置在重启后仍然有效,可以使用setsebool –P ftpd_disable_trans 1。

解决方案 »

  1.   

    因为xinetd已经启动了vsftpd,而vsftpd设置成了stardalone模式,所以,先
    停止xinetd服务,  service xinetd stop ,然后 /usr/local/sbin/vsftpd &
    启动ftp服务 500 OOPS: vsftpd: refusing to run with writable anonymous root用chmod 775 /var/ftp,就可以登入了 比如您想让匿名用户上传和下载都在/var/ftp/pub,就可以把/var/ftp/pub的权限打开,如果没有这个目录,您要自己建一个; [root@localhost ~]# mkdir /var/ftp/pub
    [root@localhost ~]# chmod -R 777 /var/ftp/pub
     这表示ftp用户的家目录的权限不对,应该改过才对;
     
    [root@localhost ~]# more /etc/passwd |grep ftp
    ftp:x:1000:1000:FTP User:/var/ftp:/sbin/nologin我们发现ftp用户的家目录在/var/ftp,就是这个/var/ftp的权限不对所致,这个目录的权限是不能打开所有权限的;是您运行了chmod 777 /var/ftp所致;如果没有ftp用户这个家目录,当然您要自己建一个;
    如下FTP用户的家目录是不能针对所有用户、用户组、其它用户组完全开放;[root@localhost ~]# ls -ld /var/ftp
    drwxrwxrwx 3 root root 4096 2005-03-23 /var/ftp修正这个错误,应该用下面的办法;
     
    [root@localhost ~]# chown root:root /var/ftp
    [root@localhost ~]# chmod 755 /var/ftp有的弟兄可能会说,那匿名用户的可读、可下载、可上传怎么办呢?这也简单,在/var/ftp下再建一个目录,权限是777的就行了,再改一改vsftpd.conf就OK了;没有什么难的;
    vsFTPd出于安全考虑,是不准让ftp用户的家目录的权限是完全没有限制的
      

  2.   

    在 ftp client (FileZilla) 出現的錯誤訊息
    500 OOPS: cannot change directory:/home/*******
    500 OOPS: child died這是因為啟用firewall, SElinux, 在不停用fireall的情況下解決方式如下:登入root權限,在終端機輸入下列指令:setsebool ftpd_disable_trans on service vsftpd restart