(1)pure-ftpd服務的搭建(官網:www.pureftpd.org)
a、首先是下載軟件:
[root@localhost ~]# cd /usr/local/src/ [root@localhost src]# wget http://download.pureftpd.org/pub/pure-ftpd/releases/pure-ftpd-1.0.42.tar.bz2
b、解壓安裝pure-ftpd
[root@localhost src]# tar jxf pure-ftpd-1.0.42.tar.bz2 [root@localhost src]# cd pure-ftpd-1.0.42 [root@localhost pure-ftpd-1.0.42]# ./configure \ --prefix=/usr/local/pureftpd \ --without-inetd \ --with-altlog \ --with-puredb \ --with-throttling \ --with-peruserlimits \ --with-tls [root@localhost pure-ftpd-1.0.42]# make && make install
c、拷貝並且修改配置文件
[root@localhost pure-ftpd-1.0.42]# cd configuration-file [root@localhost pure-ftpd-1.0.42]# mkdir -p /usr/local/pureftpd/etc/ [root@localhost configuration-file]# cp pure-ftpd.conf /usr/local/pureftpd/etc/pure-ftpd.conf [root@localhost configuration-file]# cp pure-config.pl /usr/local/pureftpd/sbin/pure-config.pl [root@localhost configuration-file]# chmod 755 /usr/local/pureftpd/sbin/pure-config.pl
d、在啓動pure-ftpd之前需要先修改配置文件,配置文件爲/usr/local/pureftpd/etc/pure-ftpd.conf,這個拷貝的配置文件可以打開來參考看下,裏面內容很多,不多大多都是註釋語句,如果覺得沒啥用我們就直接清空然後再拷貝配置文件進去,配置文件內容如下:
ChrootEveryone yes BrokenClientsCompatibility no MaxClientsNumber 50 Daemonize yes MaxClientsPerIP 8 VerboseLog no DisplayDotFiles yes AnonymousOnly no NoAnonymous no SyslogFacility ftp DontResolve yes MaxIdleTime 15 PureDB /usr/local/pureftpd/etc/pureftpd.pdb LimitRecursion 3136 8 AnonymousCanCreateDirs no MaxLoad 4 AntiWarez yes Umask 133:022 MinUID 100 AllowUserFXP no AllowAnonymousFXP no ProhibitDotFilesWrite no ProhibitDotFilesRead no AutoRename no AnonymousCantUpload no PIDFile /usr/local/pureftpd/var/run/pure-ftpd.pid MaxDiskUsage 99 CustomerProof yes
e、啓動pure-ftpd服務;如果啓動成功會顯示一行長長的以Running開頭的信息,否則就是錯誤信息
[root@localhost ~]# /usr/local/pureftpd/sbin/pure-config.pl /usr/local/pureftpd/etc/pure-ftpd.conf
這是通過啓動腳本啓動配置文件
(2)創建賬號供其它服務器上傳下載文件
[root@localhost ~]# mkdir /tmp/ [root@localhost ~]# useradd www [root@localhost ~]# chown -R www:www /tmp/ [root@localhost ~]# /usr/local/pureftpd/bin/pure-pw useradd ftp_user1 -uwww -d /tmp/ Password: Enter it again:
其中,-u將虛擬用戶ftp_user1與系統用戶www關聯在一起,也就是說使用ftp_user1賬號登陸ftp後,會以www的身份來讀取文件或下載文件。-d 後邊的目錄爲ftp_user1賬戶的家目錄(其實也就是ftp共享用來上傳下載文件的目錄),這樣可以使ftp_user1只能訪問其家目錄/tmp/. 到這裏還未完成,還有最關鍵的一步,就是創建用戶信息數據庫文件:
[root@localhost ~]# /usr/local/pureftpd/bin/pure-pw mkdb
pure-pw還可以列出當前的ftp賬號(/usr/local/pureftpd/bin/pure-pw list),當然也可以刪除某個賬號(/usr/local/pureftpd/bin/pure-pw userdelete ftp_user1), 我們再創建一個賬號:
[root@localhost ~]# /usr/local/pureftpd/bin/pure-pw useradd ftp_user2 -uwww -d /tmp [root@localhost ~]# /usr/local/pureftpd/bin/pure-pw mkdb
(3)測試pure-ftpd
測試是需要客戶端使用的一種工具爲lftp,這邊需要先安裝下這個工具(yum install -y lftp):
開始進行簡單的測試(可以在本機上測試上傳下載文件):
[root@localhost ~]# touch /data/www/123.txt [root@localhost ~]# lftp [email protected] 口令: lftp [email protected]:~> ls drwxr-xr-x 2 514 www 4096 Jun 12 11:14 . drwxr-xr-x 2 514 www 4096 Jun 12 11:14 .. -rw-r--r-- 1 514 www 0 Jun 12 11:14 123.txt
同時也可以進行本機的文件上傳(put到服務器)和下載(get到本機);
補充:我們除了可以用lftp工具來進行登陸外還可以直接用ftp來進行登錄的,但是登錄方式有點不一樣,用ftp登錄的方式:ftp 127.0.0.1(ftp直接跟IP即可);登錄進去後lftp所能使用的指令和ftp所能使用的指令也是有所差別的,不過差別不是很大。