FungLeo's Blog

键鼠轻游戏人间 风流谈笑傲江湖

CentOS7 初次安装记录(六)配置 FTP 服务器

下面要去研究研究配置FTP服务器了。

一直以来,我都是用 WinSCP 来上传下载文件的。当然,有高手直接用命令行来上传文件。我没试过,回头也可以研究一下。但是,有时候,我们不能把服务器的全部权限交给别人。这时候,FTP就显得很有作用了。

因为之前完全没有配过,所以百度了一下相关的资料。在 centos 上,一般都是使用 vsftpd 来实现FTP的,好吧。查找相关资料,开始实战!

用 vsftpd 配置 FTP 服务器

yum 安装 vsftpd

yum -y install vsftpd

很快就安装完成了。设定它开机自启动

systemctl enable vsftpd.service

安装完成之后,就需要配置它了。到/etc/vsftpd/目录看看配置文件vftpd.conf

// 编辑配置文件
vi /etc/vsftpd/vftpd.conf
// 配置开始
#设定不允许匿名访问 默认是YES
anonymous_enable=NO
#设定支持ASCII模式的上传和下载功能 默认前面有#号
ascii_upload_enable=YES
ascii_download_enable=YES
#使用户不能离开主目录 默认前面有#号
chroot_list_enable=YES

在最末尾,添加下面三行 不含注释
#设定启用虚拟用户功能 
guest_enable=YES
#指定虚拟用户的宿主用户,CentOS中已经有内置的ftp用户了
guest_username=ftp
#设定虚拟用户个人vsftp的CentOS FTP服务
user_config_dir=/etc/vsftpd/vuser_conf

新建 chroot_list 文件 写入 guest_username 这里是 ftp
看的教程,没说清楚,我是 vi chroot_list 新建了这个文件,然后输入 ftp 保存退出。不知道对不对。

创建用户名密码文件,vi /etc/vsftpd/vuser_passwd.txt 奇数行用户名,偶数行密码。写好之后,保存退出。

生成DB文件,命令如下:

db_load -T -t hash -f /etc/vsftpd/vuser_passwd.txt /etc/vsftpd/vuser_passwd.db

然后我ls 一下,果然看到了这个DB文件。

然后编辑认证文件 vi /etc/pam.d/vsftpd

##把原有的内容全部注释,然后在下面写上
auth required /lib64/security/pam_userdb.so db=/etc/vsftpd/vuser_passwd
account required /lib64/security/pam_userdb.so db=/etc/vsftpd/vuser_passwd

我压根不明白这是干嘛,跟着教程走,教程说得不清楚。

接着创建虚拟用户配置文件。先新建文件夹 mkdir /etc/vsftpd/vuser_conf/

然后新建一个文件。文件名为你在/etc/vsftpd/vuser_passwd.txt里设置的用户名我这里是test

所以,我在建立好文件夹后,输入 vi /etc/vsftpd/vuser_conf/test

在里面输入配置内容

#虚拟用户根目录,根据实际情况修改  该目录必须要有读写权限 chmod -R 777 目录 
local_root=/home/website/
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

然后设置Selinux

#设置ftp可以使用home目录
setsebool -P ftp_home_dir=1
#设置ftp用户可以有所有权限
setsebool -P allow_ftpd_full_access=1

我把selinux 关闭了,应该不用设置了。

然后教程说可以了。。。。准备启动ftp服务

systemctl start vsftpd.service

好像没报什么错误。

用flashfxp链接一下看看。。。。果然连不上去!!!!我就知道肯定没这么顺利!!!告诉我错哪里了???

百度了一下,说是给配置文件加上 allow_writeable_chroot=YES

vi /etc/vsftpd/vsftpd.conf
#在最后,加上
allow_writeable_chroot=YES
#然后重启ftp服务
systemctl restart vsftpd.service

我擦!!果然连上了!!!庆祝一下先,抽根烟去~

阅读更多
版权声明:本文为 FengCms FungLeo 原创文章,允许转载,但转载必须注明出处并附带首发链接 https://blog.csdn.net/FungLeo/article/details/49908571
个人分类: Linux\CentOS
上一篇CentOS7 初次安装记录(五)配置 apache 虚拟主机
下一篇Css 详细解读定位属性 position 以及参数
想对作者说点什么? 我来说一句

没有更多推荐了,返回首页

关闭
关闭