课程介绍
1. 网站架构存储服务配置参数
2. 网站架构存储服务应用方式
3. 网站架构存储服务挂载操作 参数
4. 网站架构存储服务权限问题
5. 网站架构全网备份项目说明
一. 知识回顾部分
存储服务的概念
作用:1. 实现数据统一管理
2. 实现运营成本节约
3. 实现数据共享存储
原理:1.服务端设共享目录
2. 客户端挂载
3. 数据存在共享目录中(存在服务端中)
实现方式
1. 中小企业
NFS: 网络文件系统 NFS客户端(本地不存) -->NFS服务器 利用挂载
FTP: 文件传输协议 FTP客户端(本地存) --> FTP服务端 配置复杂
samba 共享文件 配置复杂
2.大型企业
FastDFS 分布式储存
存储服务部署流程
服务端部署: 1. 检查软件程序安装
rpm -qa |grep -E "rpc|nfs"
yum install -y rpcbind nfs-utils
2. 编写配置目录
vim /etc/exports (共享目录 白名单(权限参数))
3. 创建存储目录并修改属主属组信息
mkdir /data
chown -R nfsnobody.nfsnobody /data
4. 启动服务
systemctl start rpcbind.service
systemctl enable rpcbind.service
systemctl start nfs
systemctl enable nfs
客户端部署流程
1. 检查安装/安装程序
yum install -y nfs-utils
2. 检查是否有共享目录
showmount -e 172.16.1.31
3. 进行挂载 mount -t 172.16.1.31:/data
昨日作业
1.如何实现共享目录自动挂载
第一种方式: 利用fstab文件
第二种方式: 利用rc.local文件
2. 保持存储属组属主身份不变
修改配置文件: no_all_squash
修改目录权限: chmod o+d /data
二. 网站存车处服务配置文件参数信息
1. 存储配置文件格式信息
/data 172.16.1.0/24(rw,sync)
/data 10.0.0.0/24(re,sync)
2. 存储文件参数说明
rw - - - - 让存储共享目录权限为读写权限
ro - - - - 让存储共享目录权限为只读权限
sync - - 同步传输数据信息(存储方式不一样 数据来了尽快存到服务器磁盘中)
用户存储数据 --> web服务器(和nfs挂载) -->nfs存储服务器 -->磁盘
async - 异步传输数据信息(存储方式不一样 数据到达服务器先到内存 缓冲 再到磁盘中)
用户存储数据 --> web服务器(和nfs挂载) -->nfs存储服务器 -->内存(缓冲) -->磁盘
all_squash - - 让所有用户都做映射 都映射为默认的nfsnobody用户
no_all_squash - - 让所有用户都不做映射 原来是什么用户传过来还是什么用户(默认)
root_squash - - 让root用户做映射 将原来root用户映射为默认nfsnobody(默认)
no_root_squash - - 不让root用户做映射
anonuid - - - 修改默认映射用户信息(用户端与服务端uid需要保持一致)
anongid - - - 修改映射用户属组信息
总结:影响数据存储因素
1. 配置文件参数信息
2. 存储目录本身权限 755 属主
3. 父级目录和子级目录
测验练习题
nfs服务端 /data/r 权限只读 同步传输 所有用户映射
/data/r 权限读写 异步传输 所有用户映射
nfs客户端:web01 挂载 /data/r --共享/data/r
backup /data/w ---共享/data/w
答: vim /etc/exports
#/data 172.16.1.0/24(rw,sync,all_squash)
/data/r 172.16.1.0/24(ro,sync,all_squash)
/data/w 172.16.1.0/24(rw,async,all_squash)
mkdir /data/w mkdir /data/r
三. 服务端重要文件信息说明:
/etc/exports --- nfs服务端配置文件信息
/usr/sbin/showmount --- 检查是否存在共享目录信息
/usr/sbin/rpcinfo --- 确认服务端nfs服务是否向rpc服务进行注册
/usr/sbin/exportfs --- 重启nfs服务(平滑重启) exportfs -rv
/var/lib/nfs/etab --- 记录nfs默认配置参数信息
/proc/mounts --- 记录客户端挂载参数信息
==============================================================
补充: 平滑重启/重启
平滑重启:
1) 链路中没有数据传输, 会将链路进行断开,重新建立
2) 链路中存在数据传输, 会等待数据传输完毕, 断开连接, 重新建立
重启:
1) 链路中无论是否有数据传输, 会将链路强制断开,重新建立连接
补充: nfs默认配置参数信息
cat /var/lib/nfs/etab
/data/w 172.16.1.0/24(rw,sync,wdelay,hide,nocrossmnt,secure,root_squash,no_all_squash,no_subtree_check,secure_locks,acl,no_pnfs,anonuid=65534,anongid=65534,sec=sys,rw,secure,root_squash,no_all_squash)
/data/r 172.16.2.0/24(ro,sync,wdelay,hide,nocrossmnt,secure,root_squash,no_all_squash,no_subtree_check,secure_locks,acl,no_pnfs,anonuid=65534,anongid=65534,sec=sys,ro,secure,root_squash,no_all_squash)
==========================================================
四. 存储服务客户端操作
如何进行存储服务挂载
1. 手动挂载方式:
mount -t nfs 172.16.1.31:/data /mnt
2. 自动挂载方式:
- 第一种方式: 利用fstab文件 (开机挂载网络存储设备,是有条件)
centos6: 启动顺序 先加载/etc/fstab文件 然后在启动相关服务程序(network)
先设置 netfs服务开机自动启动
centos7: 启动顺序 先加载/etc/fstab文件 然后在启动相关服务程序(network)
先设置 remote-fs.target服务开机自动启动
原理过程:
第一个里程: 服务器启动加载/etc/fstab文件 忽略网络挂载信息
第二个里程: 系统服务程序开机自启 network remote-fs.target
第三个里程: remote-fs.target会启动时重新加载/etc/fstab文件
将网络存储设备进行挂载 - 第二种方式: 利用rc.local文件 (文件权限为执行权限)
客户端挂载参数说明:
bg --- 后台进行挂载操作 mount -t nfs -o bg xxxx xxx 让挂载过程后台进行
fg --- 前台进行挂载操作 mount -t nfs -o bg xxxx xxx 让挂载过程前台显示
soft --- 客户端 -发送挂载请求-> 服务端 超时时间 ??? 停止发送挂载请求
hard --- 客户端 -发送挂载请求-> 服务端 一直进行发送挂载请求
rsize --- 划分出内存一部分空间, 作为存储服务读取数据缓存空间 4096 8192
wsize --- 划分出内存一部分空间, 作为存储服务写入数据缓冲空间 4096 8192
atime --- 修改文件访问时间戳信息 性能有关参数
noatime --- 不修改文件访问时间戳信息 性能有关参数
nodiratime --- 不修改目录访问时间戳信息
remount --- 在挂载点正在挂载时, 进行重新挂载
总结: 影响数据存储因素
01. 配置文件参数信息
02. 存储目录本身权限 权限755 属主
03. 父级目录权限到子集目录权限继承关系
04. 客户端挂载参数
05.课程知识总结:
- 掌握存储服务原理过程
- 掌握存储服务部署过程
- 掌握存储服务配置参数
- 掌握影响存储数据原因
- 掌握存储服务挂载参数 (挂载手动和自动)