容器持久化存储实战:使用Marathon本地卷创建有状态应用

Marathon是Mesos的一款核心框架,能够支持运行长服务。Marathon在版本1.0之后增加了持久化存储功能,本文教你快速上手使用Marathon本地持久化卷创建有状态应用。

注意: Marathon版本1.0的持久化存储功能为beta版,使用时可能存在潜在风险。建议使用Marathon版本1.1及以上。

我们知道,当Marathon应用终止或重新登录时会丢失状态。但在某些场景下,比如使用MySQL,应用状态必须得保存。这时候,我们就可以采用本地持久化卷来支持有状态应用。本地持久化卷之所以能支持有状态任务,是因为任务重启时数据不会丢失。

当配置本地持久化卷时,任务以及相关数据将直接pin到它们首个登陆的节点,如果终止后重新登录,会依然登陆到该节点。应用所需资源也将被保存。除了所配置的sandbox disk大小作为应用定义的一部分,Marathon还暗中保留一个合适大小的磁盘空间(通过persistent.size在卷中声明)。

使用Marathon本地持久化卷有哪些好处?

•运行有状态服务的任务时,所需全部资源将动态保存,从而确保任务能在同一节点重新登录并在必要时使用同一个卷。
•任务不必强制pin到某个agent里,即使数据都在其上。
•指定分布式逻辑关系时,依然可以采用限制条件。
•对于不再使用的持久化卷,Marathon找到它后立即销毁,释放资源。

如何使用Marathon本地持久化卷创建一个有状态应用?

1 前提

要使用Marathon本地持久化卷来创建有状态应用,需要设定2个命令行标记,从而让Marathon保存/释放资源,以及创建/销毁卷。

•–mesos_authentication_principal:你可以按需选择,但如果已经在Mesos master上设置了ACLs,那么这一条principal就是通过验证和授权的。
•–mesos_role: 这个role比较特别,会在Marathon中暗自使用,也就是说,不必通过—roles来配置Mesos master。

2 配置选项

可使用如下选项来配置一个持久化卷:

图片描述

•containerPath: 应用读写数据的路径。它必须是关于容器的单层路径,不能包含一个前置的斜杠(/)。(即:应该是”data”, 而不是”/data”, “/var/data”或”var/data”)。
•mode:卷的登陆模式。
•persistent.type:mesos磁盘资源使用类型。有效的选项是root, path, 和mount。

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值