热门标签 | HotTags
当前位置:  开发笔记 > 后端 > 正文

freebsd平台下ftp服务架设的全程指南

开始安装本文要介绍的是基于FreeBSD平台的FTP服务的配置过程。第一步:下载FTP服务源代码包。proftpd-1.2.7.tar.gz下载地址:ftp://ftp.servus.at/ProFTPD/distrib/source/proftpd-1.2.7.tar.gzproftpd-mod-quotatab-1
开始安装
    本文要介绍的是基于FreeBSD平台的FTP服务的配置过程。

    第一步:下载FTP服务源代码包。    
proftpd-1.2.7.tar.gz下载地址:ftp://ftp.servus.at/ProFTPD/distrib/source/proftpd-1.2.7.tar.gz
proftpd-mod-quotatab-1.2.4.tar.gz下载地址:http://www.castaglia.org/proftpd/


    第二步:解压缩源代码包。
命令格式为:
    # cd /home/ylf/app                 # “/home/ylf/app”为FTP上传目录
    # tar zxvf proftpd-1.2.7.tar.gz
    # tar zxvf proftpd-mod-quotatab-1.2.4.tar.gz
然后进入“mod-quotatab”目录,把“mod_quotatab”中的文件拷贝到“proftpd”的“modules” 目录下,命令格式为:
    # cd mod_quotatab
    # cp * ../proftpd-1.2.7/modules 

    第三步:修改位于proftpd-1.2.7/contrib 目录下的“mod_sql_mysql.c”文件。
命令格式为:
    # cd /home/ylf/app/proftpd-1.2.7/contrib.
    # vi mod_sql_mysql.c
    在此文件中找到“#include ”字段,然后将其改为自己的实际路径,比如:
    #include


编译安装proftpd
    第四步:编译安装proftpd。命令格式为:
    # cd /home/ylf/app/proftpd-1.2.7
    #./configure--prefix=/usr/local/proftpd
--with-modules=mod_sql:mod_sql_mysql:mod_quotatab:mod_quotatab_sql
    --with-includes=/usr/local/include/mysql
    --with-libraries=/usr/local/lib/mysql
    # make
    # make install

    第五步:进入配置文件所在目录,备份原有配置文件。命令格式为:
    # cd /usr/local/proftpd/etc            #进入配置文件所在目录
    # mv proftpd.conf proftpd.conf.bak    #备份原有配置文件

    第六步:编辑新的配置文件“proftpd.conf”(可以参照原配置文件进行)。
以下列举一些主要应配置的地方:
    # Port 21 is the standard FTP port.               #配置FTP服务端口号
    MaxClientsPerHost 3                         #设置每台主机最多并发连接数
    DefaultRoot ~ ftpusers
    DefaultRoot ~ FTPGRP                       #将用户限制在自己的主目录下
    QuotaDirectoryTally on                       #启用磁盘限额
    < Anonymous /ftp> 
    User ftp 中国网管联盟
    Group ftpusers                              #设置匿名用户目录为“/ftp”
    SQLConnectInfo FTP@localhost root 123456     ## 设置数据库联接信息。FTP为数据库名,localhost为主机名,root为连接数据库的用户名,#123456为密码。

建立数据库和表
    第七步:为ftp用户建立相应的数据库和表。
    1. 进入mysql数据库命令状态并建立数据库FTP
    # mysql ?p
    CREATE DATABASE FTP 
    2.接着在这个数据库中建立一个用户表FTPUSERS,命令格式为:
    use FTP 
    create table FTPUSERS (
    userid TEXT NOT NULL,
    passwd TEXT NOT NULL,
    uid INT NOT NULL,
    gid INT NOT NULL,
    homedir TEXT,
    shell TEXT
    ) 
