Centos7.1 for vsftpd配置

FTP: File Transfer Protocol 文件传输协议

FTP用户身份:

real user:实体帐号

通过帐号、密码进行登录,登录后的目录为自身的主目录,可以访问主目录以外的目录(通过chroot控制)

guest:访客

通过帐号、密码进行登录,登录后的目录为自身的主目录,不可以访问主目录以外的目录

anonymous:匿名帐号

不需要通过帐号、密码就可以登录,登录后的目录为指定的目录(通常为/var/ftp),且只能访问这一指定的目录

FTP传输方式:

ASCII传输:

可能在不同文件系统的传输中导致换行符改变

二进制传输:

只是单纯地根据字节复制文件,绝对不会改变换行符

FTP工作方式:

主动方式:

1.client选取一个随机端口X(>1023)与server的21端口通过三次握手建立连接,形成一个命令通道

2.client通过命令通道发送PORT命令到server,告知server可连接的数据端口Y(随机,大于1023且不等于X)

3.当需要进行数据传输时,server使用20端口与client的Y端口建立连接,形成数据通道

被动方式:

1.client选取一个随机端口X(>1023)与server的21端口通过三次握手建立连接,形成一个命令通道

2.当需要进行数据传输时,client通过命令通道发送PASV命令到server

3.server启动一个随机监听端口A(>1023),并通过命令通道告知client

4.client选取一个数据端口Y(随机,大于1023且不等于X)去连接server监听端口A,形成数据通道

SFTP:

由于传统FTP的明文传输已被抓包窃取,不能保障传输的安全性。sftp是较为安全的ftp,其传输的数据是密文。

vsftpd: very secure FTP daemon

vsftpd安装与配置

1.检查vsftpd是否安装,可通过yum安装

[09:41:57 [email protected] ~]# rpm -q vsftpd
[09:40:24 [email protected] ~]# yum -y install vsftpd
[09:43:23 [email protected] ~]# rpm -ql vsftpd
/etc/logrotate.d/vsftpd
/etc/pam.d/vsftpd  #PAM认证文件
/etc/vsftpd/ftpusers  #不能访问server的用户列表
/etc/vsftpd/user_list #允许访问server的用户列表
#/etc/vsftpd/chroot_list #能否访问主目录之外目录限制的用户列表
/etc/vsftpd/vsftpd.conf  #vsftp配置文件
/etc/vsftpd/vsftpd_conf_migrate.sh  #vsftpd操作的变量和设置脚本
/var/ftp  #匿名用户默认目录
/var/ftp/pub #匿名用户的下载目录,此目录需赋权根chmod 1777 pub

2.配置vsftpd

创建相关目录

[09:41:42 [email protected] Desktop]# touch /etc/vsftpd/chroot_list 
[09:42:32 [email protected] Desktop]# touch /etc/vsftpd//var/log/vsftpd.log
[09:43:55 [email protected] ~]# cp /etc/vsftpd/vsftpd.conf /etc/vsftpd/vsftpd.conf.bak
[09:44:43 [email protected] ~]# vi /etc/vsftpd/vsftpd/conf
anonymous_enable=YES  #是否允许匿名登录
local_enable=YES  #是否允许实体用户登录ftp服务器
write_enable=YES  #是否允许实体用户对ftp服务器文件进行写操作
local_umask=022   #权限掩码

anon_upload_enable=NO  #是否允许匿名用户上传文件
anon_mkdir_write_enable=NO #是否允许匿名用户创建新文件夹

#guest_enable= #使用允许guest登录
#guest_username= #指定guset的宿主用户
#user_config_dir= #指定guest的配置文件存放路径。

dirmessage_enable=YES  #是否显示目录欢迎信息

connect_from_port_20=YES  #是否使用20数据连接端口,YES表示启用,选用主动模式;为NO,则通过被动模式连接

chown_uploads=YES #是否允许改变上传文件的属主
#chown_username=whoever #设置上传文件的属主

ascii_upload_enable=YES  #是否支持ASCII模式上传
ascii_download_enable=YES #是否支持ASCII模式下载

chroot_local_user=YES #是否将所有用户限制在主目录,YES为启用 NO禁用.(该项默认值是NO,即在安装vsftpd后不做配置的
话,ftp用户是可以向上切换到要目录之外的)
chroot_list_enable=YES #是否启动限制用户例外的名单 YES为启用  NO禁用
chroot_list_file=/etc/vsftpd/chroot_list   #指定限定用户名单
#chroot_local_user=YES&&chroot_list_enable=YES:默认所有用户限制在主目录下,chroot_list_file不受限制
#chroot_local_user=YES&&chroot_list_enable=NO:所有用户限制在主目录下,不启用chroot_list_file
#chroot_local_user=NO&&chroot_list_enable=YES:默认所有用户不限制在主目录下,chroot_list_file中受限制
#chroot_local_user=YES&&chroot_list_enable=NO:默认所有用户不限制在主目录下,不启用chroot_list_file

