Ubuntu 中怎么利用VSFTP搭建FTP服務(wù)器,很多新手對(duì)此不是很清楚,為了幫助大家解決這個(gè)難題,下面小編將為大家詳細(xì)講解,有這方面需求的人可以來(lái)學(xué)習(xí)下,希望你能有所收獲。
專注于為中小企業(yè)提供網(wǎng)站制作、網(wǎng)站設(shè)計(jì)服務(wù),電腦端+手機(jī)端+微信端的三站合一,更高效的管理,為中小企業(yè)安義免費(fèi)做網(wǎng)站提供優(yōu)質(zhì)的服務(wù)。我們立足成都,凝聚了一批互聯(lián)網(wǎng)行業(yè)人才,有力地推動(dòng)了千余家企業(yè)的穩(wěn)健成長(zhǎng),幫助中小企業(yè)通過(guò)網(wǎng)站建設(shè)實(shí)現(xiàn)規(guī)模擴(kuò)充和轉(zhuǎn)變。
1、安裝vsftpd
終端輸入sudo apt-get install vsftpd
安裝之后會(huì)在/home/下建立一個(gè)ftp目錄,訪問(wèn)下可以看到一個(gè)空白內(nèi)容的ftp空間。
默認(rèn)設(shè)置下需要匿名用戶不可以登錄
2、設(shè)置 vsftpd.conf文件
修改之前最好先備份這個(gè)文件:sudo cp /etc/vsftpd.conf /etc/vsftpd.conf.old
參數(shù)意義:
Anonymous_enable=yes (允許匿名登陸)
Dirmessage_enable=yes (切換目錄時(shí),顯示目錄下.message的內(nèi)容)
Local_umask=022 (FTP上本地的文件權(quán)限,默認(rèn)是077)
Connect_form_port_20=yes (啟用FTP數(shù)據(jù)端口的數(shù)據(jù)連接)*
Xferlog_enable=yes (激活上傳和下傳的日志)
Xferlog_std_format=yes (使用標(biāo)準(zhǔn)的日志格式)
Ftpd_banner=XXXXX (歡迎信息)
Pam_service_name=vsftpd (驗(yàn)證方式)*
Listen=yes (獨(dú)立的VSFTPD服務(wù)器)*
功能:只能連接FTP服務(wù)器,不能上傳和下傳
注:其中所有和日志歡迎信息相關(guān)連的都是可選項(xiàng),打了星號(hào)的無(wú)論什么帳戶都要添加,是屬于FTP的基本選項(xiàng)
開(kāi)啟匿名FTP服務(wù)器上傳權(quán)限:
Anon_upload_enable=yes (匿名帳號(hào)開(kāi)放上傳權(quán)限)
Anon_mkdir_write_enable=yes (匿名帳號(hào)可創(chuàng)建目錄的同時(shí)可以在此目錄中上傳文件)
Write_enable=yes (開(kāi)放本地用戶寫(xiě)的權(quán)限)
Anon_other_write_enable=yes (匿名帳號(hào)可以有刪除的權(quán)限)
Anon_world_readable_only=no(開(kāi)啟匿名服務(wù)器下傳的權(quán)限)
普通用戶FTP服務(wù)器的連接(獨(dú)立服務(wù)器)配置:
Local_enble=yes (本地帳戶能夠登陸)
Write_enable=no (本地帳戶登陸后無(wú)權(quán)刪除和修改文件)
功能:可以用本地帳戶登陸vsftpd服務(wù)器,有下載上傳的權(quán)限
注:在禁止匿名登陸的信息后匿名服務(wù)器照樣可以登陸但不可以上傳下傳
用戶登陸限制進(jìn)其它的目錄,只能進(jìn)它的主目錄:
設(shè)置所有的本地用戶都執(zhí)行chroot
Chroot_local_user=yes (本地所有帳戶都只能在自家目錄)
設(shè)置指定用戶執(zhí)行chroot
Chroot_list_enable=yes (文件中的名單可以調(diào)用)
Chroot_list_file=/任意指定的路徑/vsftpd.chroot_list
注意:vsftpd.chroot_list 是沒(méi)有創(chuàng)建的需要自己添加,要想控制帳號(hào)就直接在文件中加帳號(hào)即可
限制本地用戶訪問(wèn)FTP:
Userlist_enable=yes (用userlistlai 來(lái)限制用戶訪問(wèn))
Userlist_deny=no (名單中的人不允許訪問(wèn))
Userlist_file=/指定文件存放的路徑/ (文件放置的路徑)
注:開(kāi)啟userlist_enable=yes匿名帳號(hào)不能登陸
安全選項(xiàng)
Idle_session_timeout=600(秒) (用戶會(huì)話空閑后10分鐘)
Data_connection_timeout=120(秒) (將數(shù)據(jù)連接空閑2分鐘斷)
Accept_timeout=60(秒) (將客戶端空閑1分鐘后斷)
Connect_timeout=60(秒) (中斷1分鐘后又重新連接)
Local_max_rate=50000(bite) (本地用戶傳輸率50K)
Anon_max_rate=30000(bite) (匿名用戶傳輸率30K)
Pasv_min_port=50000 (將客戶端的數(shù)據(jù)連接端口改在
Pasv_max_port=60000 50000—60000之間)
Max_clients=200 (FTP的最大連接數(shù))
Max_per_ip=4 (每IP的最大連接數(shù))
Listen_port=5555 (從5555端口進(jìn)行數(shù)據(jù)連接)
查看誰(shuí)登陸了FTP,并殺死它的進(jìn)程
ps –xf |grep ftp
kill 進(jìn)程號(hào)
3、配置本地組訪問(wèn)的FTP
首先創(chuàng)建用戶組 test和FTP的主目錄
groupadd test
mkdir /tmp/test
然后創(chuàng)建用戶
useradd -G test –d /tmp/test –M usr1
注:G:用戶所在的組
d:表示創(chuàng)建用戶的自己目錄的位置給予指定
M:不建立默認(rèn)的自家目錄,也就是說(shuō)在/home下沒(méi)有自己的目錄
useradd –G test –d /tmp/test –M usr2
接著改變文件夾的屬主和權(quán)限
chown usr1.test /tmp/test ----這表示把/tmp/test的屬主定為usr1
chmod 750 /tmp/test ----7表示wrx 5表示rx 0表示什么權(quán)限都沒(méi)有
這個(gè)實(shí)驗(yàn)的目的就是usr1有上傳、刪除和下載的權(quán)限,而usr2只有下載的權(quán)限沒(méi)有上傳和刪除的權(quán)限
主配置文件vsftpd.conf要確定local_enable=yes、write_enable=yes、chroot_local_usr=yes這三個(gè)選項(xiàng)是有的哦!
4、配置獨(dú)立FTP的服務(wù)器的非端口標(biāo)準(zhǔn)模式進(jìn)行數(shù)據(jù)連接
在VSFTPD_CONF中添加Listen_port=33333
5、配置單獨(dú)的虛擬FTP,使用虛擬FTP用戶,并使建立的四個(gè)帳戶中有不同的權(quán)限
(兩個(gè)有讀目錄的權(quán)限,一個(gè)有瀏覽、上傳、下載的權(quán)限,一個(gè)有瀏覽、下載、刪除和改文件名的權(quán)限)
1>配置網(wǎng)卡
第一塊網(wǎng)卡地址是10.2.3.4 掩碼是255.255.0.0
ifconfig eth0:1 211.131.4.253 netmask 255.255.255.0 up
2>寫(xiě)入/etc/sysconfig中(為了重起后IP地址不會(huì)丟失)
cd /etc/sysconfig/network-scripts
cp ifcfg-eth0 ifcfg-eth0:1
vi ifcfg-eth0:1在其中修改內(nèi)容如下
DEVICE=eth0:1
BROADCAST=211.131.4.255
HWADDR=該網(wǎng)卡的MAC地址
IPADDR=211.131.4.253
NETMASK=255.255.255.0
NETWORK=211.131.4.0
ONBOOT=yes
TYPE=Ethernet
wq退出
3>進(jìn)入vsftpd.conf所在的文件夾cp vsftpd.conf vsftpd2.conf
修改vsftpd.conf添加以下信息
Listen_address=10.2.3.4
修改vsftpd2.conf添加以下信息
Listen_address=211.131.4.253
Ftpd_banner=this is a virtual ftp test
到此虛擬的FTP服務(wù)器建立好了
4>建立logins.txt
vi /tmp/logins.txt
添加入下信息:
longlei------------用戶名
longlei------------密碼
zhangweibo
zhangweibo
jinhui
jinhui
lxp
lxp
格式:一個(gè)用戶名,一個(gè)密碼
5>建立訪問(wèn)者的口令庫(kù)文件,然后修改其權(quán)限
db_load –T –t hash –f /tmp/logins.txt /etc/vsftpd_login.db
6>進(jìn)如/etc/pam.d/中創(chuàng)建
在中添加如下信息
auth required /lib/security/pam_userdb.so db=/etc/vsftpd_login
account required /lib/security/pam_userdb.so db=/etc/vsftpd_login
7>在/var/ftp/創(chuàng)建目錄并改變其屬性和它的屬主
useradd -d /var/ftp/test qiang
chmod 700 /var/ftp/test
在目錄中添加test_file測(cè)試文件
8>進(jìn)入vsftpd2.conf修改其中的信息(可以是)
Listen_yes
Anonymous_enable=no
Local_enable=yes
Write_enable=no
Anon_upload_enable=no
Anon_mkdir_write_enable=no
Anon_other_write_enable=no
Chroot_local_user=yes
Guest_enable=yes----------起用虛擬用戶
Guest_username=qiang------將虛擬用戶映射為本地用戶
Listen_port=5555
Max_client=10
Max_per_ip=1
Ftpd_banner=this is a virtual server and users
Pam_service_name=ftp.vu
注:在主配置文件中給的權(quán)限越低,在后面分用戶管理的時(shí)候?qū)τ脩舻臋?quán)限劃分的空間就越大,因?yàn)橹髋渲梦募罡叩南拗品?wù)先讀主配置文件,然后再讀用戶的配置文件
配置完成時(shí)候執(zhí)行/etc/init.d/vsftpd restart重啟ftp服務(wù)器即可
到此虛擬USER就建好了
9>在VSFTPD_CONF所在的目錄中創(chuàng)建virtaul文件目錄,并在文件目錄中創(chuàng)建以你用戶名命名的配置文件
Longlei zhangweibo jinhui lxp
在longlei中添加:
Anon_world_readable_only=no
在lxp中添加
Anon_world_readable_only=no
這樣此兩個(gè)用戶就有了瀏覽目錄的權(quán)限了
在jinhui中添加
Anon_world_readable_only=no
Write_enable=yes
Anon_upload_enable=yes
此用戶就有了上傳、下載和瀏覽的權(quán)限
在zhangweibo中添加
Anon_world_readable_only=no
Write_enable=yes
Anon_upload_enable=yes
Anon_other_write_enable=yes
此用戶就有了上傳、下載、刪除文件目錄、修改文件名和瀏覽的權(quán)限
10>修改vsftpd2.conf
加入user_config_dir=/vsftpd.conf所在的目錄/virtual
重起服務(wù)器就搞定了
VSFTPD_CONF中的所有配置信息
Anonymous_enable=yes (允許匿名登陸)
Dirmessage_enable=yes (切換目錄時(shí),顯示目錄下.message的內(nèi)容)
Local_umask=022 (FTP上本地的文件權(quán)限,默認(rèn)是077)
Connect_form_port_20=yes (啟用FTP數(shù)據(jù)端口的數(shù)據(jù)連接)*
Xferlog_enable=yes (激活上傳和下傳的日志)
Xferlog_std_format=yes (使用標(biāo)準(zhǔn)的日志格式)
Ftpd_banner=XXXXX (歡迎信息)
Pam_service_name=vsftpd (驗(yàn)證方式)*
Listen=yes (獨(dú)立的VSFTPD服務(wù)器)*
Anon_upload_enable=yes (開(kāi)放上傳權(quán)限)
Anon_mkdir_write_enable=yes (可創(chuàng)建目錄的同時(shí)可以在此目錄中上傳文件)
Write_enable=yes (開(kāi)放本地用戶寫(xiě)的權(quán)限)
Anon_other_write_enable=yes (匿名帳號(hào)可以有刪除的權(quán)限)
Anon_world_readable_only=no (放開(kāi)匿名用戶瀏覽權(quán)限)
Ascii_upload_enable=yes (啟用上傳的ASCII傳輸方式)
Ascii_download_enable=yes (啟用下載的ASCII傳輸方式)
Banner_file=/var/vsftpd_banner_file (用戶連接后歡迎信息使用的是此文件中的相關(guān)信息)
Idle_session_timeout=600(秒) (用戶會(huì)話空閑后10分鐘)
Data_connection_timeout=120(秒) (將數(shù)據(jù)連接空閑2分鐘斷)
Accept_timeout=60(秒) (將客戶端空閑1分鐘后斷)
Connect_timeout=60(秒) (中斷1分鐘后又重新連接)
Local_max_rate=50000(bite) (本地用戶傳輸率50K)
Anon_max_rate=30000(bite) (匿名用戶傳輸率30K)
Pasv_min_port=50000 (將客戶端的數(shù)據(jù)連接端口改在
Pasv_max_port=60000 50000—60000之間)
Max_clients=200 (FTP的最大連接數(shù))
Max_per_ip=4 (每IP的最大連接數(shù))
Listen_port=5555 (從5555端口進(jìn)行數(shù)據(jù)連接)
Local_enble=yes (本地帳戶能夠登陸)
Write_enable=no (本地帳戶登陸后無(wú)權(quán)刪除和修改文件)
這是一組
Chroot_local_user=yes (本地所有帳戶都只能在自家目錄)
Chroot_list_enable=yes (文件中的名單可以調(diào)用)
Chroot_list_file=/任意指定的路徑/vsftpd.chroot_list (前提是chroot_local_user=no)
這又是一組
Userlist_enable=yes (在指定的文件中的用戶不可以訪問(wèn))
Userlist_deny=yes
Userlist_file=/指定的路徑/vsftpd.user_list
又開(kāi)始單的了
Banner_fail=/路徑/文件名 (連接失敗時(shí)顯示文件中的內(nèi)容)
Ls_recurse_enable=no
Async_abor_enable=yes
One_process_model=yes
Listen_address=10.2.2.2 (將虛擬服務(wù)綁定到某端口)
Guest_enable=yes (虛擬用戶可以登陸)
Guest_username=所設(shè)的用戶名 (將虛擬用戶映射為本地用戶)
User_config_dir=/任意指定的路徑/為用戶策略自己所建的文件夾 (指定不同虛擬用戶配置文件的路徑)
又是一組
Chown_uploads=yes (改變上傳文件的所有者為root)
Chown_username=root
又是一組
Deny_email_enable=yes (是否允許禁止匿名用戶使用某些郵件地址)
Banned_email_file=//任意指定的路徑/xx/
又是單的
Pasv_enable=yes ( 服務(wù)器端用被動(dòng)模式)
User_config_dir=/任意指定的路徑//任意文件目錄 (指定虛擬用戶存放配置文件的路徑)
如需要使用本地用戶登陸關(guān)閉來(lái)賓用戶,必須設(shè)置如下命令:
anonymous_enable=no
guest_enable=no
local_enable=yes
write_enable=yes
local_umask=022
chroot_list_enable=yes
chroot_list_file=/etc/vsftpd.chroot_list (如沒(méi)有則自己創(chuàng)建) (在etc/vsftpd.chroot_list 填入需要登陸的本地用戶名)
6、解決vsftpd的中文亂碼問(wèn)題
先安裝源中的vsfpd,然后把所有的功能都配置完后,再解決中文亂碼問(wèn)題
因?yàn)閯h除源的vsftpd后它的/init.d/vsftpd與/vsftpd.conf是不會(huì)刪除的,可以為我們打好鋪墊,不然你會(huì)發(fā)現(xiàn)很無(wú)奈的!如果 你是直接編譯安裝,附件給出會(huì)給出我的init.d/vsftpd與vsftpd.conf文件,把他們覆蓋到/etc下吧!
開(kāi)始做編譯的準(zhǔn)備工作,準(zhǔn)備編譯環(huán)境需要的庫(kù)包
sudo apt-get build-dep vsftpd
這里使用先安裝源里的vsftpd,然后卸載
sudo apt-get install vsftpd
apt-get remove vsftpd
下載附件并解壓包
tar -zxvf vsftpd-2.0.6
cd vsftpd-2.0.6
sudo su :使用root用戶開(kāi)始編譯
make #編譯命令,如果無(wú)錯(cuò)誤出現(xiàn),表示成功
make install #安裝
如果安裝中出現(xiàn)找不到目錄的話,就建立那個(gè)缺的目錄就好了
基本上都會(huì)提示缺少/man8和/man5目錄的,建立后在重新make install
下邊就來(lái)測(cè)試下效果修改配置文件,加入
charset_filter_enable=YES #開(kāi)啟字符過(guò)濾
charset_client=GB2312 #客戶端字符設(shè)置為簡(jiǎn)體中文
好了現(xiàn)在把服務(wù)開(kāi)啟測(cè)試下吧
sudo /etc/init.d/vsftpd restart
看完上述內(nèi)容是否對(duì)您有幫助呢?如果還想對(duì)相關(guān)知識(shí)有進(jìn)一步的了解或閱讀更多相關(guān)文章,請(qǐng)關(guān)注創(chuàng)新互聯(lián)行業(yè)資訊頻道,感謝您對(duì)創(chuàng)新互聯(lián)的支持。