Centos6.8:vsftpd安装与配置

vsftpd是一款在Linux发行版中最受推崇的FTP服务器程序。特点是小巧轻快,安全易用,具有非常高的安全性需求、带宽限制、良好的可伸缩性、可创建虚拟用户、支持IPv6、速率高等特点

1. 下载安装vsftpd服务,使用yum即可,db4用来支持文件数据库

yum install -y vsftpd db4-utils

2. 建立宿主用户vsftpd,因为默认的Vsftpd的服务宿主用户是root,但是这不符合安全性的需要。这里建立名字为vsftpd的用户,用他来作为支持Vsftpd的服务宿主用户,即运行vsftpd服务的是vsftpd。由于该用户仅用来支持Vsftpd服务用,因此没有许可他登陆系统的必要,并设定他为不能登陆系统的用户

useradd -s /sbin/nologin -M vsftpd

3. 建立ftp虚拟宿主用户,Vsftp的虚拟用户,虚拟用户并不是系统用户,也就是说这些FTP的用户在系统中是不存在的。他们的总体权限其实是集中寄托在一个在系统中的某一个用户身上的,所谓Vsftpd的虚拟宿主用户,就是这样一个支持着所有虚拟用户的宿主用户。由于他支撑了FTP的所有虚拟的用户,那么他本身的权限将会影响着这些虚拟的用户,因此,处于安全性的考虑,也要非分注意对该用户的权限的控制,该用户也绝对没有登陆系统的必要,这里也设定他为不能登陆系统的用户。

useradd -s /sbin/nologin -M peng

4. 编辑vsftpd配置文件

cp /etc/vsftpd/vsftpd.conf /etc/vsftpd/vsftpd.conf.bak
vim /etc/vsftp/vsftpd.conf
--------------------------------------------------------------
anonymous_enable=NO            #   设定禁止匿名访问
anon_upload_enable=NO           #   设定禁止匿名上传
anon_mkdir_write_enable=NO         #   设定禁止匿名创建目录
xferlog_enable=YES             #   开启日志记录功能
xferlog_file=/var/log/vsftpd.log      #   设定vsftpd服务日志报错路径,需要手动touch,由于这里更改了服务启动用户,所以需要给vsftpd用户写入权限
xferlog_std_format=YES           #   设定日志使用标准记录格式
local_enable=YES              #   设定本地用户可以访问,如果为NO,虚拟用户也无法访问
write_enable=YES              #   设定可以进行写操作
chown_uploads=NO              #   禁止上传文件更改宿主

chroot_list_enable=NO           # 设置是否启用chroot_list_file配置项指定的用户列表文件。默认值为NO
chroot_list_file=/etc/vsftpd.chroot_list    # 用于指定用户列表文件,该文件用于控制哪些用户可以切换到用户家目录的上级目录
chroot_local_user=YES                      # 用于指定用户列表文件中的用户是否允许切换到上级目录。默认值为NO  
nopriv_user=vsftpd             #  设定支撑vsftpd服务的宿主用户,即运行vsftpd服务的是vsfptd用户,这里要注意写入权限,比如日志文件     
local_umask=022              #   设定上传后的权限掩码为022
pam_service_name=vsftpd          #  设置PAM使用的名称,默认值为/etc/pam.d/vsftpd
userlist_enable=YES            #  userlist_file中的用户将不得登录FTP
guest_enable=YES            #  设定启用虚拟用户功能
guest_username=peng            #  指定虚拟用户的宿主用户
virtual_use_local_privs=YES        #  当该参数激活(YES)时,虚拟用户使用与本地用户相同的权限
user_config_dir=/etc/vsftpd/user_conf   #  设定虚拟用户个人Vsftp的配置文件存放路径,这些配置文件名必须和虚拟用户名相同
connect_from_port_20=YES          #   设定端口20进行数据连接
dirmessage_enable=YES           #   开启目录标语功能

