FTP介绍

大企业用的基本都是自动化发布工具,会用GIT企业发布的版本上传到服务器,

使用vsftpd搭建ftp服务(上)

http://blog.csdn.net/qq_26941173/article/details/54575952

1.yum安装vsftpd包

  1. [root@fuwuduan nfstestdir]# yum install -y vsftpd

2.建立账号

vsftp默认支持系统账号体系登录,但那样不安全,我们可以使用虚拟账号体系。

(一)建立与虚拟账号相关联的系统账号

  1. [root@fuwuduan nfstestdir]# useradd -s /sbin/nologin virftp
  2. [root@fuwuduan nfstestdir]#

3.创建ftp用户账号文件写入用户user1

  1. [root@fuwuduan nfstestdir]# vim /etc/vsftpd/vsftpd_login
  2. [root@fuwuduan nfstestdir]#
  1. user1
  2. user1

4.设置密码问题权限

  1. [root@fuwuduan nfstestdir]# chmod 600 /etc/vsftpd/vsftpd_login
  2. [root@fuwuduan nfstestdir]#

5.vsfptd使用的密码文件不是明文的,需要生成对应的库文件。

  1. [root@fuwuduan nfstestdir]# db_load -T -t hash -f /etc/vsftpd/vsftpd_login /etc/vsftpd/vsftpd_login.db
  2. [root@fuwuduan nfstestdir]#

6.发现生成了vsftpd_login.db文件

  1. [root@fuwuduan nfstestdir]# ls -l /etc/vsftpd/
  2. 总用量 36
  3. -rw-------. 1 root root 125 8 3 2017 ftpusers
  4. -rw-------. 1 root root 361 8 3 2017 user_list
  5. -rw-------. 1 root root 5030 8 3 2017 vsftpd.conf
  6. -rwxr--r--. 1 root root 338 8 3 2017 vsftpd_conf_migrate.sh
  7. -rw-------. 1 root root 12 2 23 15:02 vsftpd_login
  8. -rw-r--r--. 1 root root 12288 2 23 15:04 vsftpd_login.db
  9. [root@fuwuduan nfstestdir]#

7.创建虚拟用户配置文件所在目录

  1. [root@fuwuduan nfstestdir]# mkdir /etc/vsftpd/vsftpd_user_conf
  2. [root@fuwuduan nfstestdir]# cd /etc/vsftpd/vsftpd_user_conf/
  3. [root@fuwuduan vsftpd_user_conf]#

8.创建和用户对应的配置文件,用户的配置文件时单独存在的,每一个用户都有一个自己的配置文件,文件名和用户名一致

  1. [root@fuwuduan vsftpd_user_conf]# vim user1
  2. [root@fuwuduan vsftpd_user_conf]#

  

9.写入配置文件内容

  1. local_root=/home/virftp/user1 #虚拟用户的家目录
  2.  
  3. anonymous_enable=NO #是否允许匿名用户登录
  4.  
  5. write_enable=YES #是否可写
  6.  
  7. local_umask=022 #指定umask值,创建新文件/目录的权限是什么
  8.  
  9. anon_upload_enable=NO #是否允许匿名用户可上传
  10.  
  11. anon_mkdir_write_enable=NO #是否允许匿名用户可写
  12.  
  13. idle_session_timeout=600 #超过600秒需要重新登录
  14.  
  15. data_connection_timeout=120 #数据传输的超时时间
  16.  
  17. max_clients=10 #最大的链接客户多少

10.创建虚拟用户家目录

  1. [root@fuwuduan vsftpd_user_conf]# mkdir /home/virftp/user1
  2. [root@fuwuduan vsftpd_user_conf]# touch /home/virftp/user1/user1.txt
  3. [root@fuwuduan vsftpd_user_conf]# chown -R virftp:virftp /home/virftp/
  1. [root@fuwuduan vsftpd_user_conf]# vim /etc/pam.d/vsftpd (在最开始添加2行)
  2. [root@fuwuduan vsftpd_user_conf]#
  1. #%PAM-1.0
  2. auth sufficient /lib64/security/pam_userdb.so db=/etc/vsftpd/vsftpd_login
  3. account sufficient /lib64/security/pam_userdb.so db=/etc/vsftpd/vsftpd_login
  4. session optional pam_keyinit.so force revoke
  5. auth required pam_listfile.so item=user sense=deny file=/etc/vsftpd/ftpusers onerr=succeed
  6. auth required pam_shells.so
  7. auth include password-auth
  8. account include password-auth
  9. session required pam_loginuid.so
  10. session include password-auth

