更换镜像源

由于centos5已经历史久远,内置的镜像源已经不能用。看:

因此,我手工更换了阿里云的源。(ps:我本来是想用网易的源,但不知为什么,这个源在安装vsftpd时提示http 404错误)

  1. 备份你的原镜像文件,以免出错后可以恢复。
mv /etc/yum.repos.d/CentOS-Base.repo /etc/yum.repos.d/CentOS-Base.repo.backup  
  1. 下载新的CentOS-Base.repo 到/etc/yum.repos.d/
wget -O /etc/yum.repos.d/CentOS-Base.repo http://mirrors.aliyun.com/repo/Centos-5.repo  
  1. 运行yum makecache生成缓存
yum makecache  

原文地址


安装vsftpd

  1. 在终端运行下面的命令:
yum install vsftpd  
  1. 安装完成后,通过service vsftpd status命令查看,可知服务先是被禁用的,因此我们需要手动启动:
service vsftpd start
  1. 设置在下次启动时自动启用,命令chkconfig:

简单使用

此时,其实你已经可以使用ftp了,通过命令ftp ftp_server_ip_address和用户名密码便可以登录。此时,你可以通过两种方式登录:

  • 匿名登录:账号anonymous,密码为空或者你随意输入。

  • 用户名密码登录,这个用户名和密码是由ftp服务器管理员创建的。比如我用useradd命令创建了一个普通用户busui。注意:现在的ftp服务器由于没有经过任何安全设置,所以普通用户busui拥有的权限非常大。等下面会会讲如何通过修改配置文件vsftpd.conf来提高ftp的安全。


安全配置

所谓配置,就是对vsftpd配置文件/etc/vsftpd/vsftpd.conf的修改(注意,不同发行版配置文件路径不一样),使得ftp服务器按照你意愿的权限/方式运行。

  • 在linux里有这么一个习俗:更改配置文件时,先备份,所以,我们先备份:
cp /etc/vsftpd/vsftpd.conf /etc/vsftpd/vsftpd.conf.bak
  • 接下来,打开/etc/vsftpd/vsftpd.conf:
anonymous_enable=NO     ### 禁用匿名登录
local_enable=YES        ### 允许本地用户登录
write_enable=YES        ### 允许对文件系统做改动的 FTP 命令
local_umask=022         ### 本地用户创建文件所用的 umask 值
dirmessage_enable=YES   ### 当用户首次进入一个新目录时显示一个消息
xferlog_enable=YES      ### 用于记录上传、下载细节的日志文件
connect_from_port_20=YES### 使用端口 20 (ftp-data)用于 PORT 风格的连接
xferlog_std_format=YES  ### 使用标准的日志格式
listen=YES              ### 让 vsftpd 运行在独立模式
listen_ipv6=NO          ### 将vsftpd监听 IPv6停止,因为我主机是ipv4
pam_service_name=vsftpd ###  vsftpd 使用的 PAM 服务名
userlist_enable=YES     ### vsftpd 支持载入用户列表
tcp_wrappers=YES        ### 使用 tcp wrappers
  • 跟着,便是重启ftp,使得配置文件生效:service vsftpd restart:

    这里,我也遇到了一点小麻烦,由于跟着这篇文章操作,糊里糊涂地也跟着将listen设置为NO,将listen_ipv6=YES。看:

    所以,便遇到了这样的错误:

    原因分析:

    我看了一下参考文章的出处,才知道原来是从外国翻译回来的。要知道,外国(主要指美国)ipv6基本普及了,天朝还在用ipv4,所以,这样改:listen=YESlisten_ipv6=NO就万事大吉了。 刚开始我还以为是端口冲突了呢,想查看一下日志文件,却连日志都没有看到。(估计没生成)

    对于listen参数,在conf文件中注释是这样的:

    当启用“listen”指令时,vsftpd以独立模式运行,并在IPv4套接字(即ip和端口,一般说侦听某个端口)上侦听。 该指令不能与listen_ipv6指令一起使用。

  • 添加用户,测试:
    useradd -m -c “Busui Kadiven, student” -s /bin/bash busui
    设置密码passwd Busui,之后,便可以启动ftp服务并且登录。此时,除了被我们禁止的匿名用户,这台机器的所有其他用户都可以登录到你的ftp服务器上。所以,要介绍一种机制,可以让你控制谁有登录你的ftp服务器的权限。

  • 现在基于用户列表文件 /etc/vsftpd.userlist 来配置 FTP 来允许/拒绝用户的访问:
    默认情况下,如果设置了 userlist_enable=YES,当 userlist_deny 选项设置为 YES 的时候,userlist_file=/etc/vsftpd.userlist 中列出的用户被拒绝登录。然而, 更改配置为 userlist_deny=NO,意味着只有在userlist_file=/etc/vsftpd.userlist 显式指定的用户才允许登录。将下列命令添加到/etc/vsftpd/vsftpd.conf文件中,保存并重启vsftpd服务:
userlist_enable=YES
userlist_file=/etc/vsftpd.userlist
userlist_deny=NO   

现在假如我的电脑上有这些用户:Busui,test,jack,test1,但只有Busui和test1在vsftpd.userlist文件中,所以,只有Busui和test1有登录的权限。


设置chroot jail(参看这里)

到了这里,其实还有一些很重要的东西要说,参考这里。chroot jail主要有三个参数:
1,chroot_local_user: 是否将所有用户限制在主目录,YES为启用 NO禁用.(该项默认值是NO,即在安装vsftpd后不做配置的话,ftp用户是可以向上切换到要目录之外的)

  • 设置为YES时:
  • 设置为NO或注释掉时