关于此用户表的说明:此表格是为用户认证准备的,因此必不可少。其中“userid”是用做FTP服务的用户名 “passwd”是指此用户的密码 这两个字段是必不可少的。另外“uid”是系统用户的ID,也就是所映射的系统用户 “gid”是所属系统组的ID “homedir”是该用户所在的HOME目录 “shell”是为该用户指定相应的shell。当然也可以建立更多的字段,例如:用来记录用户登录次数的count,或者是日期的date等等,这里就不一一详述了,我们只了解主要部分。


    第八步:为FTP用户建立相应的系统用户(本例是将整个FTP服务只提供一个有效的系统用户FTPUSR和组FTPGRP)。
    # pw groupadd FTPGRP -g 2001                                     # 建立FTPGRP组
    # pw adduser FTPUSR -u 2001 -g 2001 -d /home/FTP -s /sbin/nologin       # 建立FTPUSR用户
    # mkdir /home/FTP
    # chown FTPUSR /home/FTP
    # chgrp FTPGRP /home/FTP                                # 为FTPUSR用户建立HOME目录,并把所有的FTP user 活动空间全放在此目录下

    第九步:添加测试用户(本例为“tryuser”)。
    use FTP
    INSERT INTO FTPUSERS (userid, passwd, uid, gid, homedir, shell)
    valueS (’tryuser’, ’ArrayArrayArrayArrayArrayArray’, ’2001’, ’2001’, ’/home/FTP/user1’, ’’ ) 

配置完成
    第十步:对此测试用户设置磁盘限额。
    INSERT INTO `quotalimits` ( `name` , `quota_type` , `per_session` , `limit_type` , `bytes_in_avail` , `bytes_out_avail` , `bytes_xfer_avail` , `files_in_avail` , `files_out_avail` , `files_xfer_avail` )
VALUES (’ tryuser ’, ’user’, ’false’, ’soft’, ’20240000’, ’0’, ’4048000’, ’1000’, ’0’, ’20’) 
解释:对此测试用户给予20M空间,最多能上传1000个文件到服务器上,文件传输流量为40M,只能传输20个文件

第十一步:设置匿名登录,最终完成配置。

    对于匿名登录用户,建议单独为其划分硬盘分区,所有的匿名用户文件都放在这个单独的分区里。
    1. 添加匿名系统用户组users1和匿名用户ftp1。
    # pw groupadd users1
    # pw useradd ftp1 -g users1 -d /ftp -s /sbin/nologin          # “/ftp”为匿名用户所在分区
    2. 在“/ftp”分区下建立匿名用户目录并设置相应权限。
    # mkdir /ftp/incoming
    # mkdir /ftp/pub
    # mkdir /ftp/bin
    # mkdir /ftp/etc
    # chown ftp1 /ftp/incoming
    # chgrp users1 /ftp/incoming

    3.测试此匿名用户。
在浏览器地址栏输入配置好的ftp服务器地址,如果能够正常显示刚才建立的几个目录,而且进入incoming目录可以在里面新建文件夹或文件,即表示匿名用户“ftp1”建立成功。OK,至此,FTP服务的配置过程也圆满结束。如果大家在理解过程中有什么困难,可以参阅相关资料或给我们留言交流。