11.在centos7为64位系统,所以库文件路径为/lib64/security/pam_userdb.so。  (32位操作系统路为/lib/security/pam_userdb.so)

  1. [root@fuwuduan vsftpd_user_conf]# ls /lib64/security/pam_userdb.so
  2. /lib64/security/pam_userdb.so
  3. [root@fuwuduan vsftpd_user_conf]#

  

12.修改全局配置文件,首先编辑vsftpd.conf文件

  1. anonymous_enable=YES YSE更改为NO #不允许匿名用户
  2.  
  3. anon_upload_enable=YES (去掉#,YES改为NO #不允许上传
  4.  
  5. anon_mkdir_write_enable=YES (去掉#,YES改为NO #不允许创建目录
  1. 在最后添加几行:
  2.  
  3. chroot_local_user=YES (将所有用户都限制在主目录)
  4.  
  5. guest_enable=YES (打开虚拟用户映射系统用户)
  6.  
  7. guest_username=virftp (映射到那个系统用户)
  8.  
  9. virtual_use_local_privs=YES (告诉服务我们使用的虚拟用户)
  10.  
  11. user_config_dir=/etc/vsftpd/vsftpd_user_conf (虚拟配置文件所在路径)
  12.  
  13. allow_writeable_chroot=YES (登录以后默认在其家目录中)

13.启动服务,查看进程和监听的端口

  1. [root@fuwuduan vsftpd_user_conf]# /usr/sbin/vsftpd systemctl start vsftpd
  2. [root@fuwuduan vsftpd_user_conf]# ps aux|grep vsftp
  3. root 68172 0.1 0.0 51140 568 ? Ss 16:39 0:00 /usr/sbin/vsftpd
  4. root 68174 0.0 0.0 112680 976 pts/2 R+ 16:39 0:00 grep --color=auto vsftp
  5. [root@fuwuduan vsftpd_user_conf]#

14.查看监听的端口

  1. [root@fuwuduan vsftpd_user_conf]# netstat -lntp
  1. tcp6 0 0 :::21 :::* LISTEN 68172/vsftpd

使用vsftpd搭建ftp服务(下)

1.安装lftp包

  1. [root@fuwuduan vsftpd_user_conf]# yum install -y lftp

2.测试(如有错误可能配置文件中有空格,去掉就可以了)

  1. [root@fuwuduan vsftpd_user_conf]# lftp user1@127.0.0.1
  2. 口令:
  3. lftp user1@127.0.0.1:~> ls
  4. -rw-r--r-- 1 1003 1003 0 Feb 23 07:57 user1.txt
  5. lftp user1@127.0.0.1:/>

3.输入?号可以看到支持的命令

  1. lftp user1@127.0.0.1:/> ?
  2. !<shell-command> (commands)
  3. alias [<name> [<value>]] attach [PID]
  4. bookmark [SUBCMD] cache [SUBCMD]
  5. cat [-b] <files> cd <rdir>
  6. chmod [OPTS] mode file... close [-a]
  7. [re]cls [opts] [path/][pattern] debug [<level>|off] [-o <file>]
  8. du [options] <dirs> exit [<code>|bg]
  9. get [OPTS] <rfile> [-o <lfile>] glob [OPTS] <cmd> <args> help [<cmd>]
  10. history -w file|-r file|-c|-l [cnt] jobs [-v] [<job_no...>]
  11. kill all|<job_no> lcd <ldir>
  12. lftp [OPTS] <site> ln [-s] <file1> <file2> ls [<args>]
  13. mget [OPTS] <files> mirror [OPTS] [remote [local]]
  14. mkdir [-p] <dirs> module name [args] more <files>
  15. mput [OPTS] <files> mrm <files>
  16. mv <file1> <file2> [re]nlist [<args>]
  17. open [OPTS] <site> pget [OPTS] <rfile> [-o <lfile>]
  18. put [OPTS] <lfile> [-o <rfile>] pwd [-p]
  19. queue [OPTS] [<cmd>] quote <cmd>
  20. repeat [OPTS] [delay] [command] rm [-r] [-f] <files>
  21. rmdir [-f] <dirs> scache [<session_no>]
  22. set [OPT] [<var> [<val>]] site <site-cmd> source <file>
  23. torrent [-O <dir>] <file|URL>... user <user|URL> [<pass>] wait [<jobno>]
  24. zcat <files> zmore <files>
  25. lftp user1@127.0.0.1:/>

4.get命令下载一个文件到当前目录  

  1. lftp user1@127.0.0.1:/> get user1.txt
  2. lftp user1@127.0.0.1:/> quit
  3. [root@fuwuduan vsftpd_user_conf]# ls -lt |head
  4. 总用量 4
  5. -rw-r--r--. 1 root root 200 2 23 17:53 user1
  6. -rw-r--r--. 1 root root 0 2 23 15:57 user1.txt
  7. [root@fuwuduan vsftpd_user_conf]#  

xshell使用xftp来传输文件

1.下载Xftp

同时按住crtl+alt+f,下载xftp服务

xshell使用xftp传输文件(xftp使用的也是ssh协议,监听的22端口)

同时按住crtl+alt+f ,xshell会跳出一个

进入下载xftp,会出现一个页面,(按照页面填好的内容写)

这时xshell会把下载地址发到你的邮箱内,在邮箱里点开链接即可。

下载并安装完成后,我们在打开xshell界面,同时按住crtl+alt+f,这时会弹出xftp的界面

左边是我们的windows,右边是我们的linux。

想从Linux把文件拉倒windows或者windows拉倒linux。只需要把文件拉倒对方即可。

使用pure-ftpd搭建ftp服务  

1.安装pure-ftpd包

  1. [root@fuwuduan ~]# yum install -y pure-ftpd

2.修改配置文件

  1. [root@fuwuduan ~]# vim /etc/pure-ftpd/pure-ftpd.conf
  2. [root@fuwuduan ~]#
  3. #PureDB /etc/pure-ftpd/pureftpd.pdb (去掉前面的#号,PureDB用户数据库文件)

3.启动pure-ftpd

  1. [root@fuwuduan ~]# systemctl stop vsftpd
  2. [root@fuwuduan ~]#
  3. [root@fuwuduan ~]# ps aux|grep vsftpd
  4. root 101522 0.0 0.0 112680 968 pts/2 S+ 18:01 0:00 grep --color=auto vsftpd
  5. [root@fuwuduan ~]# systemctl start pure-ftpd
  6. [root@fuwuduan ~]# ps aux|grep vsftpd
  7. root 101557 0.0 0.0 112680 968 pts/2 S+ 18:01 0:00 grep --color=auto vsftpd
  8. [root@fuwuduan ~]# ps aux|grep pure
  9. root 101555 0.3 0.1 200332 1184 ? Ss 18:01 0:00 pure-ftpd (SERVER)
  10. root 101559 0.0 0.0 112680 972 pts/2 R+ 18:01 0:00 grep --color=auto pure
  11. [root@fuwuduan ~]#

4.给pure-ftp的用户创建目录 

  1. [root@fuwuduan ~]# mkdir /data/ftp
  2. [root@fuwuduan ~]# useradd -u 1010 pure-ftp
  3. [root@fuwuduan ~]# chown -R pure-ftp:pure-ftp /data/ftp
  4. [root@fuwuduan ~]# pure-pw useradd ftp_usera -u pure-ftp -d /data/ftp/
  5. Password:
  6. Enter it again:
  7. [root@fuwuduan ~]#

5.测试成功

  1. [root@fuwuduan ~]# touch /data/ftp/123.txt
  2. [root@fuwuduan ~]# lftp ftp_usera@127.0.0.1
  3. 口令:
  4. lftp ftp_usera@127.0.0.1:~> ls
  5. drwxr-xr-x 2 1010 pure-ftp 20 Feb 24 18:18 .
  6. drwxr-xr-x 2 1010 pure-ftp 20 Feb 24 18:18 ..
  7. -rw-r--r-- 1 0 0 0 Feb 24 18:18 123.txt
  8. lftp ftp_usera@127.0.0.1:/>

FTP服务搭建与配置的更多相关文章

  1. linux之FTP服务搭建 ( ftp文件传输协议 VSFTPd虚拟用户)

    FTP服务搭建 配置实验之前关闭防火墙 iptables -F iptables -X iptables -Z systemctl stop firewalld setenforce 0 1.ftp简 ...

  2. syslog-ng日志收集分析服务搭建及配置

    syslog-ng日志收集分析服务搭建及配置:1.网上下载eventlog_0.2.12.tar.gz.libol-0.3.18.tar.gz.syslog-ng_3.3.5.tar.gz三个软件: ...

  3. CentOS7 FTP服务搭建(虚拟用户访问FTP服务)

    概述 最近在搞Oracle在Linux系统下集群,针对Linux系统,笔人也是一片空白.Liunx外部文件的传输,避免不了使用FTP服务,所以现在就整理下,CentOS7环境下,FTP服务的搭建.FT ...

  4. FTP服务-filezilla server 配置

    一.下载Filezilla  Server 官网网址:https://filezilla-project.org/download.php?type=server 二.安装Filezilla  Ser ...

  5. linux下FTP服务搭建(1)

    1.FTP介绍: FTP (File Transfer Protocol,文件传输协议)主要用来文件传输,尤其适用于大文件传输,提供上传下载功能 FTP官方网站:https://filezilla-p ...

  6. FTP服务搭建配置笔记

    1.什么是文件共享服务? 简单来说就是文件域存储块设备可以共享给他人使用. 1.1 实现文件共享服务的三种方式 FTP:属于应用层服务,可以跨平台使用 NFS:属于内核模式,不可以跨平台使用 Samb ...

  7. ftp服务搭建

    文件传输服务 主配置文件目录/etc/vsftpd/vsftpd.conf 首先安装ftp服务器 yum install vsftpd 默认存放文件的目录  /var/ftp/pub 匿名登陆 创建一 ...

  8. NFS服务搭建与配置

    启动NFS SERVER之前,首先要启动RPC服务(CentOS5.8下为portmap服务,CentOS6.6下为rpcbind服务,下同),否则NFS SERVER就无法向RPC服务注册了.另外, ...

  9. Debian系统下的ftp服务搭建

    安装vsftpd服务 $ sudo apt install vsftpd 配置参数 命令输入 $ vim /etc/vsftpd.conf 使用如下配置 # Example config file / ...

随机推荐

  1. [转]Spring Security学习总结一

    [总结-含源码]Spring Security学习总结一(补命名空间配置) Posted on 2008-08-20 10:25 tangtb 阅读(43111) 评论(27)  编辑  收藏 所属分 ...

  2. (Mark)JS中关于闭包

    闭包(Closures) 在ECMAScript中,函数是“第一类”对象.这个名词意味着函数可以作为参数被传递给其他函数使用 (在这种情况下,函数被称为“funargs”——“functional a ...

  3. NFS迁移

    Auth: Jin Date: 20140317 需求将NFS共享IP切换为192.168.201.221,通过192.168.201.0网段提供共享(10.0.0.0和192.168.201.0都能 ...

  4. fedora19/opensuse13.1 配置svn client

    Date: 20140208Auth: Jin 一.install zypper install  subversion yum install  subversion 二.操作 1.将文件check ...

  5. LOG收集系统(一):原日志至收集

    Date: 20140207Auth: Jin 设置一个LOG收集系统1. 收集原生(不解析,不压缩)的业务日志和WEB日志(NGINX,PHP)2. 提供给开发,测试直接阅读和下载 需求分析原生日志 ...

  6. minGW cygwin gnuwin32

    首先,三个的官方网站分别是: minGW:http://www.mingw.org cygwin:  http://www.cygwin.com gnuwin32:  https://sourcefo ...

  7. Linux设备文件简介

    转:http://www.360doc.com/content/11/0418/00/5087210_110410837.shtml 版权声明 本 文作者是一位自由软件爱好者,所以本文虽然不是软件,但 ...

  8. Netty游戏服务器之六服务端登录消息处理

    客户端unity3d已经把消息发送到netty服务器上了,那么ServerHandler类的public void channelRead(ChannelHandlerContext ctx, Obj ...

  9. jquer回显选中select下拉框

    公司使用的框架比较旧,没有使用el等表达式. <% String context = request.getContextPath(); String index = (String)reque ...

  10. 17、percona-toolkit

    pt-ioprofile工具:1.percona-toolkit(在http://www.percona.com下载)2.安装该工具依赖的perl组件yum install perl-IO-Socke ...