accept_timeout=60  #指定FTP连接的超时时间
connect_timeout=60  #指定port方式下FTP建立连接的超时时间
idle_session_timeout=360   #设定会话时限,超时离线
data_connection_timeout=120   #设定传输时限

xferlog_enable=YES
xferlog_file=/var/log/vsftpd.log  #指定日志保存路径(事先创建好)
xferlog_std_format=YES  #是否使用标准xferlog日志格式

listen_port=21  #指定ftp端口,默认为21,可修改
listen=NO  #设置为yes,则由vsftpd自己监听和处理ipv4端口的连接请求,否则由xinetd管理.如果很少使用,建议设置为NO
#listen_ipv6=YES  

pam_service_name=vsftpd #用于认证的PAM模块配置文件名

userlist_enable=YES #是否使用user_list文件
userlist_deny=NO #user_list中的用户是否允许访问server
userlist_file=/etc/vsftpd/user_list
#仅当userlist_enable=YES时,userlist_deny设置才有效
#userlist_enable=YES && userlist_deny=YES:user_list中用户无法登录
#userlist_enable=YES && userlist_deny=NO:只有user_list中用户可以登录
#userlist_enable=YES && userlist_deny=NO:要想匿名登录,必须通过anonymous这一空用户名实现

tcp_wrappers=YES #是否使用tcp_wrappers作为主机访问控制方式
anon_max_rate=0   #指定匿名用户最大数据传输速度,默认值为0(不限速)
local_max_rate=0  #指定实体用户最大数据传输速度,默认值为0(不限速)

max_clients=5  #指定最大可连接的客户端数目
max_per_ip=1   #同一个ip上的连接数

3.设置防火墙规则

iptables -A INPUT -p tcp -m state --state NEW -m tcp --dport 21 -j ACCEPT
service iptables save
service iptables restart

4.启动vsftpd

systemctl start vsftpd

5.创建一个实体用户及相关文件

建议创建的账户只可以登录ftp,而不可以登录系统

[13:28:26 [email protected] vsftpd]# useradd -d /data1/myftp -g ftp -s /sbin/nologin myftp
[13:30:00 [email protected] vsftpd]# passwd myftp
[13:30:40 [email protected] vsftpd]# echo "myftp" >>/etc/vsftpd/user_list 
[13:32:00 [email protected] vsftpd]# echo "anonymous" >>/etc/vsftpd/user_list
[13:32:00 [email protected] vsftpd]# echo "myftp" >>/etc/vsftpd/chroot_list

6.客户机上测试

测试1:

[14:35:07 [email protected] ~]# ftp 172.17.220.145
Connected to 172.17.220.145 (172.17.220.145).
220 (vsFTPd 3.0.2)
Name (172.17.220.145:root): myftp
331 Please specify the password.
Password:
230 Login successful.
Remote system type is UNIX.
Using binary mode to transfer files.
ftp> put /home/wsdf/Desktop/ttt.rar /data1/myftp/ttt.tat
local: /home/wsdf/Desktop/ttt.rar remote: /data1/myftp/ttt.tat
227 Entering Passive Mode (172,17,220,145,41,198).
150 Ok to send data.
226 Transfer complete.
6590298 bytes sent in 0.874 secs (7543.17 Kbytes/sec)
ftp> get 1.txt /home/wsdf/Desktop/my_copy.cnf                    
local: /home/wsdf/Desktop/my_copy.cnf remote: 1.txt
227 Entering Passive Mode (172,17,220,145,142,85).
150 Opening BINARY mode data connection for 1.txt (40 bytes).
226 Transfer complete.
40 bytes received in 0.000318 secs (125.79 Kbytes/sec)

测试2:

ftp://myftp:[email protected]

FTP常用语法:

help:列出ftp的所有命令

lcd:切换本地路径

cd:切换远程路径

!ls:查看本地路径下的文件与目录

dir:查看远程路径下的文件与目录

get remote_file local_file: 从远程获取文件,保存到本地

put local_file remote_file: 从本地获取文件,传送到到远程服务器

asc:以ascii方式传输文件

bin:以二进制方式传输文件

时间: 2024-12-29 06:39:49

