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。