SeaweedFS学习笔记:TTL 配置数据存活时间

1. 介绍

SeaweedFS本质是key-file存储,文件可以通过TTL配置过期时间。

2. 如何使用

假设有一个文件需要保留3分钟。
首先,请求Master服务分配一个TTL为3分钟的file id。

curl http://localhost:9333/dir/assign?ttl=3m
{"count":1,"fid":"5,01637037d6","url":"127.0.0.1:8080","publicUrl":"localhost:8080"}

然后,使用这个file id将文件存储至volume服务。

curl -F "file=@x.go" http://127.0.0.1:8080/5,01637037d6?ttl=3m

文件写入后,在TTL过期前文件的内容可以被正常的读取, TTL过期后,文件的内容不能被读取。

3. TTL格式

TTL的格式是一个整型的数字后跟一个时间单位,时间单位可以是 ‘m’, ‘h’, ‘d’, ‘w’, ‘M’, ‘y’。
例如:

  • 3m: 3 分钟
  • 4h: 4 小时
  • 5d: 5 天
  • 6w: 6 周
  • 7M: 7 月
  • 8y: 8 年

4. TTL实现细节

  1. 在分配file id时,Master会选择一个与文件TTL配置一致的TTL-Volume, 如果不存在这样的Volume,则会创建一个。
  2. Volume server 保存文件,当文件的过期,则该文件不可访问。
  3. Volume server会追踪每个Volume的最大过期时间,停止向Master服务发送过期Volume的信息。
  4. Master服务会认为之前的Volume已经停止服务了,停止分配向这类Volume发送写请求。
  5. 在TTL过后的一段时间,最多不超过十分钟,Volume server会删除过期的Volume。

5. 部署建议

在生产中,TTL-Volume的最大size需要仔细考虑。
当写入非常的频繁时,TTL-Volume很快就会增长到最大size。当磁盘空间不太充裕的时候,最好减小最大size的配置。

不建议在同一个集群中混合TTL-Volume和non TTL-Volume,因为Volume的最大size在集群级别设置的。

6. 参考文档下载

《小文件存储SeaweedFS技术指南》

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论
好的,我会尽力回答你的问题。关于通过UDP传输音视频,我了解一些相关的知识,下面是一些学习笔记: 1. gstreamer是一个流媒体框架,用于创建、处理和播放多媒体流。它支持多种音视频格式,可以通过插件扩展功能。 2. 通过gstreamer可以使用UDP协议传输音视频数据。UDP协议是一种无连接的协议,不保证数据传输的可靠性和顺序性,但是传输效率高。 3. 首先需要创建一个gstreamer的pipeline,包括音视频源、编码器、UDP发送端等组件。例如: ``` gst-launch-1.0 -v filesrc location=test.mp4 ! decodebin ! x264enc ! rtph264pay ! udpsink host=192.168.1.100 port=5000 ``` 这个pipeline的作用是从test.mp4文件读取音视频流,解码后使用x264编码器进行压缩,然后使用rtph264pay将数据打包成RTP数据包,最后通过udpsink发送到指定的IP地址和端口。 4. 接收端需要创建一个gstreamer的pipeline,包括UDP接收端、解包器、解码器等组件。例如: ``` gst-launch-1.0 -v udpsrc port=5000 ! application/x-rtp, payload=96 ! rtpjitterbuffer ! rtph264depay ! avdec_h264 ! autovideosink ``` 这个pipeline的作用是从UDP端口5000接收音视频数据,使用rtpjitterbuffer解决网络抖动问题,使用rtph264depay将RTP数据包解包成原始的H.264数据流,然后使用avdec_h264解码器进行解码,最后使用autovideosink播放视频。 5. 在实际使用过程中,还需要考虑数据的带宽限制、网络延迟等问题,以保证音视频传输的效果。 希望这些笔记能对你有帮助。如果你还有其他问题,可以继续问我。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

修破立生

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值