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]
racknerd在促销美国洛杉矶multacom数据中心的一款大硬盘服务器,用来做存储、数据备份等是非常划算的,而且线路还是针对亚洲有特别优化处理的。双路e5+64G内存,配一个256G的SSD做系统盘,160T SAS做数据盘,200T流量每个月,1Gbps带宽,5个IPv4,这一切才389美元...洛杉矶大硬盘服务器CPU:2 * e5-2640v2内存:64G(可扩展至128G,+$64)硬...
传统农历新年将至,国人主机商DogYun(狗云)发来了虎年春节优惠活动,1月31日-2月6日活动期间使用优惠码新开动态云7折,经典云8折,新开独立服务器可立减100元/月;使用优惠码新开香港独立服务器优惠100元,并次月免费;活动期间单笔充值每满100元赠送10元,还可以参与幸运大转盘每日抽取5折码,流量,余额等奖品;商家限量推出一款年付特价套餐,共100台,每个用户限1台,香港VPS年付199元...
pacificrack官方在搞2021年七夕促销,两款便宜vps给的配置都是挺不错的,依旧是接入1Gbps带宽,KVM虚拟、纯SSD raid10阵列,支持包括Linux、Windows 7、10、server2003、2008、2012、2016、2019在内多种操作系统。本次促销的VPS请特别注意限制条件,见本文末尾!官方网站:https://pacificrack.com支持PayPal、支...