分类: LINUX
2012-07-05 15:40:48
Linux下FTP服务器原理简介及简单应用
v 常见的FTP服务器程序
ü Win:IIS、Serv-U
ü Linux:wu-ftpd,Proftpd,vsftpd(Very Secure FTP Daemon)
v 常见的FTP客户端程序
ü ftp命令(cmd),浏览器
ü CuteFTP、FlashFXP、LeapFTP、Filezilla
ü gftp、kuftp
v FTP连接方式
ü 控制连接:标准端口为21,用于发送FTP命令信息
ü 数据连接:标准端口为20,用于上传、下载数据
v 数据连接的建立类型:
v FTP传输模式
ü 文本模式:ASCII模式,以文本序列传输数据
ü 二进制模式:Binary模式,以二进制序列传输数据
v FTP用户的类型
ü 匿名用户:anonymous或ftp
ü 本地用户:
ü 虚拟用户:
V常用的FTP指令
[root@ftp ~]# man 5 vsftpd.conf #参考手册
vsftpd服务基础
ü 官方站点:
ü 主程序:/usr/sbin/vsftpd
ü 服务名:vsftpd
ü 用户控制列表文件
ü 主配置文件
[root@ftp ~]# yum info vsftpd
[root@ftp ~]# yum install vsftpd -y
[root@ftp ~]# rpm -qc vsftpd
V常用的全局配置项
ü listen=YES:是否以独立运行的方式监听服务
ü listen_address=192.168.4.1:设置监听的IP地址
ü listen_port=21:设置监听FTP服务的端口号
ü write_enable=YES:是否启用写入权限
ü download_enable=YES:是否允许下载文件
ü userlist_enable=YES:是否启用user_list列表文件
ü userlist_deny=YES:是否禁用user_list中的用户
ü max_clients=0:限制并发客户端连接数
ü max_per_ip=0:限制同一IP地址的并发连接数
V常用的匿名FTP配置项
ü anonymous_enable=YES:启用匿名访问
ü anon_umask=022:匿名用户所上传文件的权限掩码
ü anon_root=/var/ftp:匿名用户的FTP根目录
ü anon_upload_enable=YES:允许上传文件
ü anon_mkdir_write_enable=YES:允许创建目录
ü anon_other_write_enable=YES:开放其他写入权
ü anon_max_rate=0:限制最大传输速率,单位为字节
V常用的本地用户FTP配置项
ü local_enable=YES:是否启用本地系统用户
ü local_umask=022:本地用户所上传文件的权限掩码
ü local_root=/var/ftp:设置本地用户的FTP根目录
ü chroot_local_user=YES:是否将用户禁锢在主目录
ü local_max_rate=0:限制最大传输速率(字节/秒)
[root@ftp ~]# man 5 vsftpd.conf #参考手册
vsftpd主要设置文件/etc/vsftpd/vsftpd.conf详解:
15 local_enable=YES #本地账户可以登录
18 write_enable=YES #本地账户可写权限
31 #anon_mkdir_write_enable=YES #匿名账户是否可以创建目录
35 dirmessage_enable=YES #启用目录说明功能
(切换到目录下,显示一些消息,在目录下创建.message文件)
83 #ftpd_banner=Welcome to blah FTP service. #欢迎条幅
96 chroot_list_file=/etc/vsftpd/chroot_list #此文件中的账户将不能切换家目录(必须结合chroot_list_enable=YES )
(chroot_list_enable=YES,chroot_local_user=YES,
107 listen=YES #监听功能打开
(设置pam的认证服务的配置文件名称,存入/etc/pam.d/目录下)
userlist_deny=NO #只允许user_list中账户访问
(/etc/vsftpd/user_list不让输密码,/etc/vsftpd/ftpusers允许输密码)
【说明:在/etc/vsftpd/user_list中 # If userlist_deny=NO, only allow users in this file# If userlist_deny=YES (default), never allow users in this file, and do not even prompt for a password.】
pasv_max_port #被动连接的最大端口
pasv_min_port #被动连接的最小端口
[root@ftp ~]# mount /dev/cdrom /mnt/cdrom/
[root@ftp Server]# rpm -ivh vsftpd-2.0.5-12.el5.i386.rpm
[root@ftp Server]# rpm -ivh db4-utils-4.3.29-9.fc6.i386.rpm
[root@ftp vsftpd]# db_load -T -t hash -f vuser.txt vuser.db
auth required pam_userdb.so db=/etc/vsftpd/vuser
account required pam_userdb.so db=/etc/vsftpd/vuser
[root@ftp pam.d]# useradd -d /home/virtual qq
客户端测试,使用虚拟账号zhangsan成功登录ftp。如下所示:
FTP 的服务器软件非常多,例如 Wu FTP, Proftpd, vsftpd 等等,各种 FTP 服务器软件的发展理念并不相同, 所以选择时请依照你的需求来决定所需要的软件;
FTP 使用的是明码传输,而过去一些 FTP 服务器软件也曾被发现安全漏洞,因此设定前请确定该软件已是最新版本,避免安全议题的衍生;
由于 FTP 是明码传输,其实可以使用 SSH 提供的 sftp 来取代 FTP ;
大多数的 FTP 服务器软件都提供 chroot 的功能,将实体用户限制在他的家目录内;
FTP 这个 daemon 所开启的正规埠口为 20 与 21 ,其中 21 为命令通道, 20 为主动联机的数据传输信道;
FTP 的数据传输方式主要分为主动与被动(Passive, PASV),如果是主动的话,则 ftp-data 在服务器端主动以 port 20 连接到客户端,否则需开放被动式监听的埠口等待客户端来连接;
在 NAT 主机内的客户端 FTP 软件联机时可能发生困扰,这可以透过 iptables 的 nat 模块或利用被动式联机来克服;
一般来说, FTP 上面共有三个群组,分别是实体用户、访客与匿名登录者(real, guest, anonymous);
可以藉由修改 /etc/passwd 里面的 Shell 字段,来让使用者仅能使用 FTP 而无法登入主机;
FTP 的指令、与用户活动所造成的登录档是放置在 /var/log/xferlog 里面;
FTP 在建立联机以及数据传输时,会建立哪些联机?
需建立两种联机,分别是命令信道与数据传输信道。在主动式联机上为 port 21(ftp)与 port 20(ftp-data)。
主动式联机的时候,命令联机是由 client 端主动连接到服务器端,但是 ftp-data 则是由服务器端主动的联机到 client 端。至于被动式联机的时候,则不论 command 还是 ftp-data 的联机,服务器端都是监听客户端的要求的!
有哪些动作可以让你的 FTP 主机更为安全 (secure) ?
o 随时更新服务器软件到最新版本;
o 让 guest 与 anonymous 的家目录限制在固定的目录中(chroot 或是 restricted);
o 拒绝大部分的 upload 行为!
我们知道 ftp 会启用两个 ports ,请问这两个 port 在哪里规范的 (以 vsftpd 为例)?而且,一般正规的 port 是几号?
若为 stand alone 时,都是由 vsftpd.conf 规范,命令通道为 listen_port=21 规范,数据连接为 connect_from_port_20=YES 及pasv_max_port=0, pasv_max_port=0 所规范。 若是 super daemon 所管理时,命令信道则由 /etc/services 所规范了。
那几个档案可以用来抵挡类似 root 这种系统账号的登入 FTP?
/etc/vsftpd/ftpusers /etc/vsftpd/user_list
在 FTP 的 server 与 client 端进行数据传输时,有哪两种模式?为何这两种模式影响数据的传输很重要?
数据的传输有 ASCII 与 Binary 两种方式,在进行 ascii 传送方式时,被传送的档案将会以文本模式来进行传送的行为, 因此,档案的属性会被修改过,可能造成执行档最后却无法执行等的问题!一般来说,ASCII 通常仅用在文本文件与一些原始码档案的传送。
我的主机明明时区设定没有问题,但为何登入 vsftpd 这个 FTP 服务时,时间就是少八小时?该如何解决?