ftp安装和虚拟用户创建(终于搞清楚了)
安装
一.安装
sudo apt-get install vsftpd
二.查看安装结果
安装完毕,检查vsftpd进程是否已启动,可以查看进程或者查看监听端口
ps -eaf|grep vsftpd tony@T:~$ ps -eaf | grep vsftpd root : ? :: /usr/sbin/vsftpd tony : pts/ :: grep --color=auto vsftpd netstat -tnl | grep : tony@T:~$ netstat -tnl | grep : tcp 0.0.0.0: 0.0.0.0:* LISTEN 端口21正在被监听
三. 尝试匿名用户登录
安装完后不用做任何配置既可用匿名方式进行访问,默认的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。 (vsFTPd 2.2.) 用户(192.168.1.108:(none)): ftp Please specify the password. 密码: Login successful.
登录到的目录就是/srv/ftp目录,在里面的文件就能够查看到
四. 使用ubuntu的账户登录
此时就访问ftp账户,默认是linux的账户,使用cmd中登录。
需要注意的是,ftp服务器端文件路径是用户的家目录
C:\Users\Tony>ftp 192.168.1.108 连接到 192.168.1.108。 (vsFTPd 2.2.) 用户(192.168.1.108:(none)): tony Please specify the password. 密码: Login successful.
五. 在ubuntu中,vsftpd的主要配置文件分布如下:
/etc/vsftpd.conf vsftpd服务器的配置文件 /usr/sbin/vsftpd vsftpd服务器的进程文件 /etc/pam.d/vsftpd vsftpd服务器的PAM接口配置文件 /var/ftp vsftpd服务器匿名用户的工作目录
六. vsftpd的开始、关闭和重启
sudo /etc/init.d/vsftpd start #开始 sudo /etc/init.d/vsftpd stop #关闭 sudo /etc/init.d/vsftpd restart #重启
创建虚拟账户
一.安装生成虚拟帐号数据库工具db
sudo apt-get install db4.-util
二. 更改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= //设置本地用户上传建立文件时的权限掩码 #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= data_connection_timeout= //#数据连接的超时时间 #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= max_per_ip= local_max_rate= #hide_ids=YES idle_session_timeout= guest_enable=YES guest_username=ftp user_config_dir=/etc/vsftpd/vsftpd_user_conf pam_service_name=vsftpd.vu
三. 建立各账户的home目录
在/home目录建立ftp的账户ftpdir目录
cd /home/ftp/ sudo mkdir ftpdir
然后在ftpdir目录下创建admin, tony目录
cd ftpdir
sudo mkdir admin tony
四.为虚拟用户创建本地系统用户
虚拟用户家目录为/home/ftpdir, 用户登录终端设为/bin/false(即使之不能登录系统)
sudo useradd ftp -d /home/ftpdir -s /bin/false
sudo chown -R ftp:ftp /home/ftpdir
五. 创建虚拟用户数据库
新建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 /etc/vsftpd/vsftpd_login.db
六. 配置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
七.新建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
八. 配置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
九. 配置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
十. 新建/etc/vsftpd/vsftpd.chroot_list
sudo touch /etc/vsftpd/vsftpd.chroot_list sudo vi /etc/vsftpd/vsftpd.chroot_list 里面添加 admin
在按照以上的过程去安装,有可能Linux的数据源里面根本就找不到对应的安装包,可以通过手动安装的方法;网上找了篇db4的安装问题,分享一下:
1、下载安装文件:
下载地址直达:http://cz.archive.ubuntu.com/ubuntu/pool/universe/d/db4.8/
2、dpkg - i db4.8-util_4.8.30-11ubuntu1_amd64.deb
即可
命令使用:这里针对Vsftpd虚拟用户的创建
sudo db4.8_load -T -t hash -f /home/user.txt /etc/vsftpd_login.db
当然也有命令安装db的方法:
已解决了 sudo apt-get install db-util
在这又不得不来句粗口,尼玛,之前找了那么久的解决办法,原来是没有找对方法,网上一大堆也是无用的,有些方法更本用不了,回头想想当你的知识积累起来了之后,你就会忽然想起来这问题的解决方法,自己都会被自己惊呆,当年这么简单的问题居然都不会,当年真是傻呆笨啊!
总结:知识积累是多么地重要啊!
ftp安装和虚拟用户创建(终于搞清楚了)的更多相关文章
- ftp安装和虚拟用户创建
安装 1.安装 sudo apt-get install vsftpd 2 查看安装结果 安装完毕,检查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 ...
随机推荐
- 分布式-信息方式-JMS信息结构
JMS的消息结构JMS消息由以下几部分组成:消息头,属性和消息体消息头包含消息的识别信息和路由信息,消息头包含一些标准的属性如下:1: JMSDestination:由send方法设置2: JMSDe ...
- 安卓项目集成objectbox-java数据库框架教程(非关系型)
objectbox数据库是greenrobot团队开发的全新非关系型数据库框架,该团队还开发过greenDao,EventBus等热门框架,objectbox可能是第一次听说,但是greenDao,E ...
- 191121HTML
一.HTML 1.web server import socket def handle_request(client): buf = client.recv(1024) client.send(by ...
- 【Spark机器学习速成宝典】模型篇07梯度提升树【Gradient-Boosted Trees】(Python版)
目录 梯度提升树原理 梯度提升树代码(Spark Python) 梯度提升树原理 待续... 返回目录 梯度提升树代码(Spark Python) 代码里数据:https://pan.baidu.co ...
- zoopkeeper 的ACL操作
1.创建一个变量存放模式信息, private static final String MODE = "digest"; //ACL模式 2.在一个类的构造函数内放入初始化信息 ...
- Dark 面向对象
1 继承 使用extends继承一个类 子类会继承父类可见的属性和方法,不包含构造方法 可以复写父类的方法 单继承,多态性 构造方法 子类的构造方法会默认调用父类的无名无参构造方法 如果父类没有无名无 ...
- committed与urgent的区别
Committed跟Urgent都是time automaton 中用来表示state的关键词. 它们的主要区别是: Committed前后的两个状态改变(transition)是串行发生,不可打断的 ...
- C#规范整理·语言要素
如有不理解,请留言,开始! 1. 正确操作字符串 拼接字符串一定要考虑使用 StringBuilder ,默认长度为16,实际看情况设置. StringBuilder本质: 是以非托管方式分配内存. ...
- LoadRunner 技巧之 添加事务
事务(Transaction)用于模拟用户的一个相对完整的.有意义的业务操作过程,例如登录.查询.交易.转账,这些都可以作为事务,而一般不会把每次HTTP请求作为一个事务. 拿笔者所测试的邮箱系统为例 ...
- 【ABAP系列】SAP ABAP7.40新语法简介第一篇
公众号:SAP Technical 本文作者:matinal 原文出处:http://www.cnblogs.com/SAPmatinal/ 原文链接:[ABAP系列]SAP ABAP7.40新语法简 ...