跳到主要内容

存储管理

数据类型

服务端系统在运行中产生的数据有三种类型,分别为系统数据、文件数据、系统备份,存储路径配置在config.json文件中,多数情况下,只需要配置这三种类型的存储路径即可,如下表:

名称配置文件字段描述
系统数据service.ydisk.path.data系统运行过程中产生的结构化数据库文件,需高速固态硬盘,可以有良好的性能。
文件数据service.oss.build.nodes.paths系统中管理的企业文件数据
系统备份        service.ydisk.path.backup系统数据备份

系统数据

系统数据包含MySQL、Redis、ElasticSearch三个服务的结构化数据,默认是作为子目录存储在系统数据路径中,根据生产经验,每存储1TB的企业文件需要消耗大约1GB的系统数据空间。如果有特殊需要也可以单独配置这三个路径(不推荐),在config.json文件的字段对应如下表:

名称配置文件字段
MySQL数据service.db.build.data
Redis数据service.redis.build.data
ElasticSearch数据service.es.build.data

文件数据

文件数据,是系统中管理的企业文件数据,为了数据存储安全,默认有2个存储节点服务(对应2个存储路径),所有数据都在不同的存储节点中分别存储1份数据,共2份数据,这样的数据冗余方式可以在一个存储节点故障时,保证数据不丢失。存储节点由主节点和卷节点组成,主节点在存储文件数据的同时提供标准的S3服务,卷节点则只提供存储服务,类似于Windows系统中的扩展分区。

当存储服务或整个服务器发生一些事件后,文件数据的持久性情况如下:

事件类型文件数据保存
存储服务正常关闭
存储服务异常结束
服务器正常关机
服务器异常断电可能丢失刚上传完成的文件数据

系统备份

系统备份,包含所有系统数据的备份,防止存储设备损坏造成的系统数据丢失。

文件存储扩容

当服务器文件存储空间不足时,需要对存储空间进行扩容,可以通过添加存储路径和添加存储节点两种方式进行扩容。

增加存储路径

添加存储路径是最简单的存储扩容方式,需要扩容的存储节点数量必须大于或等于数据冗余份数。

例如:系统当前数据冗余模式是2份数据,则需要为任意至少2个存储节点分别添加存储路径,这是因为在2份数据冗余模式下,数据需要同时写入到2个不同的存储节点中。

运维管理->系统维护-> 存储管理 中选择指定的存储节点,然后在存储节点中添加新路径即可。

删除存储路径

当删除一个存储路径时,存储节点服务需重新平衡数据,以将删除的路径中的数据恢复到其他路径中,重现实现数据的冗余。通常存储节点会每8小时自动平衡一次数据,但如果是删除存储路径,应该在删除后立即执行数据平衡。

如果文件存储路径中没有数据,可以直接在配置文件config.json中删除存储节点对应的路径,然后使配置生效,不需要平衡数据。

如果文件存储路径中有数据,则不能直接删除,否则可能丢失文件数据,为了数据安全,每次只能在一个存储节点中删除路径,然后立即平衡数据,不能同时在多个存储节点中删除路径,这样可能会因为无法平衡数据而造成数据丢失。

删除前要先确认删除后当前存储节点的剩余空间大于已删除路径中的空间,以保证删除后数据重新平衡到其他路径时有足够的写入空间,如果剩余空间不足,需要先添加一个新存储路径使剩余空间足够,然后再删除原存储路径,路径删除后需要立即重新平衡数据

系统存储扩容

修改系统存储路径

如果系统存储路径空间不足,会造成系统不能正常启动运行,可以通过修改系统存储路径,实现将数据迁移到更大空间的存储路径中。

以下操作中,我们将修改前的路径称为原路径,修改后的路径称为目标路径

具体操作是:

  1. 系统管理员登录,进入运维管理->系统维护->计划任务,执行系统备份,等待完成。
  2. 确认目标路径的剩余空间大于原路径的已使用空间,否则会造成数据转移时目标路径空间不足。
  3. 关闭服务端。Windows直接在托盘菜单中关闭,Linux执行命令: sudo /opt/ydisks/ydisk.py --stop
  4. 原路径下的所有文件复制到目标路径
  5. 参考配置文件说明(Windows / Linux ),在 service.ydisk.path.data字段中将原路径修改为目标路径,修改后需要使配置生效
  6. 服务端启动完成后,登录网盘系统,如果原有文件存在并上传下载正常则操作完成。

修改备份路径

可以通过修改配置文件config.json,直接修改备份 路径。

以下操作中,我们将修改前的路径称为原路径,修改后的路径称为目标路径

具体操作是:

  1. 系统管理员登录,进入运维管理->基础设置->系统维护->存储管理,查看存储路径的已使用空间,新的备份路径剩余空间应大于现有备份路径的已使用空间,否则可能会造成备份空间不足。
  2. 关闭服务端。Windows直接在托盘菜单中关闭,Linux执行命令: sudo /opt/ydisks/ydisk.py --stop
  3. 原路径下的所有文件复制到目标路径
  4. 参考配置文件说明(Windows / Linux ),在 service.ydisk.path.backup字段中将原路径修改为目标路径,修改后需要使配置生效
  5. 系统管理员登录,进入运维管理->基础设置->系统维护->存储管理,查看备份路径状态。

重新平衡数据

重新平衡数据,可以删除不需要的冗余数据以及让数据更均衡的分散到各个存储节点。

在开始菜单搜索“PowerShell”,点开或右键“以管理员身份运行”,打开PowerShell并执行如下命令:

$path = Join-Path $env:YDISK_SERVER_HOME 'etc\config.json'
$REPL = (Get-Content -Raw $path | ConvertFrom-Json).service.oss.build.replication
Write-Host "当前 replication: $REPL"
@"
lock
volume.list
volume.configure.replication -collectionPattern "*" -replication "$REPL"
volume.balance -force
volume.list
unlock
"@ | & "$env:YDISK_SERVER_HOME\bin\yoss\yoss2.exe" shell --master localhost:2041

调整数据冗余

为了数据存储安全,系统安装时默认2份数据冗余,对于一些特殊场景,比如存储系统已用磁盘阵列进行数据保护的情况则不必再进行数据冗余,可以使用1份数据即可。

如果需要调整数据冗余数可以通过修改系统配置文件的方式实现,参考配置文件说明(Windows / Linux ),在service.oss.build.replication字段中修改值(如下表),修改后需要使配置生效

replication值描述
0001份数据,需要至少1个存储节点。
0012份数据,需要至少2个存储节点,数据在2个节点上复制。
0023份数据,需要至少3个存储节点,数据在3个节点上复制。

配置生效后,需重新平衡数据