在线时间:8:00-16:00
迪恩网络APP
随时随地掌握行业动态
扫描二维码
关注迪恩网络微信公众号
第一步:下载vsftpd的RPM包 你可以从下面两个地方获得最新的vsftpd的RPM包 Redhat's rpm collection 或者 rpmfind.net.为了你的方便, 你也可以使用wget从本站下载vsftpd的rpm包到你的本地电脑. 复制代码 代码如下:wget http://www.vsftpdrocks.org/vsftpd-1.1.3-8.i386.rpm 一但有了vsftpd的RPM包,你就可以安装它 第二步:启动并在"standalone"模式下进行测试 复制代码 代码如下:vi /etc/vsftpd/vsftpd.conf 添加下面一行, 或者查看文件确定存在下面一行: 复制代码 代码如下:listen=YES 保存并退出. 复制代码 代码如下:/usr/sbin/vsftpd & 现在来用ftp命令至你的服务器. 你可以看到如下面这下样的成功登陆后的会话信息: 复制代码 代码如下:[root@somehost]ftp localhost Connected to localhost.localdomain. 220 (vsFTPd 1.2.1) Name (localhost:admin): bobsmith (很明显,你必须使用在你的服务器上的有效用户) 331 Please specify the password. Password: 230 Login successful. Remote system type is UNIX. Using binary mode to transfer files. ftp> ls 150 Here comes the directory listing. -rw-r--r-- 1 1001 1001 25372 Jan 17 18:50 somefile.tar.gz drwx------ 2 1001 1001 512 Jan 16 19:16 index.htm 226 Directory send OK. ftp> quit 221 Goodbye. [root@somehost] 如果你准备就绪的话,就可以看到类似于上面的返回信息 ! 如果你想让你的FTP服务器运行在 inetd或xinetd上, 那么你就需要继续进行下面的测试. 我个人推荐将FTP服务器运行在 inetd或xinetd上. 第三步:为inetd/xinetd操作进行配置 要在inetd或xinetd配置vsftpd,要进行下面的操作: 首先,来编辑/etc/vsftpd.conf,并告诉它vsftpd没有运行在"standalone"模式: 复制代码 代码如下:vi /etc/vsftpd/vsftpd.conf 确认下行的存在并将其设置为 "NO": 复制代码 代码如下:listen=NO 如果你在运行inetd,进行下面的操作: 复制代码 代码如下:vi /etc/inetd.conf 如果文件有包含任何“ftp"行的存在, 请注释或删除掉它们,并添加入下面一行: 复制代码 代码如下:ftp stream tcp nowait root /usr/local/sbin/vsftpd vsftpd 保存并退出. 现在重启inetd: 复制代码 代码如下:/etc/rc.d/init.d/inetd restart 如果你的xinetd正在运行,进行下面的操作: Redhat用户: 复制代码 代码如下:vi /etc/xinetd.d/vsftpd # default: off # description: The vsftpd FTP server serves FTP connections. It uses \ # normal, unencrypted usernames and passwords for authentication. service ftp { disable = no socket_type = stream wait = no user = root server = /usr/sbin/vsftpd nice = 10 } 保存并退出. 现在停止并重启xinetd... 复制代码 代码如下:/etc/rc.d/init.d/xinetd restart 现在来测试inetd/xinetd ftp服务器: 复制代码 代码如下:[root@somehost]ftp localhost Connected to localhost.localdomain. 220 (vsFTPd 1.2.1) Name (localhost:admin): bobsmith (很明显,你必须使用在你的服务器上的有效用户) 331 Please specify the password. Password: 230 Login successful. Remote system type is UNIX. Using binary mode to transfer files. ftp> ls 150 Here comes the directory listing. -rw-r--r-- 1 1001 1001 25372 Jan 17 18:50 somefile.tar.gz drwx------ 2 1001 1001 512 Jan 16 19:16 index.htm 226 Directory send OK. ftp> quit 221 Goodbye. [root@somehost] 如果你准备就绪的话,就可以看到类似于上面的返回信息 ! 恭喜,你的FTP服务器已经正常运行! 在接下来的步骤, 我们将调整vsftpd的配置让其拥有最好的性能. 第四步:vsftpd主配置文件 vsftpd主要配置应该是在:/etc/vsftpd.conf. 这个文件将决定如何对你的vsftpd FTP服务器进行操作. 你必须在vsftpd.conf中查找是否包含下面的配置选项。我虽然不能讲诉所有的选面,但是列表中列出来了vsftpd配置的重要部分 : anonymous_enable=NO/YES 这个开关用于开启FTP的匿名访问. 如果将该选项打开,那么请按照第三步的方法进行匿名匿名服务的配置. 如果你不清楚什么是匿名FTP服务,最好把该选项选项设置为“ON” local_enable=NO/YES 启用或禁用这个选项,可以使本地系统用户FTP至你的服务器. 典型的FTP服务器会将其设置为"YES". 我认为只有一种可以选"NO", write_enable=NO/YES local_umask=022 (或者根据你的需要设置) xferlog_enable=YES ftpd_banner=Welcome to blah FTP service chroot_list_enable=NO/YES userlist_enable=NO/YES 第五步: vsftpd.ftpusers, vsftpd.user_list 配置文件 这两个文件直接与/etc/vsftpd.conf配置文件中的""userlist_enable" 和"userlist_deny"选项关联.当"userlist_enable"选项设置为 "YES"时, 这两个文件列表中的用户将允许访问FTP服务器. 不管怎样, 当额外加上"userlist_deny=YES"选项时,这两个文件列表中的用户将不允许访问FTP服务器. 当"userlist_deny"选项被使用时,决定一个有户是否被FTP服务拒绝,主要取决于它存在于上述两个文件中的其中的哪一个. 如果一个用户同时存在于"vsftpd.user_list"与"userlist_deny",当用户试图连接FTP服务器时,它们在开始请求FTP连接时 得不到密码提示并会被拒绝. 如果一个用户同时存在于"vsftpd.user_list"与"userlist_deny", 用户必须登陆后更改这一密码提示. 就个人而言, 我更喜欢使用 "vsftpd.user_list"来建立用户列表(root, apache, www, nobody等等.) 如果有谁从未见到密码提示,那么他应该进行FTP的初始化连接. 第六步: vsftpd.chroot_list 配置文件 "vsfrtpd.chroot_list", 当启用"chroot_list_enable"选项时, 为FTP建立的用户列表文件,不管是谁,都必须被 "chrooted"至主FTP目录. 那些用户不能改变路径到其它用户目录.在保密性较强的公共FTP环境中,这是一个非常不错的功能. 就这么简单. 这里还有其它很多选项,可以根据你的 |
请发表评论