#idle_session_timeout=600         # 设置多长时间不对FTP服务器进行任何操作,则断开该FTP连接,单位为秒。默认值为300
#data_connection_timeout=120        # 设置建立FTP数据连接的超时时间,单位为秒。默认值为120
#accept_timeout=60             # 设置建立FTP连接的超时时间,单位为秒。默认值为60
async_abor_enable=YES           # 设定支持异步传输功能
ascii_upload_enable=YES          # 设定支持ascii上传
ascii_download_enable=YES         # 设定支持ascii下载
ftpd_banner=‘Welcome‘           # 设定ftp登录欢迎语
ls_recurse_enable=NO            # 禁止用户登陆FTP后使用"ls -R"的命令。该命令会对服务器性能造成巨大开销
listen=YES                 # 设定该Vsftpd服务工作在StandAlone模式下,所谓StandAlone模式就是该服务拥有自己的守护进程支持
tcp_wrappers=YES              # vsftpd服务器会检查/etc/hosts.allow 和/etc/hosts.deny 中的设置,来决定请求连接的主机,是否允许访问该FTP服务器
#比如允许192.168.1.0这个网段访问vsftpd服务,在hosts.allow添加
#vsftpd:192.168.0. :allow
local_max_rate=0    #  本地用户使用的最大传输速度,单位为B/s,0 表示不限制速度。预设值为0

5. 建立vsftpd日志文件,并赋予相关的权利

touch /var/log/vsftpd.log
chown vsftpd:vsfptd /var/log/vsftpd.log
mkdir /etc/vsftpd/user_conf

6. 制作虚拟用户数据库文件

#    先建立虚拟用户名单,这个文件就是来记录vsftpd虚拟用户的用户名和口令的数据文件
touch /etc/vsftpd/virtusers
#    编辑虚拟用户名单,添加可访问的用户和密码,一行一用户,一行一密码
echo -e ‘user1\n123456‘ >> /etc/vsftpd/virtusers
#    生成虚拟用户数据文件
db_load -T -t hash -f /etc/vsftpd/virtusers /etc/vsftpd/virtusers.db
#    查看生成的用户数据文件
ll /etc/vsftpd/virtusers.db
#    如果以后再添加虚拟用户,需要再执行生成一次虚拟用户数据文件

7. 设定PAM验证文件,并指定虚拟用户数据文件读取

#    在编辑前备份
cp /etc/pam.d/vsftpd /etc/pam.d/vsftpd.bak
vim /etc/pam.d/vsftpd
#    添加俩行,目的是对虚拟用户和账号权限进行验证
auth    sufficient    /lib64/security/pam_userdb.so    db=/etc/vsftpd/virtusers
account sufficient /lib64/security/pam_userdb.so   db=/etc/vsftpd/virtusers

8. 虚拟用户的配置

#    规划好虚拟用户的主路径
mkdir /opt/vsftpd
#    建立测试用户的FTP主目录
mkdir /opt/vsftpd/user1
#    定制测试用户的配置文件
cp /etc/vsftpd/vsftpd.conf.bak /etc/vsftpd/user_conf/user1
vim !$
----------------------------------
#    定义测试用户的FTP家目录
local_root=/opt/vsftpd/user1   
----------------------------------
# 这里将原vsftpd.conf配置文件经过简化后保存作为虚拟用户配置文件的模版。这里将并不需要指定
太多的配置内容,主要的框架和限制交由 Vsftpd的主配置文件vsftpd.conf来定义,即虚拟用户配置文
件当中没有提到的配置项目将参考主配置文件中的设定。而在这里作为虚拟用户的配置文件模版只需要
留一些和用户流量控制,访问方式控制的配置项目就可以了。这里的关键项是local_root这个配置,
用来指定这个虚拟用户的FTP主路径。

9. 更改虚拟用户的家目录权限

chown -R peng:peng /opt/vsftpd/

10. 启动服务

service vsftpd start

错误:

如果使用lftp遇到500错误,可能你的vsftpd.conf有不能被识别的命令,还有一种可能是命令的YES 或 NO 后面有空格,可使用cat -E vsftpd.conf检查

具体vsftpd.conf详细参数配置可见此贴:http://yuanbin.blog.51cto.com/363003/108262/

时间: 2024-10-15 11:20:34

Centos6.8:vsftpd安装与配置的相关文章

CentOs6.5中安装和配置vsftp简明教程

这篇文章主要介绍了CentOs6.5中安装和配置vsftp简明教程,需要的朋友可以参考下 一.vsftp安装篇 复制代码代码如下: # 安装vsftpdyum -y install vsftpd# 启动service vsftpd start# 开启启动chkconfig vsftpd on 二.vsftp相关命令之服务篇 复制代码代码如下: # 启动ftp服务service vsftpd start# 查看ftp服务状态service vsftpd status # 重启ftp服务servic