2,chroot_list_enable:是否启动限制用户的名单 YES为启用 NO禁用(包括注释掉也为禁用)
3,chroot_list_file=/etc/vsftpd/chroot_list:是否限制在主目录下的用户名单,至于是限制名单还是排除名单,这取决于chroot_local_user的值. chroot_local_user总是一个全局性的设定,其为YES时,全部用户被锁定于主目录,其为NO时,全部用户不被锁定于主目录。那么我们势必需要在全局设定下能做出一些“微调”,即,我们总是需要一种“例外机制",所以当chroot_list_enable=YES时,表示我们“需要例外”。而”例外“的含义总是有一个上下文的,即,当”全部用户被锁定于主目录“时(即chroot_local_user=YES),"例外"就是:不被锁定的用户是哪些;当"全部用户不被锁定于主目录"时(即chroot_local_user=NO),"例外"“就是:要被锁定的用户是哪些。这样解释和记忆两者之间的关系就很清晰了!


结尾

到了这里,基本是结束了,关于centos7还有更详细的设置,请参考这里。

转载于:https://www.cnblogs.com/busui/p/6885881.html

Centos5搭建vsftpd服务相关推荐

  1. CentOS 搭建 Vsftpd 服务,一次性成功,收藏了!

    点击下方"民工哥技术之路",选择"设为星标" 回复"1024"获取独家整理的学习资料! 文件传输协议 FTP 文件传输协议(FTP)是一种基 ...

  2. centos7 搭建vsftpd服务并锁定用户的家目录

    1.安装vsftpd服务 yum install vsftpd -y 2.创建用户 useradd vsftp -s /sbin/nologin ####添加用户,并且这个用户没有登陆系统的权限pas ...

  3. ubuntu vsftpd虚拟用户配置/ubuntu12.04上搭建vsftpd服务示例linux

    转自这里 在ubuntu中安装完vsftpd后,安装libdb4.6-util: 复制代码 代码示例: sudo apt-get install db4.6-util 在etc下面建立目录vsftpd ...

  4. 银河麒麟V10 SP2搭建vsftp服务

    vsftpd 的作用: 提供各主机之间文件共享服务,可以应用在互联网中 能支持上传下载目录,安全性比tftp高,功能更强大,双向传输,不受操作系统限制,只要支持vsftpd协议,就是vsftpd服务器 ...

  5. java ftp返回到根目录,Linux下搭建ftp服务,更改根目录到大存储到位置

    Linux下ftp服务可以通过搭建vsftpd服务来实现,以CentOS为例,首先查看系统中是否安装了vsftpd,可以通过执行命令 rpm -qa | grep vsftpd 来查看是否安装相应的包 ...

  6. 15.1-15.3 FTP,使用vsftpd搭建FTP服务

    FTP介绍 FTP是File Transfer Protocol(文件传输协议,简称文传协议)的英文简称,用于在Internet上控制文件的双向传输. FTP的主要作用就是让用户连接一个远程计算机(这 ...

  7. 在Linux4.1.15上使用vsftpd搭建FTP服务问题解析

    在Linux4.1.15上使用vsftpd搭建FTP服务问题解析 BUG1:在windows系统登陆arm Linux FTP时,显示"服务器不允许匿名登录,或者不接受该电子邮件地址&quo ...

  8. CentOS5快速搭建vsftp服务

    既然强调快速, 我们就马上开始,环境是centos5安装vsftpd,用了半天做了测试与修改,终于完成.   第一步:安装vsftpd,在终端允许 # yum -y install vsftpd 没什 ...

  9. vsftpd服务的搭建

    1.vsftpd介绍 vsftpd:是非常安全的ftp守护进程(Very secure ftp Daemon). 进程:正在进行(运行running)的程序. 守护进程Daemon:网络服务类的程序都 ...

最新文章

  1. window.open使用中遇到的问题
  2. MySQL -- 行转列 -- GROUP_CONCAT -- MAX(CASE WHEN THEN)
  3. 对Excel或者其他office操作推荐使用NPOI
  4. HDOJ_ACM_统计问题
  5. Eclipse SVN插件版本
  6. 中美线径对照表_导线截面与线径对照表
  7. 基于SIFT特征提取的图像拼接算法matlab仿真
  8. NFC读卡MS522|CV520
  9. 八类网线和七类网线的区别_7类网线和8类网线到底有何不同?
  10. 关于msp430的BSL下载
  11. 音质好的蓝牙耳机有哪些?音质好的蓝牙耳机推荐
  12. BIDI算法 (Unicode Bidirectional Algorithm)
  13. 互联网赚钱发展趋势,网赚案例精准分析
  14. App Store上推广App的实战经验
  15. Android 强制应用全局横屏或竖屏
  16. 2020年浙江机器人公司十大品牌排名
  17. HCIA网络基础11-IP路由原理及静态路由
  18. 51单片机学习笔记-3模块化编程
  19. C#利用方法重载实现2个整数,2个双精度数,3个整数中求最大值。由于设计了方法重载,系统会根据调用方法时传递的实参类型和个数而自动选择相应的方法来求最大数。
  20. 生成二维码或条形码JavaScript脚本库

热门文章

  1. Node.js 使用webpack-dev-server工具运行项目实现自动打包编译的功能
  2. Node.js 执行webpack命令出现的错误
  3. IDEA配置自定义maven库
  4. 大一暑假第三周学习体会
  5. 外卖(food) 洛谷4040宅男计划 三分套二分贪心
  6. Python 正则表达式 匹配任意字符
  7. 每天一个linux命令---导出到文件
  8. nginx日志分割脚本
  9. 念 2013-8-6 (写于爸爸走之后,之七)
  10. C02-程序设计基础提高班(C++)第7周上机任务-指针