Linux安装ftp组件

1  安装vsftpd组件

安装完后,有/etc/vsftpd/vsftpd.conf文件,是vsftp的配置文件。

  1. [root@bogon ~]# yum -y install vsftpd

2  添加一个ftp用户

此用户就是用来登录ftp服务器用的。

  1. [root@bogon ~]# useradd ftpuser

这样一个用户建完,可以用这个登录,记得用普通登录不要用匿名了。登录后默认的路径为 /home/ftpuser.

3  给ftp用户添加密码。

  1. [root@bogon ~]# passwd ftpuser

输入两次密码后修改密码。

4  防火墙开启21端口

因为ftp默认的端口为21,而centos默认是没有开启的,所以要修改iptables文件

  1. [root@bogon ~]# vim /etc/sysconfig/iptables

在行上面有22 -jACCEPT 下面另起一行输入跟那行差不多的,只是把22换成21,然后:wq保存。

还要运行下,重启iptables

  1. [root@bogon ~]# service iptables restart

5  修改selinux

外网是可以访问上去了,可是发现没法返回目录(使用ftp的主动模式,被动模式还是无法访问),也上传不了,因为selinux作怪了。

修改selinux:

执行以下命令查看状态:

  1. [root@bogon ~]# getsebool -a | grepftp
  2. allow_ftpd_anon_write --> off
  3. allow_ftpd_full_access --> off
  4. allow_ftpd_use_cifs --> off
  5. allow_ftpd_use_nfs --> off
  6. ftp_home_dir --> off
  7. ftpd_connect_db --> off
  8. ftpd_use_passive_mode --> off
  9. httpd_enable_ftp_server --> off
  10. tftp_anon_write --> off
  11. [root@bogon ~]#

执行上面命令,再返回的结果看到两行都是off,代表,没有开启外网的访问

  1. [root@bogon ~]# setsebool -P allow_ftpd_full_access on
  2. [root@bogon ~]# setsebool -P ftp_home_dir on

这样应该没问题了(如果,还是不行,看看是不是用了ftp客户端工具用了passive模式访问了,如提示Entering Passive mode,就代表是passive模式,默认是不行的,因为ftp passive模式被iptables挡住了,下面会讲怎么开启,如果懒得开的话,就看看你客户端ftp是否有port模式的选项,或者把passive模式的选项去掉。如果客户端还是不行,看看客户端上的主机的电脑是否开了防火墙,关吧)

FileZilla的主动、被动模式修改:

菜单:编辑→设置

6  关闭匿名访问

修改/etc/vsftpd/vsftpd.conf文件:

重启ftp服务:

  1. [root@bogon ~]# service vsftpd restart

7  开启被动模式

默认是开启的,但是要指定一个端口范围,打开vsftpd.conf文件,在后面加上

  1. pasv_min_port=30000
  2. pasv_max_port=30999

表示端口范围为30000~30999,这个可以随意改。改完重启一下vsftpd

由于指定这段端口范围,iptables也要相应的开启这个范围,所以像上面那样打开iptables文件。

也是在21上下面另起一行,更那行差不多,只是把21 改为30000:30999,然后:wq保存,重启下iptables。这样就搞定了。

8  设置开机启动vsftpd ftp服务

    1. [root@bogon ~]# chkconfig vsftpd on

最新文章

  1. oracle11g interval(numtoyminterval())自动创建表分区
  2. Cesium应用篇:2影像服务(上)
  3. SQL Server 临时禁用和启用所有外键约束(高版本向低版本迁移数据)
  4. SQL CURSOR
  5. css学习笔记 4
  6. EF6.0批量插入
  7. 5ucms后台调用标签
  8. Android开发自学笔记—1.1(番外)AndroidStudio常用功能介绍
  9. Unity3D外包
  10. asp.net 页面局部刷新
  11. spark在eclipse上配置
  12. windbg命令分类与概述
  13. 无法建立到http://localhost:6080/arcgis/manager/的连接
  14. Unity的Lerp函数实现缓动
  15. 加快modelsim仿真速度的方法(原创)
  16. Android Studio下载及离线升级方法
  17. HttpClient 发送图片
  18. java中多种写文件方式的效率对比实验
  19. none 和 host 网络的适用场景 - 每天5分钟玩转 Docker 容器技术(31)
  20. 解决Maven web 项目 Cannot detect Web Project version. Please specify version of Web Project through ... 的错误

热门文章

  1. Django项目部署:使用uwsgi和nginx的方式
  2. (47)zabbix报警媒介:Ez Texting
  3. python计算机基础(一)
  4. menu JPopupMenu JTabbedPane
  5. Html + Css 小知识点
  6. Python内置函数7
  7. PHP “引号兄弟”
  8. c标准库 徐明远 背景基础
  9. Django之model admin自定义后台管理
  10. poj2104&&poj2761 (主席树&&划分树)主席树静态区间第k大模板