Solr6.5在Centos6上的安装与配置 (一)

这篇文章主要是介绍在Centos6上Solr6.5的安装与配置. 一.安装准备及各软件使用版本说明: 1.JDK8,版本jdk1.8.0_121下载地址:jdk-8u121-linux-x64.tar.gz 2.Apache Tomcat,版本8.5.13 下载地址:apache-tomcat-8.5.13.tar.gz 3.Solr,版本solr-6.5.0,下载地址:solr-6.5.0.tgz 此文使用的是centos6.6的系统.在系统根目录下建立down目录.然后依次下载上面的三个软件

centos下vsftpd安装与配置

1.已经配置好可以上网了,所以即可通过yum install vsftpd安装啦.如果不能上网则可以通过dvd2.iso工具集rpm方式进行安装. 2.安装好后,默认本地可以通过匿名用户登录,但是其它电脑是不能访问.本文主要记录下允许匿名用户上传下载删除文件所做的些配置,主要需要做3大方面配置vsftpd本身.selinux和iptables 3.vsftpd方面有一个关键配置是anon_umask=022即设置上传的文件的权限,否则默认上传文件权限为600,那么上传的权限是不能被下载的. 4.

Ubuntu下vsftpd安装和配置

1.安装 sudo apt-get install vsftpd 2.安装后启动,停止,重启命令 sudo service vsftpd start sudo service vsftpd stop sudo service vsftpd restart 3.配置 vi /etc/vsftpd.conf listen = YES   #Run standalone? 启用独立vsftpd服务器,YES表示是 #listen_ipv6=YES #是否监听ipv6默认关闭 anonymous_ena

Centos6.5-----nagios快速安装编译配置文档-全部虚拟环境

写这个文档的目的,就是为了方便 快捷的部署nagios,涉及到个人喜好的配置,大家自行修改,可以套用. 一.下载并安装所需软件 1,yum install gcc mysql httpd php gd openssl openssl-devel mysql-server vim wget Wget http://prdownloads.sourceforge.net/sourceforge/nagios/nagios-4.0.7.tar.gz Wget http://nagios-plugins

Vsftpd安装以及配置FTP虚拟用户实践

安装vsftpd #查看当前系统版本 [[email protected] vsftpd]# cat  /etc/redhat-release CentOS release 6.7 (Final) #安装 yum  install  vsftpd  -y #开机启动 chkconfig  vsftpd   on 基于虚拟用户和被动模式的配置 [[email protected] vsftpd]# cat  vsftpd.conf anonymous_enable=NO listen=YES li

CentOS6.6 Vsftpd虚拟用户配置

#安装软件包 yum -y install vsftpd db4* #关闭SELinux vim /etc/sysconfig/selinux SELINUX=permissive #命令行输入,立即生效SELinux配置 getenforce 0 #防火墙允许22号端口 iptables -A INPUT -m state --state NEW -m tcp -p tcp --dport 22 -j ACCEPT #建立虚拟用户登录文件,基数行为用户,偶数行为密码,只能这样写,否则系统不认

centos6.5下安装vsftp配置与注意事项

最近在公司服务器环境下部署应用,需要用到FTP来传图片,在配置权限上走了一些弯路,现把步骤记录下来,做后续参考: Vsftp(Very Secure FTP)是一种在Unix/Linux中非常安全且快速稳定的FTP服务器,目前已经被许多大型站点所采用,如ftp.redhat.com,ftp.kde.org,ftp.gnome.org.等.Vsftpd的实现有三种方式  1.匿名用户形式:在默认安装的情况下,系统只提供匿名用户访问  2.本地用户形式:以/etc/passwd中的用户名为认证方式 

FTP服务学习笔记之vsftpd安装和配置(2)

在redhat5部署FTP服务 实验环境介绍: 操作系统:Redhat5.8_X64bit 实验平台:VMware Workstation 一.基于匿名用户的FTP服务部署 1.匿名FTP 访问匿名的FTP服务器时不需要密码,只需要用户名"ftp"和"anonymous". 2.安装vsftpd软件 #yum install vsftpd #rpm -ql vsftpd 3.启动vsftpd服务 #service vsftpd start #chkconfig vs