SUSE上vsftpd架设
OpenSUSE 自带了下列 FTP 服务器端程序,自行选择一个:* pure-ftpd
* vsftpd
* ftpd (包含在 krb5-apps-servers 软件包中)
vsftpd
特性
* 可以与 xinetd 结合使用
* 安全第一的设计原则
* 小,轻量级软件
安装
* 从 YAST/软件管理 搜索安装 vsftpd。(安装盘上有)
设置
vsftpd 有两种模式,独立模式和 xinetd 模式。
独 立模式需要你在开机后手动以 root 执行 vsftpd 命令启动 FTP 服务器,xinetd 模式则不一直运行FTP后台,只有有用户向你的 FTP 服务器发出 ftp 请求时立即启动 FTP 服务器后台程序。后者需要机器启动时打开 xinetd 服务,在 SUSE/SLED 系列是默认的设置。先确定你要选择哪种模式,然后进行之后的设置。
xinetd 模式
* 在 xinetd 中打开,可以手动编辑 /etc/xinetd.d/vsftpd 文件把 disabled yes 改成 disabled no,或者使用命令来实现
代码:
chkconfig vsftpd on
* 启动 xinetd (如果未运行)。代码:
/etc/init.d/xinetd start
* 确定 xinetd 在机器启动时运行代码:
chkconfig xinetd on
* root权限编辑文件 /etc/vsftpd.conf,确定 listenYES 前面加了 #。如果没有,加上保存。独立模式
* root权限编辑文件 /etc/vsftpd.conf,确定 listenYES 前面没有 #。如果有,去掉保存。
检查运行状况和防火墙设置
* 检查 FTP 服务器是否在正常运行,默认配置文件是允许匿名用户只读的,/srv/ftp/ 作为对外 FTP 的主目录。
* 如果必要,调整防火墙设置。如果是用默认的SuSEFirewall2,在 YaST-系统-/etc/sysconfig 编辑器,network-SuSEfirewall2 把 ftp 添加到 FW_SERVICES_EXT_TCP,比如你还要打开 ssh 那么
代码:
FW_SERVICES_EXT_TCP"ftp ssh"
* 如果你需要被动模式 FTP 和 nat,在 YaST-系统-/etc/sysconfig 编辑器,network-SuSEfirewall2代码:
FW_LOAD_MODULES"ip_conntrack_ftp ip_nat_ftp"
重启之后,vsftpd 将会按照你选择的模式运行。
简明配置
配置要修改文件 /etc/vsftpd.conf.
* 启用向服务器的写权限,去掉下面一行前面的#
代码:
write_enableYES
* 允许本地用户登录,去掉下面一行前面的#代码:
local_enableYES
* 默认,一个用户不能访问自己主目录之外的目录,要禁用去掉下面一行前面的#代码:
chroot_local_userNO
* 禁用匿名用户登录代码:
anonymous_enableNO
配置文件
* /etc/logrotate.d/vsftpd