文件服务系列
文件存储服务系统(File Storage Service System)-00-文件服务器是什么?为什么需要?
文件存储服务系统(File Storage Service System)-01-常见的文件协议介绍
文件存储服务系统(File Storage Service System)-02-SFTP 协议介绍
分布式文件服务系统(Distributed File System, DFS)-00-分布式文件服务系统是什么?
分布式存储系统-02-开源的分布式文件系统 Fastdfs 安装入门介绍
分布式存储系统-03-ceph 一个可扩展的分布式存储系统介绍
分布式存储系统-04-GlusterFS 是一个基于对象的开源分布式文件系统,适用于云存储和媒体流等场景
分布式存储系统-05-Lustre 是一个高性能的分布式文件系统,主要用于大型超级计算机集群
分布式存储系统-06-MooseFS 是一个开源的分布式文件系统,设计用于提供高可靠性和扩展性
分布式存储系统-07-OpenAFS 是 Andrew File System 的开源实现,是一个分布式网络文件系统
分布式存储系统-08-OrangeFS 是 PVFS 的下一代版本,是一个面向高性能计算的开源并行文件系统
FTP
环境: Ubuntu 14.04
- Install
- Start & Restart
注意:
网上文章很多有提及/etc/init.d/vsftpd start
之类的启动方式。但是这个目录下我不存在 vsftpd. 这个目录确实有: /etc/init/vsftpd.conf
- Create ftp user
1.此用户只是用来使用ftp服务的
2.此用户不可登录服务器
3.此用户不能访问ftp指定文件夹之外的文件
(1) 创建一个用户ftp0
(2) 修改ftp0的密码
- Config
/etc/vsftpd.conf
报错误信息:
从2.3.5之后,vsftpd增强了安全检查,如果用户被限定在了其主目录下,则该用户的主目录不能再具有写权限了!如果检查发现还有写权限,就会报该错误。
(1) 启用了chroot的话,根目录要设置为不可写
(2) 或者添加一句话
可是添加这句话可能会导致服务重启失败。。。
无奈之下。。。chroot_local_user=YES
这句话暂时不加。
- 让用户不能登录
after all these, restart the ftp service:
- Test
需要 vi /etc/shells
, 最后一行添加:
重新测试:
21 端口查看:
Ftp Java code
- Java 测试代码
chat
详细介绍一下 FTP 协议
FTP(File Transfer Protocol)是用于在网络上进行文件传输的标准协议。
它是应用层协议,使用 TCP 端口 21 进行通信,主要用于在客户端和服务器之间上传、下载和管理文件。以下是对 FTP 协议的详细介绍:
FTP 协议概述
工作原理
FTP 协议采用客户端-服务器架构,主要涉及两个通信通道:
- 控制连接:用于传输控制信息(如命令和响应),使用 TCP 端口 21。
- 数据连接:用于传输实际的文件数据,使用 TCP 端口 20 或动态分配的端口。
传输模式
FTP 有两种传输模式:
-
主动模式(Active Mode):
- 客户端通过随机的高位端口连接到服务器的控制端口(21)。
- 客户端在传输数据时告诉服务器监听一个随机高位端口。
- 服务器从其数据端口(20)连接到客户端指定的高位端口进行数据传输。
-
被动模式(Passive Mode):
- 客户端通过随机的高位端口连接到服务器的控制端口(21)。
- 客户端请求服务器进入被动模式,服务器选择一个随机高位端口并告知客户端。
- 客户端从其随机高位端口连接到服务器的该随机高位端口进行数据传输。
FTP 命令和响应
常见 FTP 命令
- USER:提供用户名
- PASS:提供密码
- CWD:改变工作目录
- PWD:打印工作目录
- LIST:列出文件和目录
- RETR:下载文件
- STOR:上传文件
- DELE:删除文件
- QUIT:退出会话
常见 FTP 响应代码
- 1xx:积极的初始答复(如150,表示文件状态良好,准备打开数据连接)
- 2xx:成功(如200,表示命令成功)
- 3xx:需要进一步的信息(如331,表示用户名正确,需要密码)
- 4xx:暂时的负面答复(如421,表示服务不可用,关闭控制连接)
- 5xx:永久的负面答复(如530,表示未登录)
安全性
传统的 FTP 协议没有加密机制,传输的数据和凭证都是以明文形式发送的,这会导致安全风险。因此,衍生出了以下更安全的版本:
- FTPS(FTP Secure/SSL):通过 SSL/TLS 对 FTP 连接进行加密。
- SFTP(SSH File Transfer Protocol):虽然名称相似,但 SFTP 是基于 SSH 的完全独立的协议,提供加密的数据传输。
使用场景
- 文件共享:FTP 服务器可用于在组织内部或与客户之间共享大文件。
- 网站管理:许多网站管理员使用 FTP 来上传和管理网站文件。
- 数据备份:FTP 可用于将数据备份到远程服务器。
FTP 的优缺点
优点
- 简单:易于实现和使用。
- 跨平台:广泛支持各种操作系统和设备。
- 效率高:传输大文件时性能较好。
缺点
- 不安全:传统的 FTP 缺乏加密机制,容易被攻击。
- 防火墙问题:主动模式和被动模式的连接建立可能会被防火墙阻止。
- 过时:相对于现代文件传输协议,FTP 的功能和安全性不足。
相关工具
- FTP 客户端:FileZilla、WinSCP、Cyberduck 等。
- FTP 服务器:vsftpd、ProFTPD、FileZilla Server 等。
结论
FTP 协议作为一种古老而广泛使用的文件传输协议,尽管在现代安全要求下显得不够完善,但在一些场景中仍然非常有用。
对于需要更高安全性的场景,可以选择 FTPS 或 SFTP 等替代方案。