Ubuntu构建ftp服务器(一)
2015-08-26 15:31
555 查看
Date: 8.25-8.26
Target: 用vsftpd在Ubuntu Kylin 14 LTS(没记错的话)构建ftp服务器
安装vsftpd
修改vsftpdconf
局域网登录
测试-下,输入vsftpd -version,显示vsftpd: version 3.0.2。
在firefox上测试一下,输入ftp://localhost和ftp://192.168.0.104(内网ip),需要输入用户名和密码才能登录。成功后显示的是$HOME,也就是/home/wang(我现在的用户名)。能查看文件并下载,切换目录,但是不能修改。
这时,vsftpd是running的,然后我试着用手机登录,发现不行,可能是没用户吧。然后又试着把vsftpd stop,用firefox再登录,发现这次不需要用户名和密码就能登上了,新建标签页也是。不过手机仍没登上。好吧,试着用chromium上,却登不上了。那firefox登上的是啥?。。。一段时间后,现在firefox也登不上了。
再次start,这会登上。再次stop,chromium是立即断了连接,firefox是一段时间才登不上的。重新打开firefox也是登不上,需要start,加上用户名和密码才行。
难不成stop不是真正的关?stop时显示vsftpd stop/waiting,waiting是why?这让我想起来那背得欲仙欲死的操作系统,是那进程状态阻塞态或挂起态?
好吧,暂且不管。总之已经安装了vsftpd。service vsftpd start/stop是启动和关闭。
基本上ftp用默认的就已经搭建完了。
先保存原文件,恩,都是这样说的。
不要自启动,那就要修改其启动脚本
vim /etc/init/vsftpd.conf
将
这是改启动级别实现的。
改变ftp根目录,GG跳转到文件尾,插入
,其中ftp是刚新建的文件夹,这是登录的话,一开始就不是/home/wang,而是local_root(刚设为/home/wang/ftp),说这是为了让用户不能随意操作其他目录。可是却能通过返回上一层到其他目录。后来发现firefox是这样,在chromium却是没这功能。
我是个执着的人,所以钻牛角去了。又搜索了,在Wiki(?)上找到。在Shell上登录
完了后再输入
不出意外发现是/home/wang/ftp,好,跟着干。
试试×-×。再次登录,呵呵,显示500 OOPS: vsftpd: refusing to run with writable root inside chroot()。刚看过,忘了是什么鬼。幸亏度娘,比较和胃口的说法是用户的根目录可写,我们使用了chroot限制,在最近的更新里是不被允许的。要修复这个错误,可以
就ok了,登录,啪啪,行了.这样做后,用户也不能移动到其他目录了。
用户登录时,我希望是带着口令的,即不能让匿名用户登录。那就是默认的效果,不用修改。不过,可以尝试一下匿名的登录
发现/和先前带口令登录时不一样,看看就其实默认的是/srv/ftp。修改的话,可以先创建Tinuy文件夹
然后映射虚拟路径
再登录时,的确是变了。改变其中一个文件夹,两个同时变。不过,怎么卸载我还没搞懂<-_<-,慎用慎用,哦米托佛。
关于这里,其实还可以创建虚拟用户,不过这又是另话了。
好了,碰壁完了,改回
允许ftp端口(21)
开了以后就只能使用ftp登录了,理论上是,但手机登录的时候确实没反应。ping一下,能通。后来开了apache2,也是登不上http。关了ufw
http能登上了。说明防火墙是有用的。关了后也是上不了ftp,而开机是ufw默认是关了。所以走歪了。难道是端口问题?在vsftpd.conf里添加了
试一下,还是只能本地行。
显示2121在监听,不过手机还是不行不行的。Please Try Again!那就是ip了吧,但却能上http?!逗我呢。苦恼中。。。。
总结一下,现在问题是局域网内不能互通ftp。同时,也有需要改进的地方,设置虚拟用户和虚拟主机。
恩,to be continue…….
mark一下看过的教程这个比较靠谱。
Target: 用vsftpd在Ubuntu Kylin 14 LTS(没记错的话)构建ftp服务器
安装vsftpd
修改vsftpdconf
局域网登录
1.安装vsftpd
sudo su apt-get install vsftpd
测试-下,输入vsftpd -version,显示vsftpd: version 3.0.2。
在firefox上测试一下,输入ftp://localhost和ftp://192.168.0.104(内网ip),需要输入用户名和密码才能登录。成功后显示的是$HOME,也就是/home/wang(我现在的用户名)。能查看文件并下载,切换目录,但是不能修改。
这时,vsftpd是running的,然后我试着用手机登录,发现不行,可能是没用户吧。然后又试着把vsftpd stop,用firefox再登录,发现这次不需要用户名和密码就能登上了,新建标签页也是。不过手机仍没登上。好吧,试着用chromium上,却登不上了。那firefox登上的是啥?。。。一段时间后,现在firefox也登不上了。
再次start,这会登上。再次stop,chromium是立即断了连接,firefox是一段时间才登不上的。重新打开firefox也是登不上,需要start,加上用户名和密码才行。
难不成stop不是真正的关?stop时显示vsftpd stop/waiting,waiting是why?这让我想起来那背得欲仙欲死的操作系统,是那进程状态阻塞态或挂起态?
好吧,暂且不管。总之已经安装了vsftpd。service vsftpd start/stop是启动和关闭。
基本上ftp用默认的就已经搭建完了。
2.修改vsftpd.conf
这是实现需要的功能的地方,比如限制用户,限制下载什么的。网上有课程说要修改/etc/init.d/vsftpd的,然并卵。我在这里找不到这文件,可能是因为用的是Ubuntu 14,启动方式已经改为Upstart,启动的配置脚本是在/etc/init里面的。man一下,发现修改的是/etc/vsftpd.conf才对。至于前者,反正我电脑没有,有的也只是/etc/init/vsftp.conf这个看起来像是启动脚本的东西。cp /etc/vsftpd.conf /etc/vsftpd.conf.old
先保存原文件,恩,都是这样说的。
不要自启动,那就要修改其启动脚本
vim /etc/init/vsftpd.conf
将
start on runlevel [2345] or net-device-up IFACE!=lo改为
start on runlevel [345]
这是改启动级别实现的。
vim /etc/vsftpd.conf
改变ftp根目录,GG跳转到文件尾,插入
local_root=/home/wang/ftp
,其中ftp是刚新建的文件夹,这是登录的话,一开始就不是/home/wang,而是local_root(刚设为/home/wang/ftp),说这是为了让用户不能随意操作其他目录。可是却能通过返回上一层到其他目录。后来发现firefox是这样,在chromium却是没这功能。
我是个执着的人,所以钻牛角去了。又搜索了,在Wiki(?)上找到。在Shell上登录
ftp localhost
完了后再输入
pwd
不出意外发现是/home/wang/ftp,好,跟着干。
chroot_local_user=YES
试试×-×。再次登录,呵呵,显示500 OOPS: vsftpd: refusing to run with writable root inside chroot()。刚看过,忘了是什么鬼。幸亏度娘,比较和胃口的说法是用户的根目录可写,我们使用了chroot限制,在最近的更新里是不被允许的。要修复这个错误,可以
chmod a-w /home/wang/ftp去除用户根目录的写权限。又或者简单点(我喜欢)。添加
allow_wirteable_chroot=YES
就ok了,登录,啪啪,行了.这样做后,用户也不能移动到其他目录了。
用户登录时,我希望是带着口令的,即不能让匿名用户登录。那就是默认的效果,不用修改。不过,可以尝试一下匿名的登录
anonymous_enable=NO
发现/和先前带口令登录时不一样,看看就其实默认的是/srv/ftp。修改的话,可以先创建Tinuy文件夹
mkdir /src/ftp/Tinuy mkdir /home/wang/Tinuy
然后映射虚拟路径
sudo mount --bind /srv/ftp/Tinuy /home/wang/Tinuy
再登录时,的确是变了。改变其中一个文件夹,两个同时变。不过,怎么卸载我还没搞懂<-_<-,慎用慎用,哦米托佛。
关于这里,其实还可以创建虚拟用户,不过这又是另话了。
好了,碰壁完了,改回
anoymous_enable=YES
3.局域网登录
本地登录行,用手机却登不上,局域网内的啊?!难道是防火墙?试试ufw enable
允许ftp端口(21)
ufw default allow ufw allow ftp ufw status
开了以后就只能使用ftp登录了,理论上是,但手机登录的时候确实没反应。ping一下,能通。后来开了apache2,也是登不上http。关了ufw
ufw disable
http能登上了。说明防火墙是有用的。关了后也是上不了ftp,而开机是ufw默认是关了。所以走歪了。难道是端口问题?在vsftpd.conf里添加了
listen_port=2121
试一下,还是只能本地行。
netstat -nl
显示2121在监听,不过手机还是不行不行的。Please Try Again!那就是ip了吧,但却能上http?!逗我呢。苦恼中。。。。
总结一下,现在问题是局域网内不能互通ftp。同时,也有需要改进的地方,设置虚拟用户和虚拟主机。
恩,to be continue…….
mark一下看过的教程这个比较靠谱。
相关文章推荐
- Ubuntu 默认壁纸历代记
- Ubuntu Remix Cinnamon 20.04 评测:Ubuntu 与 Cinnamon 的完美融合
- 关于Ubuntu 11.10启动提示waiting for the network configuration的问题
- 在 Ubuntu 桌面中使用文件和文件夹
- ubuntu下chrome无法同步问题解决
- Ubuntu Linux使用体验
- 使用 GNOME 优化工具自定义 Linux 桌面的 10 种方法
- 以Ubuntu 9.04为例 将工作环境迁移到 Linux
- VirtualBox虚拟机XP与宿主机Ubuntu互访共享文件夹
- 从USB安装Ubuntu Server 10.04.3 图文详解
- Ubuntu 15.04 正式版发布下载
- Linux-Ubuntu 10.04安装Cadence-ic610 方法总结图解
- Ubuntu 12.04和Windows 7双系统安装图解
- 开机出现:grub rescue的修复方法
- Ubuntu连接Android真机调试
- 你应该选择 Ubuntu 还是 Fedora?
- 100 个最佳 Ubuntu 应用(中)
- 看看我的Ubuntu Linux截图
- Ubuntu 12.04 LTS服务器版安装过程及使用图解
- Windows 7/8/8.1 硬盘安装 Ubuntu 14.04 实现双系统