RHEL7 -- Linux搭建FTP虛擬用戶


安裝vsftpd軟件包
[root@localhost ~]# yum install vsftpd -y
[root@localhost ~]# yum install db4 db4-utils

建立vsftpd服務的宿主用戶
[root@localhost ~]# useradd vir -s /sbin/nologin

創建日志文件
[root@localhost ~]# touch /var/log/vsftpd.log
[root@localhost ~]# chown vir:vir /var/log/vsftpd.log

修改 vsftp 配置文件
[root@localhost ~]# vi /etc/vsftpd/vsftpd.conf
#不允許匿名訪問
anonymous_enable=NO
#本地用戶可以訪問
local_enable=YES
#使用戶不能離開主目錄
chroot_list_enable=YES
#允許上傳
ascii_upload_enable=YES
#支持ASCII模式的下載功能
ascii_download_enable=YES
#千萬別忘記添加
pam_service_name=vsftpd

#手工輸入以下參數和值
#開啟虛擬用戶的功能
guest_enable=YES
#指定虛擬用戶的宿主用戶
guest_username=vir
user_config_dir=/etc/vsftpd/vuser_conf
#vsftpd的服務日志保存路徑,默認不存在
xferlog_file=/var/log/vsftpd.log

 

先建立虛擬用戶名單文件
[root@localhost ~]# vi /etc/vsftpd/vsftp_users.conf
#輸入奇數行為賬號,偶數行為密碼
yb1 #賬號
abcd1234 #密碼
yb2
abcd1234

生成認證文件
db_load 找不到的話就先安裝 db4-utils(yum install db4 db4-utils)
[root@localhost ~]# db_load -T -t hash -f /etc/vsftpd/vsftp_users.conf /etc/vsftpd/vsftp_users.db
修改其權限
[root@localhost ~]# chmod 600 /etc/vsftpd/vsftp_users.db

編輯認證文件,清空或注釋文件中全部內容(保留第一行內容)
[root@localhost ~]# vi /etc/pam.d/vsftpd
清空之后,再輸
auth required pam_userdb.so db=/etc/vsftpd/vsftp_users
account required pam_userdb.so db=/etc/vsftpd/vsftp_users

建立虛擬用戶配置文件存放位置
[root@localhost ~]# mkdir /etc/vsftpd/vuser_conf/

自定義用戶(可以分別設置不同虛擬用戶權限等)
[root@localhost ~]# vi /etc/vsftpd/vuser_conf/yb1

添加以下內容
local_root=/data01/yb1 #虛擬用戶yb2根目錄
write_enable=YES
anon_umask=022
anon_world_readable_only=NO
anon_upload_enable=YES
anon_mkdir_write_enable=YES
anon_other_write_enable=YES

[root@localhost ~]# vi /etc/vsftpd/vuser_conf/yb2

添加以下內容
local_root=/data01/yb2 #虛擬用戶yb2根目錄
write_enable=YES
anon_umask=022
anon_world_readable_only=NO
anon_upload_enable=YES
anon_mkdir_write_enable=YES
anon_other_write_enable=YES

OK了,啟動或重啟 vsftp
[root@localhost ~]# systemctl vsftpd restart(重啟 restart)


連接 FTP 時若提示錯誤:vsftpd 530 login incorrect
原因:/etc/vsftpd.conf參數配置里面有空格
解決方法:去掉空格


連接 FTP 時若提示錯誤:500 OOPS: vsftpd: refusing to run with writable root inside chroot()
原因:vsftpd的安全規則是不允許ftp用戶對ftp根目錄有可寫權限,因此那個ftp用戶就被服務器拒絕了。
解決方法:
chmod a-w /data01/yb1
chmod a-w /data01/yb2


免責聲明!

本站轉載的文章為個人學習借鑒使用,本站對版權不負任何法律責任。如果侵犯了您的隱私權益,請聯系本站郵箱yoyou2525@163.com刪除。



 
粵ICP備18138465號   © 2018-2025 CODEPRJ.COM