1.
FTP的安装
检查
rpm -q vsftpd
vsftpd -v
安装
yum -y install vsftpd ft
查看安装位置
[root@ftp ~]# whereis vsftpd
vsftpd: /usr/sbin/vsftpd /etc/vsftpd /usr/share/man/man8/vsftpd.8.gz
[root@ftp ~]# vsftpd -v
vsftpd: version 3.0.
关闭防火墙
systemctl disable firewalld.service
systemctl stop firewalld.service
firewall-cmd –permanent –zone=public –add-service=ftp
firewall-cmd –reload
关闭selinux
setenforce 0
sed -i ‘s#SELINUX=enforcing#SELINUX=disabled#’ /etc/selinux/config
getsebool -a | grep ftp
setsebool -P ftpd_full_access on
启动vsftp服务
[root@ftp ~]# systemctl start vsftpd
[root@ftp ~]# systemctl enable vsftpd
匿名用户登录
[root@ftp ~]# ftp localhost
Trying ::1…
Connected to localhost (::1).
220 (vsFTPd 3.0.2)
Name (localhost:root): ftp
331 Please specify the password.
Password:
230 Login successful.
Remote system type is UNIX.
Using binary mode to transfer files.
ftp> bye
421 Timeout.
配置文件解析
1# 不允许匿名访问,禁用匿名登录
2anonymous_enable=NO
3
4# 启用限定用户在其主目录下
5chroot_local_user=YES
6
7# 使用本地时(自行添加)
8use_localtime=YES
9
10# 允许使用本地帐户进行FTP用户登录验证
11local_enable=YES
12
13# 如果启用了限定用户在其主目录下需要添加这个配置,解决报错 500 OOPS: vsftpd: refusing to run with writable root inside chroot()
14allow_writeable_chroot=YES
15
16# 启用上传和下载的日志功能,默认开启
17xferlog_enable=YES
18
19# 设置本地用户默认文件掩码022
20local_umask=022
配置多用户
cat >>/etc/vsftpd/vsftpd.conf <
use_localtime=YES
listen_port=21
chroot_local_user=YES
idle_session_timeout=300
guest_enable=YES
guest_username=ftpuser
user_config_dir=/etc/vsftpd/vuser_conf
user_config_dir=/etc/vsftpd/vuser_conf
virtual_use_local_privs=NO
data_connection_timeout=1
pasv_min_port=10060
pasv_max_port=10090
accept_timeout=5
connect_timeout=1
EOF
创建宿主用户
创建用户 ftpuser并指定用户目录为 /home/vsftpd/
mkdir -p /home/vsftpd/
useradd -g root -M -d /home/vsftpd -s /sbin/nologin ftpuser
passwd ftpuser
chown -R ftpuser.root /home/vsftpd
useradd ftpuser -d /home/vsftpd -s /bin/false
chown ftpuser:ftpuser /home/vsftpd -R
chown www:www /home/www -R
建立虚拟用户文件
vim /etc/vsftpd/vuser_passwd
test
123456
生成虚拟用户数据文件
db_load -T -t hash -f /etc/vsftpd/vuser_passwd /etc/vsftpd/vuser_passwd.db
chmod -R 777 /etc/vsftpd/vuser_passwd.db
创建用户配置
mkdir /etc/vsftpd/vuser_conf
cd /etc/vsftpd/vuser_conf
vim test
local_root=/home/vsftpd/test # 用户 hss 配置目录
write_enable=YES # 允许本地用户对FTP服务器文件具有写权限
anon_world_readable_only=NO
anon_upload_enable=YES # 允许匿名用户上传文件(默认YES)
anon_mkdir_write_enable=YES # 允许匿名用户创建目录
anon_other_write_enable=YES # 允许匿名用户删除和重命名权限
创建用户目录
mkdir -p /home/vsftpd/test/upload
chmod -R 777 /home/vsftpd/test/upload
mkdir /var/ftp/upload
重启vsftpd服务器
systemctl restart vsftpd.servic
vsftpd中几种用户的区分
本地用户:
用户在FTP服务器拥有账号,且该账号为本地用户的账号,可以通过自己的账号和口令进行授权登录,登录目录为自己的home目录。
虚拟用户:
用户在FTP服务器上拥有账号,但该账号只能用于文件传输服务,登录目录为某一特定的目录,通常可以上传和下载 。
匿名用户:
用户在FTP服务器上没有账号,登录目录为/var/ftp。
FTP状态码
230 # 登录成功
200 # 命令执行成功
150 # 文件状态正常,开启数据连接端口
250 # 目录切换操作完成
226 # 关闭数据连接端口,请求的文件操作成功
FTP命令
ftp> ascii
ftp> bell
ftp> binary
ftp>bye
ftp>case
ftp>cd
ftp> cdup
ftp> chmod
ftp> close
ftp> delete
ftp> dir [remote-directory] [local-file]
ftp> get [remote-file] [local-file]
ftp> help [command]
ftp> lcd
ftp> ls [remote-directory] [local-file]
ftp> macdef
ftp> mdelete [remote-files]
ftp> mget [remote-files]
ftp> mkdir directory-name
ftp> mput local-files
ftp> open host [port]
ftp> prompt
ftp> put local-file [remote-file]
ftp>pwd
ftp> quit
ftp> recv remote-file [local-file]
ftp> rename [from] [to]
ftp> rmdir directory-name
ftp> send local-file [remote-file]
ftp> status
ftp> system
ftp> user user-name [password] [account]
ftp> ? [command]
ftp> !
ftp>bye
ftp>exit
ftp> quit
2
FTP上传脚本
if [ # -ne 2 ]
then
echo “Usage # -ne 2 ] then echo “Usage 0
IP=127.0.0.1
FULLNAME=$1
DESTDIR=$2
basename $FULLNAME
local_filename=basename $FULLNAME
DESTFILE= DESTDIR/ D E S T D I R / local_filename
ftp -i -n <
if [ # -ne 2 ]
then
echo “Usage # -ne 2 ] then echo “Usage 0
IP=127.0.0.1
FULLNAME=$1
DESTDIR=$2
remote_filename=basename $FULLNAME
DESTFILE= DESTDIR/ D E S T D I R / remote_filename
ftp -i -n <