Red Ha t 7使用v s f t p d架设FTP服务器
RedHat7使用vsftpd架设FTP服务器
实验要求
采用vsftpd搭建一台ftp服务器( 192.168.17.128) 。
实验准备
默认实验环境
已经安装好RedHat6操作系统和Redhat7操作系统配置完网卡配置完库。 yum 这个实验其实跟Redhat6还是Redhat7没有关系。服务器端使用vsftpd,使用lftp Redhat6安装vsftpd 客户端# yum instal l vsftpd
Redhat7安装lftp
# yum instal l lftp
实验过程
Redhat6主机启动vsftpd服务
# service vsftpd start
在Redhat7上做测试
测试一、上传下载
在Rathat7主机上使用lftp连接FTP主机
# lftp 192.168.17.128lftp 192.168.17.128:~>cd pub
出现cd ok,cwd=/pub表示匿名用户连接成功。可以进入pub目录。
执行命令lftp 192.168.17.128:/pub>getfi le1
匿名用户可以下载,下载的文件可以在本地家目录下找到。lftp 192.168.17.128:/pub>put putfile put:Access fai led:550 Permission denied. (putfi le)说明匿名用户无法上传文件lftp 192.168.17.128:/pub>mkdirabc mkdir:Access fai led:550 Permission denied. (abc)说明匿名用户无法创建目录测试二、
开通匿名用户权限
权限有4部分防火墙 sel inux,目录权限 ftp匿名用户权限
这里只谈FTP,因此不讨论防火墙和sel inux。将这两个软件关闭。开通目录权限Vsft p d默认匿名用户在/va r/ft p/p u b下因此要将此目录给ot h e r用户加rwx权限。特别注意这里不能给/va r/ft p/直接加o+rwx权限如果加了将报500权限失败的错误。# chmod o+rwx-R/var/ftp/pub
开通FTP匿名用户权限
编辑文件/etc/vsftpd/vsftpd.conf
# vim/etc/vsftpd/vsftpd.conf
确保以下配置正确anonymous_enable=YES //12行允许匿名访问anon_upload_enable=YES//27行允许匿名上传anon_mkdir_write_enable=YES//31行允许匿名创建目录
重启服务器上FTP服务
# service vsftpd restart
客户端匿名用户访问
# lftp 192.168.17.128
Iftp 192.168.17.128:/>cd pub
上传文件成功
Iftp 192.168.17.128:/pub>putgetfi le
创建目录成功
Iftp 192.168.17.128:/pub>mkdirabc mkdir ok, 'abc'created
显示目录下内容lftp 192.168.17.128:/pub>ls drwx---- 214 50 4096 Nov0205:51 abc
-rw------ 1 14 50 0 Nov 0205:51 getfi le
-rw-r--rw- 1 0 0 0 Nov0205:41 putfile
刚刚创建的文件和目录都已成功lftp 192.168.17.128:/pub>rm abc rm:Access fai led:550 Permissio n deni ed. (abc)
删除目录失败lftp 192.168.17.128:/pub>rm putfile rm:Access fai led:550 Permissio n deni ed. (putfi le)lftp 192.168.17.128:/pub>rm getfile rm:Access fai led:550 Permissio n deni ed. (getfi le)
删除文件失败lftp 192.168.17.128:/>cd/lftp 192.168.17.128:/>ls drwxr-xrwx20 0 4096 Nov0205:41 pub
希望进入系统根目录访问失败。匿名用户只能在 /va r/ft p目录下游荡。测试三、使用l inux下客户访问
客户端使用lftp访问
登录用户
#lftp Jiane@192.168.17.128
Password:lftp Jiane@192.168.17.128:~>
下载文件成功lftp Jiane@192.168.17.128:~>getJia ne
6 bytes tran sferred
上传文件成功lftp Jiane@192.168.17.128:~>put putJiane
6 bytes transferred
创建目录成功lftp Jiane@192.168.17.128:~>mkdirabc mkdir ok, 'abc'created
显示如下说明创建目录和上传文件成功lftp Jiane@192.168.17.128:~>ls
-rw-rw-r-- 1 500 500 6 Nov0207:16Jiane drwxr-xr-x 2500 500 4096 Nov 0207:18 abc
-rw-r--r--
删除文件成功lftp Jiane@192.168.17.128:~>rm Jiane rm ok, 'Jiane' removed lftp Jiane@192.168.17.128:~>rm putJiane rm ok, 'putJiane' removed
删除目录成功lftp Jiane@192.168.17.128:~>rm-fr abc rm ok, 'abc' removed
显示没有文件lftp Jiane@192.168.17.128:~>ls
可以在任意目录里面游荡lftp Jiane@192.168.17.128:~>cd/tmp cd ok,cwd=/tmp lftp Jiane@192.168.17.128:/tmp>ls drwxrwxrwt 20 0 4096 Nov 01 01:26 VMwareDnD drwx----- 242 42 4096 Nov 0204:37 orbit-gdm drwx----- 20 0 4096 Nov 01 00:45 pulse-dKiUJVHwp5gi drwx----- 242 42 4096 Nov 0204:37 pulse-jMfmTL64uZ9d -rw-r--r-- 1 0 0 5278 Nov 0204:37 vgauthsvclog.txt.0drwx----- 20 0 4096 Nov 0204:37 vmware-root
根据实验得知 l inux用户登录FTP是进入用户的家目录并且可以在任何目录里面游荡。
匿名用户登录只能在/va r/ft p目录下并且只能在该目录中工作
默认情况下所有l inux的用户都可以在任何目录下游荡这个不安全。因此需要限制。确保只
有部分用户可以其他用户不可以。chroot_local_user=YES
chroot_l ist_enable=YES chroot_l ist_fi le=/etc/vsftpd/chroot_l ist
#cat /etc/vsftpd/chroot_l ist
Jiane
以上命令确保了系统里只有Jiane这个用户可以用ftp方式登录服务器并且在
里面任意游荡其他用户不行。
登录用户Jiane
#lftp Jiane@192.168.17.128
Password:
切换到其他目录成功lftp Jiane@192.168.17.128:~>cd/tmp cd ok,cwd=/tmp lftp Jiane@192.168.17.128:/tmp>ls drwxrwxrwt 20 0 4096 Nov 01 01:26 VMwareDnD drwx----- 242 42 4096 Nov 0204:37 orbit-gdm drwx----- 20 0 4096 Nov 01 00:45 pulse-dKiUJVHwp5gi drwx----- 242 42 4096 Nov 0204:37 pulse-jMfmTL64uZ9d
-rw-r--r-- 1 0 0 5278 Nov 0204:37 vgauthsvclog.txt.0drwx----- 20 0 4096 Nov 0204:37 vmware-root lftp Jiane@192.168.17.128:/tmp>exit
登录用户abc
#lftp abc@192.168.17.128
Password:lftp abc@192.168.17.128:~>ls
切换到其他目录失败lftp abc@192.168.17.128:/>cd/tmp cd:Access fai led:550 Fai led to change directory. (/tmp)显示其他目录内容失败lftp abc@192.168.17.128:/>ls/tmp
测试四、白名单和黑名单
设置可以访问FTP的白名单和黑名单
首先/etc/vsftpd/ftpusers为一个黑名单它不受任何配置影响总是有效。
而/etc/vsftpd/user_l ist与/etc/vsftpd/vsftpd.conf中的userl ist_enable和userl ist_deny
密切相关。它可以有效也可以无效可以是黑名单也可以是白名单。useri n在/etc/vsftpd/user_l ist里面userout不在/etc/vsftpd/user_l ist里面
1 . userl ist_enable表示该表启用与否 yes表示启用user_l ist文件 no表示不启用user_l ist文件。
2. Userl ist_deny是在userl ist_enable启用的状态下表示 user_l ist中的用户是被允许还是被拒绝。测试四、创建虚拟用户访问
创建宿主用户名
# useradd vftp-s/bin/false
该用于将被写入/etc/vsftpd/vsftpd.conf作为虚拟用户登录的宿主用户
创建虚拟用户
# vim/etc/vsftpd/vftpuser
# cat /etc/vsftpd/vftpuser che n1che n1che n2chen2
# db_load-T-t hash-f/etc/vsftpd/vftpuser/etc/vsftpd/vftpuser.db
/etc/vsftpd/vsftpuser.db将被写入/etc/pam.d/vsftpd作为用户登录的凭证
修改/etc/pam.d/vsftpd文件
# cat /etc/pam.d/vsftpd
#%PAM-1.0
#sessi on opti onal pam_keyi nit.so force revoke
#auth required pam」 istfi le.so item=user sen se=de ny fi le=/etc/vsftpd/ftpusers on err=succeed
#auth required pam_shel ls.so
#auth include password-auth
#account include password-auth#session required pam_loginuid.so#session include password-auth auth sufficient /l ib64/security/pam_userdb.so db=/etc/vsftpd/vftpuser account sufficient /l ib64/security/pam_userdb.so db=/etc/vsftpd/vftpuser
在/etc/pam.d/vsftpd里面配置登录用户认证方式
为每一个用户创建一个目录
#mkd ir -p/ftproot/chen{1 . .2}
# touch/ftproot/chen1/chen1
# touch/ftproot/chen2/chen2为每一个用户创建一个目录。
修改/etc/vsftpd/vsftpd.conf文件
#cat /etc/vsftpd/vsftpd.co nf|grep"八[八#]"anonymous_enable=NO //禁止匿名用户访问local_enable=YES
write_enable=YES
local_umask=022
dirmessage_enable=YES xferlog_enable=YES con n ect_from_port_20=YES xferlog_std_format=YES chroot_local_user=YES //禁止用户访问其他目录l isten=YES guest_enable=yes /启/用客户访问guest_username=vftp //客户放我采用vftp用户user_config_dir=/etc/vsftpd/vftp.conf//客户访问配置文件放在/etc/vsftpd/vftp.conf 文件夹下virtual_use_local_privs=yes //虚拟用户认证机制pam_service_name=vsftpd userl ist_enable=YES
tcp_wrappers=YES
创建每个用户的配置文件
#mkdir/etc/vsftpd/vftp.conf
#cat /etc/vsftpd/vftp.conf/chen 1 local_root=/ftproot/chen 1
#cat/etc/vsftpd/vftp.conf/chen2 local_root=/ftproot/chen2这些文件在启动服务的时候会被读入在客户登录的时候就会直接执行相应
用户名相对的脚本。
启动vsftpd服务
#service vsftpd start
Starting vsftpd for vsftpd: [OK]
Starting vsftpd for vftp.conf: :500 OOPS:cannot read config fi le: /etc/vsftpd/vftp.conf: [FAILED]Starting vsftpd for chen1:500 OOPS:cannot read config fi le:chen1
[FAILED]
Starting vsftpd for chen2:500 OOPS:cannot read config fi le:chen2[FAILED]
官方网站:点击访问青果云官方网站活动方案:—————————–活动规则—————————1、选购活动产品并下单(先不要支付)2、联系我司在线客服修改价格或领取赠送时间3、确认价格已按活动政策修改正确后,支付订单,到此产品开设成功4、本活动产品可以升级,升级所需费用按产品原价计算若发生退款,按资源实际使用情况折算为产品原价再退还剩余余额! 美国洛杉矶CN2_GIACPU内存系统盘流量宽带i...
DiyVM是一家比较低调的国人主机商,成立于2009年,提供VPS主机和独立服务器租用等产品,其中VPS基于XEN(HVM)架构,数据中心包括香港沙田、美国洛杉矶和日本大阪等,CN2或者直连线路,支持异地备份与自定义镜像,可提供内网IP。本月商家最高提供5折优惠码,优惠后香港沙田CN2线路VPS最低2GB内存套餐每月仅50元起。香港(CN2)VPSCPU:2cores内存:2GB硬盘:50GB/R...
企鹅小屋怎么样?企鹅小屋最近针对自己的美国cn2 gia套餐推出了2个优惠码:月付7折和年付6折,独享CPU,100%性能,三网回程CN2 GIA网络,100Mbps峰值带宽,用完优惠码1G内存套餐是年付240元,线路方面三网回程CN2 GIA。如果新购IP不能正常使用,请在开通时间60分钟内工单VPS技术部门更换正常IP;特价主机不支持退款。点击进入:企鹅小屋官网地址企鹅小屋优惠码:年付6折优惠...