1.DAS
DAS是指存储设备直接连接到服务器总线上,存储设备只与一台独立的主机连接,其他主机不能使用这个存储设备
2.NAS
NAS存储就是存储设备通过标准的网络拓扑结构(比如以太网)添加到一群计算机上
3.SAN
存储区域网络,这个是通过光纤通道或以太网交换机连接存储阵列和服务器主机,最后成为一个专用的存储网络。
1.ftp的定义
FTP是一种用于在计算机网络上传输文件的标准协议,基于C/S结构。
通过FTP,用户可以在客户端和服务器之间进行文件的上传(上传到服务器)和下载(从服务器下载到本地计算机)操作
数据传输格式:二进制(默认)和文本
2.双通道协议
20 数据端口(数据传输)
21 命令端口 (账户验证 权限管理)
3.用户类型
1.匿名用户 :ftp,anonymous,对应Linux用户ftp
2.系统用户:Linux用户,用户/etc/passwd,密码/etc/shadow。
3.虚拟用户:用于特定服务的用户。
服务端主动连接 客户端,开启20端口 ,向客户端传输数据
服务端开启随机端口,等待客户端连接 。
服务端通过命令端口21 ,告知客户端,开启了哪个随机端口
vsftpd是一个在Linux和Unix系统上常见的FTP服务器软件。
#安装#
##在服务端##
yum install -y vsftpd #安装软件
systemctl start vsftpd #开启服务
systemctl status vsftpd #查看服务状态
ftp 192.168.2.102 #客户端连接服务端
#连接后 默认在服务端的 /var/ftp下
#为什么默认在此目录?#
#因为会生成一个新用户,此目录为新用户的家目录,可以usermod -s 修改用户家目录 来更改ftp连接后的位置
#服务端#
vim /etc/vsftpd/vsftpd.conf #编辑配置文件
systemctl restart vsftpd #重启服务
#客户端#
ftp 192.168.2.100 2121 #连接服务端需要加端口号
用户登录将使用自己的用户名和密码进行身份验证,并且只能访问其分配的用户目录。
服务端配置
vim /etc/vsftpd/vsftpd.conf
user_config_dir=/etc/vsftpd/conf.d/
#希望每个用户的配置文件存储在/etc/vsftpd/conf.d/目录下
systemctl restart vsftpd #重启服务
mkdir -p /etc/vsftpd/conf.d #建立用户配置目录
#建立用户子配置,以用户test1和test2为例#
##test1##
vim /etc/vsftpd/conf.d/test1
local_root=/data/test1 #设置用户的FTP起始目录
##test2##
vim /etc/vsftpd/conf.d/test2
local_root=/data/test2
#建立目录
mkdir -p /data/{test1,test2}
#建立测试文件
touch /data/test1/t11
touch /data/test2/t22
NFS(Network File System)是一种用于在网络上分享和访问文件的协议。
NFS允许远程计算机通过网络访问另一台计算机上的文件系统,就像访问本地文件一样。
1. 客户端请求:NFS 的客户端向 NFS 服务器发送文件访问请求。这可以是读取文件、写入文件或执行其他文件操作。
2. 访问协议:客户端使用 RPC(Remote Procedure Call)协议与服务器通信。客户端会发送特定的 RPC 调用来请求文件操作,如打开文件、读取文件或关闭文件。
3. NFS 服务端:NFS 服务器收到来自客户端的请求,并解析这些请求。服务器根据客户端请求的内容,在本地文件系统上执行相应的操作。
4. 文件传输:当服务器执行文件操作时,它会读取或写入相应的文件或目录。数据通过网络传输,从服务器发送到客户端或从客户端发送到服务器。
5. 返回结果:服务器完成请求后,会将执行结果返回给客户端。这可能包括成功的确认、文件内容、错误信息等。
软件包:nfs-utils(包括服务器和客户端相关工具,CentOS8 最小化安装时默认没有安装)
相关软件包:rpcbind(必须),tcp_wrappers
yum install -y nfs-utils rpcbind #安装服务
端口:2049(nfsd), 其它端口由portmap(111)分配
RPCbind 111
NFS服务主要进程
说明:CentOS 6 开始portmap进程由rpcbind代替
NFS相关文件
#日志#
/var/lib/nfs/
#配置文件#
/etc/exports
/etc/exports.d/*.exports
#文件路径
/etc/eports
#文件内容
/dir 主机1(opt,opt2,)
共享文件夹 域名、ip。。。。
vim /etc/exports
...
共享文件夹 允许访问的主机[权限] #添加的内容
...
:wq
#例如
/data * #允许所有访问共享目录/data
exportfs
是一个用于在 Linux 操作系统上管理 NFS(Network File System)导出的命令。
##常用选项##
-v #查看本机所有NFS共享
-r #重读配置文件,并共享目录
-a #输出本机所有共享
-au #停止本机所有共享
showmount -a #显示所有共享的目录
showmount -e <服务器主机名或IP地址> #显示特定 NFS 服务器上的共享目录
showmount -l #仅显示挂载点的主机名或IP地址
#关闭防火墙和selinux
systemctl stop firewalld
setenforce 0
#安装nfs-utils和rpcbind软件包
yum install nfs-utils rpcbind -y
#新建共享目录,在目录内创建文件
mkdir /test
touch /test/t1
#编辑nfs配置文件
vim /etc/exports
/test 192.168.2.0/24
#允许192.168.2.0网段的主机访问共享目录/test
#启动服务,查看详细的nfs信息
systemctl start nfs
systemctl start rpcbind
showmount -e #查看本机发布的NFS共享目录
exportfs -v #查看NFS共享目录的详细信息
#挂载共享目录到本机挂载点目录下
mount 192.168.2.100:/test /mnt
#切换回服务端#
cd /test
touch thisistest #随意创建一个空文件
#返回客户端#
cd /mnt
ls #查看挂载点目录下有没有服务端生成的文件