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]
ucloud云服务器怎么样?ucloud为了扩大云服务器市场份额,给出了超低价云服务器的促销活动,活动仍然是此前的Ucloud全球大促活动页面。目前,ucloud国内云服务器2元/月起;香港云服务器4元/首月;台湾云服务器3元/首月。相当于2-4元就可以试用国内、中国香港、中国台湾这三个地域的云服务器1个月了。ucloud全球大促仅限新用户,国内云服务器个人用户低至56元/年起,香港云服务器也仅8...
DMIT.io是成立于2018年的一家国外主机商,提供VPS主机和独立服务器租用,数据中心包括中国香港、美国洛杉矶和日本等,其中日本VPS是新上的节点,基于KVM架构,国际线路,1Gbps带宽,同时提供月付循环8折优惠码,或者年付一次性5折优惠码,优惠后最低每月8.72美元或者首年65.4美元起,支持使用PayPal或者支付宝等付款方式。下面列出部分日本VPS主机配置信息,价格以月付为例。CPU:...
咖啡主机怎么样?咖啡主机是一家国人主机销售商,成立于2016年8月,之前云服务器网已经多次分享过他家的云服务器产品了,商家主要销售香港、洛杉矶等地的VPS产品,Cera机房 三网直连去程 回程CUVIP优化 本产品并非原生地区本土IP,线路方面都有CN2直连国内,机器比较稳定。咖啡主机目前推出美国洛杉矶弹性轻量云主机仅13元/月起,高防云20G防御仅18元/月;香港弹性云服务器,香港HKBN CN...