CentOS中如何搭建FTP服务器-创新互联

这篇文章主要讲解了“CentOS中如何搭建FTP服务器”,文中的讲解内容简单清晰,易于学习与理解,下面请大家跟着小编的思路慢慢深入,一起来研究和学习“CentOS中如何搭建FTP服务器”吧!

成都创新互联公司专注于企业全网整合营销推广、网站重做改版、澄迈网站定制设计、自适应品牌网站建设、HTML5建站商城系统网站开发、集团公司官网建设、成都外贸网站制作、高端网站制作、响应式网页设计等建站业务,价格优惠性价比高,为澄迈等各大城市提供网站开发制作服务。

1 基本环境


CentOS中如何搭建FTP服务器


2 ftp工作模式


2.1 ftp通道


ftp工作会启动两个通道:


控制通道,数据通道


在ftp协议中,控制连接均是由客户端发起的,而数据连接有两种模式:port模式(主动模式)和pasv(被动模式)


2.2 port模式


在客户端需要接收数据时,ftp_client(大于1024的随机端口)----port命令-----ftp_server(21)发送port命令,这个port命令包含了客户端是用什么端口来接收数据(大于1024的随机端口),在传送数据时,ftp_server将通过自己的tcp 20端口和port中包含的端口建立新的连接来传送数据。


2.3 pasv模式


传送数据时,ftp_client---pasv命令---ftp_server(21)发送pasv命令时,ftp_server自动打开一个1024--5000之间的随机端口并且通知ftp_client在这个端口上传送数据,然后客户端向指定的端口发出请求连接,建立一条数据链路进行数据传输。


3 安装vsftp


# rpm -qa vsftpd   #检查是否已安装
# yum -y install vsftpd
# chkconfig --level 35 vsftpd on   #设置开机自启动
# chkconfig --list|grep vsftpd    #检查开机是否是自动启动

4 ftp文件说明


# rpm -ql vsftpd
/etc/logrotate.d/vsftpd    #vsftpd的日志文件
/etc/pam.d/vsftpd      #pam认证文件
/etc/rc.d/init.d/vsftpd    #启动脚本
/etc/vsftpd         #vsftpd的配置文件存放目录
/etc/vsftpd/ftpusers     #禁止使用vsftpd的用户列表文件
/etc/vsftpd/user_list     #禁止或允许使用vsftpd的用户列表文件
/etc/vsftpd/vsftpd.conf    #ftp的主配置文件
/etc/vsftpd/vsftpd_conf_migrate.sh   #vsftpd操作的一些变量和设置
/var/ftp         #匿名用户目录
/var/ftp/pub       匿名用户的下载目录

5 配置ftp


5.1 vsftpd.conf文件参数说明


黄色部分为添加的,红色为修改的


anonymous_enable=no    #是否开启匿名登录
local_enable=yes       #是否允许本地用户登录
write_enable=yes       #是否允许上传
local_umask=022        #默认的umask码
dirmessage_enable=yes     #是否显示目录说明文件
xferlog_enable=yes       #是否记录ftp传输过程
connect_from_port_20=yes   #是否确定端口传输来自20
xferlog_std_format=yes     #是否使用标准的ftp xferlog模式
chroot_list_enable=yes      #是否将系统用户限制在自己的home目录下
chroot_list_file=/etc/vsftpd/chroot_list  #列表不受限制的用户
listen=yes            #是否开启监听
pam_service_name=vsftpd     #服务名称
userlist_enable=yes
tcp_wrappers=yes

5.2 关闭selinux


# setenforce 0
# sed -i 's#selinux=enforcing#selinux=disabled#g' /etc/selinux/config

6 创建虚拟用户


6.1 创建一个用户

创建用户后修改用户的shell为nologin,让用户不能登录系统,只能使用ftp之内的服务

# useradd -d /home/ftp/test -g ftp -s /sbin/nologin test
# echo 123456|passwd --stdin test #设置密码

6.2 将用户test添加到chroot_list中


# touch /etc/vsftpd/chroot_list 
# echo test >>/etc/vsftpd/chroot_list

6.3 启动vsftp服务


# /etc/init.d/vsftpd start

6.4 登陆ftp方式

6.4.1 文件夹登陆

在文件夹路径框输入: 按回车登陆                                      


6.4.2 浏览器登陆


浏览器里输入    输入用户名test和密码123456进行测试

6.4.3 cmd命令行登陆

打开windows cmd窗口输入:ftp 10.0.0.8 按回车输入用户名和密码登陆

6.4.4 第三方客户端登陆

比如xftp客户端登陆

7 其他参数说明

max_client=100       #vsftpd较大支持链接数100个ip
max_per=5         #每个ip能支持的5个链接
local_max_rate=81920     #限制传输速度
listen_address=ip       #绑定某个ip到vsftpd,只允许该ip访问
xferlog_file=/var/log/vsftpd.log  #日志存放位置

8 常见报错

8.1 报错1

[root@oldboyedu45-wang ~]# service vsftpd start

为 vsftpd 启动 vsftpd:500 oops: bad bool value in config file for: chroot_list_enable                                                           [失败]


此报错时由于chroot_list_enable后面有空格导致的

感谢各位的阅读,以上就是“CentOS中如何搭建FTP服务器”的内容了,经过本文的学习后,相信大家对CentOS中如何搭建FTP服务器这一问题有了更深刻的体会,具体使用情况还需要大家实践验证。这里是创新互联网站建设公司,,小编将为大家推送更多相关知识点的文章,欢迎关注!


网站标题:CentOS中如何搭建FTP服务器-创新互联
转载来于:http://ybzwz.com/article/ccshdd.html