ftp安装和虚拟用户创建
安装
1.安装
sudo apt-get install vsftpd
2 查看安装结果
安装完毕,检查vsftpd进程是否已启动,可以查看进程或者查看监听端口
ps -eaf|grep vsftpd
tony@T:~$ ps -eaf | grep vsftpd
root 2244 1 0 21:08 ? 00:00:00 /usr/sbin/vsftpd
tony 2408 2104 0 21:11 pts/0 00:00:00 grep --color=auto vsftpd
netstat -tnl | grep :21
tony@T:~$ netstat -tnl | grep :21
tcp 0 0 0.0.0.0:21 0.0.0.0:* LISTEN
端口21正在被监听
3. 尝试匿名用户登录
安装完后不用做任何配置既可用匿名方式进行访问,默认的ftp文件夹为/srv/ftp。
登录可以在浏览器中,文件夹输入框中以及类型windows/Linux终端中进行测试。
建议使用windows/Linux终端测试,失败了会有错误输出,可以根据错误进行调试。
更改配置文件vsftpd.conf
anonymous_enable=YES
匿名登录,用户名称ftp,密码不输入,直接回车
C:\Users\Tony>ftp 192.168.1.108
连接到 192.168.1.108。
220 (vsFTPd 2.2.2)
用户(192.168.1.108:(none)): ftp
331 Please specify the password.
密码:
230 Login successful.
登录到的目录就是/srv/ftp目录,在里面的文件就能够查看到
4. 使用ubuntu的账户登录
此时就访问ftp账户,默认是linux的账户,使用cmd中登录。
需要注意的是,ftp服务器端文件路径是用户的家目录
C:\Users\Tony>ftp 192.168.1.108
连接到 192.168.1.108。
220 (vsFTPd 2.2.2)
用户(192.168.1.108:(none)): tony
331 Please specify the password.
密码:
230 Login successful.
5. 在ubuntu中,vsftpd的主要配置文件分布如下:
/etc/vsftpd.conf vsftpd服务器的配置文件
/usr/sbin/vsftpd vsftpd服务器的进程文件
/etc/pam.d/vsftpd vsftpd服务器的PAM接口配置文件
/var/ftp vsftpd服务器匿名用户的工作目录
6. vsftpd的开始、关闭和重启
sudo /etc/init.d/vsftpd start #开始
sudo /etc/init.d/vsftpd stop #关闭
sudo /etc/init.d/vsftpd restart #重启
创建虚拟账户
1.安装生成虚拟帐号数据库工具db
sudo apt-get install db4.8-util
2. 更改vsftp.conf的配置
修改配置之前,先备份当前配置
sudo cp /etc/vsftp.conf /etc/vsftp.conf.old
配置的服务器中 vsftpd.conf的参数使用如下:
listen=YES
#listen_ipv6=YES
anonymous_enable=NO //允许匿名用户访问,若禁止使用NO
local_enable=YES //允许本地用户访问,若禁止则使用NO
write_enable=YES //表示是否允许本地用户有上传权限的,YES表示可以,NO表示禁止,也取决于客户端连接时使用的客户端工具
#local_umask=022 //设置本地用户上传建立文件时的权限掩码
#anon_upload_enable=YES //匿名用户上传文件使能
#anon_mkdir_write_enable=YES //匿名用户可以创建目录
dirmessage_enable=YES //用户切换进入目录时显示.message(如果存在)文件的内容
message_file=Welcome
xferlog_enable=YES //是否开启传输日志的
connect_from_port_20=YES ////连接控制端口为20
chown_uploads=YES
chown_username=ftp
chroot_local_user=YES //所有的本地用户都被锁定在家目录下
chroot_list_enable=YES
chroot_list_file=/etc/vsftpd/vsftpd.chroot_list
xferlog_file=/var/log/vsftpd.log
xferlog_std_format=YES
idle_session_timeout=600
data_connection_timeout=120 //#数据连接的超时时间
#nopriv_user=ftpsecure
#async_abor_enable=YES
ascii_upload_enable=YES
ascii_download_enable=YES
ftpd_banner=Welcome to blah FTP service. //login欢迎信息
#deny_email_enable=YES
max_clients=10
max_per_ip=5
local_max_rate=256000
#hide_ids=YES
idle_session_timeout=3000
guest_enable=YES
guest_username=ftp
user_config_dir=/etc/vsftpd/vsftpd_user_conf
pam_service_name=vsftpd.vu
3. 建立各账户的home目录
在/home目录建立ftp的账户ftpdir目录
cd /home/ftp/
sudo mkdir ftpdir
然后在ftpdir目录下创建admin, tony目录
cd ftpdir
sudo mkdir admin tony
4.为虚拟用户创建本地系统用户
虚拟用户家目录为/home/ftpdir, 用户登录终端设为/bin/false(即使之不能登录系统)
sudo useradd ftp -d /home/ftpdir -s /bin/false
sudo chown -R ftp:ftp /home/ftpdir
5. 创建虚拟用户数据库
新建loguser.txt文件,
sudo vi /home/loguser.txt
里面输入虚拟用户名和密码,格式如下
admin
admin
tony
tony
注意不要多空格和空行,其中奇数行为用户名,偶数行为密码。
最后一行需要回车(否则建立数据库文件时无法识别最后一行,导致报奇数行错误)。
新建一个文件夹/etc/vsftpd,放置配置文件
sudo mkdir /etc/vsftpd
然后执行
sudo db4.8_load -T -t hash -f /home/loguser.txt /etc/vsftpd/vsftpd_login.db
最后设置一下数据库文件的访问权限
sudo chmod 600 /etc/vsftpd/vsftpd_login.db
6. 配置PAM文件
新建/etc/pam.d/vsftpd.vu,并编辑,
sudo touch /etc/pam.d/vsftpd.vu
sudo vi /etc/pam.d/vsftpd.vu
输入内容如下:
auth required /lib/security/pam_userdb.so db=/etc/vsftpd/vsftpd_login
account required /lib/security/pam_userdb.so db=/etc/vsftpd/vsftpd_login
7.新建etc/vsftpd /vsftpd_user_conf文件夹
sudo mkdir /etc/vsftpd/vsftpd_user_conf
现在,我们要把各个用户的配置文件放到目录/etc/vsftpd/vsftpd_user_conf中
cd /etc/vsftpd/vsftpd_user_conf
sudo touch admin tony
8. 配置admin虚拟用户
权限:上传,下载删除,重命名.
sudo vi /etc/vsftpd/vsftpd_user_conf/admin
里面添加
write_enable=YES
anon_world_readable_only=NO
anon_upload_enable=YES
anon_mkdir_write_enable=YES
anon_other_write_enable=YES
local_root=/home/ftpdir
9. 配置tony虚拟用户
权限:上传,下载
sudo vi /etc/vsftpd/vsftpd_user_conf/tony
里面添加
write_enable=YES
anon_world_readable_only=NO
anon_upload_enable=YES
anon_mkdir_write_enable=NO
anon_other_write_enable=NO
local_root=/home/ftpdir/tony
10. 新建/etc/vsftpd/vsftpd.chroot_list
sudo touch /etc/vsftpd/vsftpd.chroot_list
sudo vi /etc/vsftpd/vsftpd.chroot_list
里面添加
admin
Author
Tony Liu
2016-8-2, Shenzhen
ftp安装和虚拟用户创建的更多相关文章
- ftp安装和虚拟用户创建(终于搞清楚了)
安装 一.安装 sudo apt-get install vsftpd 二.查看安装结果 安装完毕,检查vsftpd进程是否已启动,可以查看进程或者查看监听端口 ps -eaf|grep vsftpd ...
- FTP原理和虚拟用户映射登录-2019.2.8
FTP主动模式和被动模式 FTP(File Transfer Protocol)是文件传输协议的简称.正如其名所示:FTP的主要作用,就是让用户连接上一个远程计算机(这些计算机上运行着FTP服务器程序 ...
- Ubuntu14 vsftp 的安装和虚拟用户配置
一.介绍 FTP 是 File Transfer Protocol (文件传输协议)的缩写 ,在 Unix/Linux 系统中常用的免费 FTP 服务器软件主要是 VSFTP,vsftp的官方地址:h ...
- vsftpd虚拟用户创建实例(转载)
vsftpd虚拟用户创建实例 发布:theboy 来源:net [大 中 小] vsftpd虚拟用户创建实例,有需要的朋友可以参考下. vsftpd虚拟用户创建实例,有需要的朋友可以参考 ...
- Centos下安装FTP并进行虚拟用户访问方式配置
1. 安装认证所需包 [root@localhost]#yum install pam* [root@localhost]#yum install db4* 首先安装PAM(用于用户认证)和DB4(用 ...
- vsftpd安装及虚拟用户配置
服务器环境:CentOS6.9 Linux 2.6.32-696.10.1.el6.x86_64 安装vsftpd.db4.db4-utils # yum -y install vsftpd db4 ...
- vsftpd服务安装与虚拟用户配置
vsftpd的全名是“Very secure FTP Daemon” 一.安装vsftpd安装db4-util用于生成认证文件 yum -y install db4-utils 安装vsftpd yu ...
- vsftpd安装配置虚拟用户
原文发表于cu:2016-03-11 参考文档: FTP原理:http://vbird.dic.ksu.edu.tw/linux_server/0410vsftpd_1.php FTP配置:http: ...
- CentOS 6.8 ftp服务安装配置 基于本地用户和虚拟用户
CentOS 6.8 ftp服务安装配置 基于本地用户和虚拟用户 一.安装ftp服务 1.检查是否已经安装 # rpm -qa | grep ftp ftp-0.17-54.el6.x86_64 vs ...
随机推荐
- 修复错误配置/etc/fstab文件导致系统无法正常启动
1.文件介绍 /etc/fstab这个文件描述系统中各种文件系统的信息,应用程序读取这个文件,然后根据其内容进行自动挂载的工作.作为系统配置文件,fstab通常都位于/etc目录下,它包括了所有分 ...
- 首都医科大学附属北京安贞医院全院级PACS系统采购项目[转]
项目名称:首都医科大学附属北京安贞医院全院级PACS系统采购项目 项目编号:TC140VCF0 采购人名称:首都医科大学附属北京安贞医院 采购人地址:北京市朝阳区安贞里 采购人联系方式:010-644 ...
- 转换到 StoryBoard 的公布说明(Converting to Storyboards Release Notes)
转换到 StoryBoard 的公布说明(Converting to Storyboards Release Notes) 太阳火神的漂亮人生 (http://blog.csdn.net/opengl ...
- Tp框架中模板中if条件如何使用?
- MyEclipse连接sqlserver2008具体流程
参照这里: 图形连接 http://wenku.baidu.com/view/f50838086c85ec3a87c2c53a.html 还有查看的是这个: 2. 重新用Window验证方式登陆 ...
- 恢复阿里云RDS云数据库MySQL的备份文件到自建数据库
云数据库MySQL版使用开源软件Percona Xtrabackup对数据库进行备份,所以您可以使用该软件将云数据库MySQL的备份文件恢复到自建数据库中,本文将介绍详细的操作步骤. 关于云数据库My ...
- 阿里云RDS实例内不同数据库之间的数据迁移
适用场景 本文适用于使用DTS实现相同实例下库名不同的数据库之间的数据迁移.本文以使用DTS将同一RDS实例下的amptest库迁移到jiangliu_amptest库为例来说明如何使用DTS实现相同 ...
- spring in action小结2
1 @Component注解声明的类都会创建为bean,并且bean的id为首字母小写的类名. 2 解决bean自动装配奇异性问题,可以使用@Qualifier("name")限定 ...
- MySQL Subquery
Summary: in this tutorial, we will show you how to use the MySQL subquery to write complex queries a ...
- Hadoop-2.2.0中文文档—— Shell命令
FS Shell 调用文件系统(FS)Shell命令应使用 bin/hadoop fs <args>的形式. 全部的的FS shell命令使用URI路径作为參数.URI格式是scheme: ...