推荐阅读
  • 本文介绍了如何使用php限制数据库插入的条数并显示每次插入数据库之间的数据数目,以及避免重复提交的方法。同时还介绍了如何限制某一个数据库用户的并发连接数,以及设置数据库的连接数和连接超时时间的方法。最后提供了一些关于浏览器在线用户数和数据库连接数量比例的参考值。 ... [详细]
  • 本文介绍了在开发Android新闻App时,搭建本地服务器的步骤。通过使用XAMPP软件,可以一键式搭建起开发环境,包括Apache、MySQL、PHP、PERL。在本地服务器上新建数据库和表,并设置相应的属性。最后,给出了创建new表的SQL语句。这个教程适合初学者参考。 ... [详细]
  • 推荐一个ASP的内容管理框架(ASP Nuke)的优势和适用场景
    本文推荐了一个ASP的内容管理框架ASP Nuke,并介绍了其主要功能和特点。ASP Nuke支持文章新闻管理、投票、论坛等主要内容,并可以自定义模块。最新版本为0.8,虽然目前仍处于Alpha状态,但作者表示会继续更新完善。文章还分析了使用ASP的原因,包括ASP相对较小、易于部署和较简单等优势,适用于建立门户、网站的组织和小公司等场景。 ... [详细]
  • 搭建Windows Server 2012 R2 IIS8.5+PHP(FastCGI)+MySQL环境的详细步骤
    本文详细介绍了搭建Windows Server 2012 R2 IIS8.5+PHP(FastCGI)+MySQL环境的步骤,包括环境说明、相关软件下载的地址以及所需的插件下载地址。 ... [详细]
  • 本文介绍了如何在MySQL中将零值替换为先前的非零值的方法,包括使用内联查询和更新查询。同时还提供了选择正确值的方法。 ... [详细]
  • PHP设置MySQL字符集的方法及使用mysqli_set_charset函数
    本文介绍了PHP设置MySQL字符集的方法,详细介绍了使用mysqli_set_charset函数来规定与数据库服务器进行数据传送时要使用的字符集。通过示例代码演示了如何设置默认客户端字符集。 ... [详细]
  • 在数据分析工作中,我们通常会遇到这样的问题,一个业务部门由若干业务组构成,需要筛选出每个业务组里业绩前N名的业务员。这其实是一个分组排序的 ... [详细]
  • 本文介绍了在Hibernate配置lazy=false时无法加载数据的问题,通过采用OpenSessionInView模式和修改数据库服务器版本解决了该问题。详细描述了问题的出现和解决过程,包括运行环境和数据库的配置信息。 ... [详细]
  • Oracle Database 10g许可授予信息及高级功能详解
    本文介绍了Oracle Database 10g许可授予信息及其中的高级功能,包括数据库优化数据包、SQL访问指导、SQL优化指导、SQL优化集和重组对象。同时提供了详细说明,指导用户在Oracle Database 10g中如何使用这些功能。 ... [详细]
  • 在说Hibernate映射前,我们先来了解下对象关系映射ORM。ORM的实现思想就是将关系数据库中表的数据映射成对象,以对象的形式展现。这样开发人员就可以把对数据库的操作转化为对 ... [详细]
  • 本文详细介绍了MysqlDump和mysqldump进行全库备份的相关知识,包括备份命令的使用方法、my.cnf配置文件的设置、binlog日志的位置指定、增量恢复的方式以及适用于innodb引擎和myisam引擎的备份方法。对于需要进行数据库备份的用户来说,本文提供了一些有价值的参考内容。 ... [详细]
  • 本文由编程笔记小编整理,介绍了PHP中的MySQL函数库及其常用函数,包括mysql_connect、mysql_error、mysql_select_db、mysql_query、mysql_affected_row、mysql_close等。希望对读者有一定的参考价值。 ... [详细]
  • 这是原文链接:sendingformdata许多情况下,我们使用表单发送数据到服务器。服务器处理数据并返回响应给用户。这看起来很简单,但是 ... [详细]
  • 本文介绍了使用AJAX的POST请求实现数据修改功能的方法。通过ajax-post技术,可以实现在输入某个id后,通过ajax技术调用post.jsp修改具有该id记录的姓名的值。文章还提到了AJAX的概念和作用,以及使用async参数和open()方法的注意事项。同时强调了不推荐使用async=false的情况,并解释了JavaScript等待服务器响应的机制。 ... [详细]
  • 阿,里,云,物,联网,net,core,客户端,czgl,aliiotclient, ... [详细]
author-avatar
主播新鲜看连
这个家伙很懒,什么也没留下!
PHP1.CN | 中国最专业的PHP中文社区 | DevBox开发工具箱 | json解析格式化 |PHP资讯 | PHP教程 | 数据库技术 | 服务器技术 | 前端开发技术 | PHP框架 | 开发工具 | 在线工具
Copyright © 1998 - 2020 PHP1.CN. All Rights Reserved | 京公网安备 11010802041100号 | 京ICP备19059560号-4 | PHP1.CN 第一PHP社区 版权所有