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]
Hostio是一家成立于2006年的国外主机商,提供基于KVM架构的VPS主机,AMD EPYC CPU,NVMe硬盘,1-10Gbps带宽,最低月付5欧元起。商家采用自己的网络AS208258,宿主机采用2 x AMD Epyc 7452 32C/64T 2.3Ghz CPU,16*32GB内存,4个Samsung PM983 NVMe SSD,提供IPv4+IPv6。下面列出几款主机配置信息。...
tmhhost放出了2021年的端午佳节+618年中大促的优惠活动:日本软银、洛杉矶200G高防cn2 gia、洛杉矶三网cn2 gia、香港200M直连BGP、韩国cn2,全都是高端优化线路,所有这些VPS直接8折,部分已经做了季付8折然后再在此基础上继续8折(也就是6.4折)。 官方网站:https://www.tmhhost.com 香港BGP线路VPS ,200M带宽 200M带...
WebHorizon是一家去年成立的国外VPS主机商,印度注册,提供虚拟主机和VPS产品,其中VPS包括OpenVZ和KVM架构,有独立IP也有共享IP,数据中心包括美国、波兰、日本、新加坡等(共享IP主机可选机房更多)。目前商家对日本VPS提供一个8折优惠码,优惠后最低款OpenVZ套餐年付10.56美元起。OpenVZCPU:1core内存:256MB硬盘:5G NVMe流量:200GB/1G...