Centos7.1 for vsftpd配置的相关文章

centos7下安装vsftpd配置

0. 首先安装ftp服务 yum install -y ftp 1. 通过yum install -y vsftp安装vsftp 2.    修改vi /etc/vsftpd/vsftpd.conf,把chroot_list_enabled=yes打开,chroot_list_file=/etc/vsftpd/chroot_list打开 然后 touch /etc/vsftpd/chroot_list 添加刚才的用户 3.    新建ftp用户: useradd -d /home/ftp -g

CentOS7 FTP安装与配置

CentOS7 FTP安装与配置 1.FTP的安装 #安装yum install -y vsftpd #设置开机启动systemctl enable vsftpd.service #启动systemctl start vsftpd.service #停止systemctl stop vsftpd.service #查看状态systemctl status vsftpd.service 2.配置FTP #打开配置文件 vim /etc/vsftpd/vsftpd.conf #显示行号 :set n

Ubuntu 用vsftpd 配置FTP服务器

原文:Ubuntu 用vsftpd 配置FTP服务器 网上的文章好难懂啊..只想要简单粗暴,弄好能用就行啊,复杂的以后研究不行吗...折腾好久,其实弄出来能用不就这么点内容吗... 本文在Ubuntu Server 14.04 amd64系统测试. Made By:CSGrandeur 安装ftp sudo apt-get install vsftpd 配置vsftpd.conf sudo nano /etc/vsftpd.conf #禁止匿名访问 anonymous_enable=NO #接受

Centos7下安装及配置PPTP VPN

说到VPN服务,我们大家都知道,VPN是虚拟专用网络(Virtual Private Network)的缩写,VPN有多种分类方式,包括PPTP.L2TP.IPSec等,本文配置的VPN服务器是采用PPTP协议的,PPTP是在PPP协议基础上开发的一种新的增强型安全协议.当然在windows上和linux上都可以部署服务,我们今天主要介绍一下在Centos7下安装及配置PPTP VPN. 因为PPTP是基于PPP协议基础上的,因此需要系统支持PPP,使用 rpm -qa ppp 检查是否安装了P

转载:Centos7 从零编译配置Memcached

序言 Memcached 是一个高性能的分布式内存对象缓存系统,用于动态Web应用以减轻数据库负载.它通过在内存中缓存数据和对象来减少读取数据库的次数,从而提高动态.数据库驱动网站的速度. Memcached基于一个存储键/值对的hashmap.其守护进程(daemon )是用C写的,但是客户端可以用任何语言来编写,并通过memcached协议与守护进程通信. 当然memcached分为服务端和客户端.服务端用来存放缓存,客户端用来操作缓存. 客户端有两种常见的实现方式. 第一种是用php代码根

Centos7下安装及配置Zabbix3.0

说到Zabbix相信很多管理员都使用过,因为zabbix所提供的功能给广大管理员们及时得知自己所管理的服务器的服务状态,当然有很多软件服务(cacti.ngios等)都可以实现zabbix类似的功能,但是对于zabbix的功能相对更强大一点,具体就不细说了,今天我们主要介绍一下,Centos7下安装及配置Zabbix3.0的介绍,具体见下: 在安装服务器的时候我们需要注意一些问题:比如服务器的防火墙.selinux等都会影响到Zabbix的正常通信 环境介绍: OS:Centos7 Servic

CentOS7下Firewall防火墙配置用法详解

官方文档地址: https://access.redhat.com/documentation/en-US/Red_Hat_Enterprise_Linux/7/html/Security_Guide/sec-Using_Firewalls.html#sec-Introduction_to_firewalld1 修改防火墙配置文件之前,需要对之前防火墙做好备份 重启防火墙后,需要确认防火墙状态和防火墙规则是否加载,若重启失败或规则加载失败,则所有请求都会被防火墙拦截 1 2 3 4 5 6 7

vsftpd配置

环境:CentOS 5.0 操作系统一.安装:1.安装Vsftpd服务相关部件:[[email protected] ~]# yum install vsftpd*Dependencies Resolved=============================================================================Package                 Arch       Version          Repository       

Centos7安装RocketMQ及配置测试

环境 Centos7 RocketMQ 3.2.6 安装位置 /usr/local/alibaba-rockermq 外网ip 182.254.145.66 内网ip 10.105.23.114 安装 wget https://github.com/alibaba/RocketMQ/releases/download/v3.2.6/alibaba-rocketmq-3.2.6.tar.gz tar alibaba-rocketmq-3.2.6.tar.gz cd  alibaba-rocketm