From 0d219c515a6af5e3b966bfb009b8c01ed7a86c67 Mon Sep 17 00:00:00 2001 From: Tomas Barton Date: Thu, 12 Jul 2018 15:35:51 +0200 Subject: [PATCH 1/3] Switch to Mesos based health checks for MoM (#1667) --- repo/packages/M/marathon/201/config.json | 436 ++++++++++++++++++ .../M/marathon/201/marathon.json.mustache | 47 ++ repo/packages/M/marathon/201/package.json | 19 + repo/packages/M/marathon/201/resource.json | 14 + 4 files changed, 516 insertions(+) create mode 100644 repo/packages/M/marathon/201/config.json create mode 100644 repo/packages/M/marathon/201/marathon.json.mustache create mode 100644 repo/packages/M/marathon/201/package.json create mode 100644 repo/packages/M/marathon/201/resource.json diff --git a/repo/packages/M/marathon/201/config.json b/repo/packages/M/marathon/201/config.json new file mode 100644 index 000000000..3721fe3a9 --- /dev/null +++ b/repo/packages/M/marathon/201/config.json @@ -0,0 +1,436 @@ +{ + "additionalProperties" : false, + "description" : "Marathon DC/OS Service properties", + "properties" : { + "service" : { + "additionalProperties" : false, + "description" : "Marathon app configuration properties.", + "properties" : { + "name" : { + "description" : "The name of this Marathon service inside DC/OS base Marathon.\nIf not specified otherwise, this name will also be used for the framework name, dcos service name, zk path and mesos role.\nTo create a nested path, please specify a group.", + "type" : "string", + "default" : "marathon-user", + "pattern" : "^(([a-z0-9]|[a-z0-9][a-z0-9\\-]*[a-z0-9])\\.)*([a-z0-9]|[a-z0-9][a-z0-9\\-]*[a-z0-9])$" + }, + "group" : { + "description" : "The group of this Marathon service inside DC/OS base Marathon. If a group is defined, the id of this service will be group/name", + "type" : "string", + "pattern" : "^[/]?(([a-z0-9])([a-z0-9\\-]*[a-z0-9]))([/](([a-z0-9])([a-z0-9\\-]*[a-z0-9])))*$" + }, + "cpus" : { + "default" : 2, + "description" : "CPU shares to allocate to each Marathon instance.", + "minimum" : 0, + "type" : "number" + }, + "mem" : { + "default" : 1536, + "description" : "Memory (MB) to allocate to each Marathon instance.", + "minimum" : 512, + "type" : "number" + }, + "instances" : { + "default" : 1, + "description" : "Number of Marathon instances to run.", + "minimum" : 0, + "type" : "integer" + }, + "uris" : { + "default" : [ ], + "description" : "List of URIs that will be downloaded and made available in the current working directory of Marathon. For example this can be used to download a Java keystore file for SSL configuration.", + "items" : { + "pattern" : "^[\\s]+", + "type" : "string" + }, + "type" : "array" + } + }, + "required" : [ "cpus", "mem", "instances" ], + "type" : "object" + }, + "jvm" : { + "additionalProperties" : false, + "description" : "JVM configuration properties", + "properties" : { + "heap-min" : { + "default" : 256, + "description" : "Memory (MB) start size for the JVM heap. This number should be be less or equals than the heap-max.", + "minimum" : 0, + "type" : "integer" + }, + "heap-max" : { + "default" : 768, + "description" : "Memory (MB) max size for the JVM heap. This number should be less than the memory allocated to the Marathon instance (General rule: 50%).", + "minimum" : 0, + "type" : "integer" + }, + "opts" : { + "description" : "Allows additional JVM_OPTS to be applied outside of the standard mx and ms.", + "type" : "string" + } + }, + "required" : [ "heap-min", "heap-max" ], + "type" : "object" + }, + "marathon" : { + "additionalProperties" : true, + "description" : "Marathon command line flags. These are the same flags that are passed through to Marathon when launching manually from the command line. See details here: https://mesosphere.github.io/marathon/docs/command-line-flags.html", + "properties" : { + "access-control-allow-origin" : { + "description" : "The origin(s) to allow in Marathon. Not set by default. Example values are \"*\", or \"http://localhost:8888, http://domain.com\"", + "type" : "string" + }, + "backup-location" : { + "description" : "The location uri of the backup to create.", + "type" : "string" + }, + "checkpoint" : { + "description" : "Enabled: (Default) Enable checkpointing of tasks. Requires checkpointing enabled on slaves. Allows tasks to continue running during mesos-slave restarts and upgrades Disabled: Disable checkpointing of tasks.", + "type" : "boolean", + "default" : true + }, + "decline-offer-duration" : { + "description" : "(Default: 120 seconds) The duration (milliseconds) for which to decline offers by default", + "type" : "integer", + "default" : 120000 + }, + "default-accepted-resource-roles" : { + "description" : "Default for the defaultAcceptedResourceRoles attribute of all app definitions as a comma-separated list of strings. This defaults to all roles for which this Marathon instance is configured to receive offers.", + "type" : "string", + "default" : "*" + }, + "default-network-name" : { + "description" : "Network name, injected into applications' container-mode network{} specs that do not define their own name.", + "type" : "string" + }, + "disable-http" : { + "description" : "Disable listening for HTTP requests completely. HTTPS is unaffected.", + "type" : "boolean", + "default" : false + }, + "draining-seconds" : { + "description" : "(Default: 0 seconds) the seconds when marathon will start declining offers before a maintenance window start time. This is only evaluated if `maintenance_mode` is in the set of `enable_features`!", + "type" : "integer", + "default" : 0 + }, + "enable-features" : { + "description" : "A comma-separated list of features. Available features are: secrets - Enable support for secrets in Marathon (experimental), external_volumes - Enable external volumes support in Marathon, maintenance_mode - Enable support for maintenance mode in Marathon (experimental), vips - Enable networking VIPs UI, gpu_resources - Enable support for GPU in Marathon (experimental), task_killing - Enable the optional TASK_KILLING state, available in Mesos 0.28 and later", + "type" : "string", + "default" : "vips,task_killing" + }, + "env-vars-prefix" : { + "description" : "Prefix to use for environment variables injected automatically into all started tasks.", + "type" : "string" + }, + "event-stream-max-outstanding-messages" : { + "description" : "The event stream buffers events, that are not already consumed by clients. This number defines the number of events that get buffered on the server side, before messages are dropped.", + "type" : "integer", + "default" : 1024 + }, + "executor" : { + "description" : "Executor to use when none is specified. If not defined the Mesos command executor is used by default.", + "type" : "string", + "default" : "//cmd" + }, + "failover-timeout" : { + "description" : "(Default: 1 week) The failover_timeout for mesos in seconds.", + "type" : "integer", + "default" : 604800 + }, + "framework-name" : { + "description" : "(Default: service.name) Framework name to register with Mesos.", + "type" : "string" + }, + "ha" : { + "description" : "Enabled: (Default) Run Marathon in HA mode with leader election. Allows starting an arbitrary number of other Marathons but all need to be started in HA mode. This mode requires a running ZooKeeper Disabled: Run Marathon in single node mode.", + "type" : "boolean", + "default" : true + }, + "hostname" : { + "description" : "The advertised hostname that is used for the communication with the Mesos master. The value is also stored in the persistent store so another standby host can redirect to the elected leader.", + "type" : "string" + }, + "http-address" : { + "description" : "The address to listen on for HTTP requests", + "type" : "string" + }, + "http-compression" : { + "description" : "Enabled: (Default) Enable http compression. Disabled: Disable http compression. ", + "type" : "boolean", + "default" : true + }, + "http-credentials" : { + "description" : "Credentials for accessing the http service. If empty, anyone can access the HTTP endpoint. A username:password pair is expected where the username must not contain ':'. May also be specified with the `MESOSPHERE_HTTP_CREDENTIALS` environment variable. ", + "type" : "string" + }, + "http-max-concurrent-requests" : { + "description" : "The number of concurrent HTTP requests that are allowed before rejecting.", + "type" : "integer" + }, + "http-port" : { + "description" : "The port to listen on for HTTP requests", + "type" : "integer" + }, + "http-realm" : { + "description" : "The security realm (aka 'area') associated with the credentials", + "type" : "string", + "default" : "Mesosphere" + }, + "https-address" : { + "description" : "The address to listen on for HTTPS requests.", + "type" : "string" + }, + "https-port" : { + "description" : "The port to listen on for HTTPS requests", + "type" : "integer" + }, + "launch-token-refresh-interval" : { + "description" : "The interval (ms) in which to refresh the launch tokens to --launch_token_count", + "type" : "integer", + "default" : 30000 + }, + "launch-tokens" : { + "description" : "Launch tokens per interval", + "type" : "integer", + "default" : 100 + }, + "leader-proxy-connection-timeout" : { + "description" : "Maximum time, in milliseconds, to wait for connecting to the current Marathon leader from another Marathon instance.", + "type" : "integer", + "default" : 5000 + }, + "leader-proxy-read-timeout" : { + "description" : "Maximum time, in milliseconds, for reading from the current Marathon leader.", + "type" : "integer", + "default" : 10000 + }, + "leader-proxy-ssl-ignore-hostname" : { + "description" : "Do not verify that the hostname of the Marathon leader matches the one in the SSL certificate when proxying API requests to the current leader.", + "type" : "boolean", + "default" : false + }, + "local-port-max" : { + "description" : "Max port number to use when assigning globally unique service ports to apps.", + "type" : "integer", + "default" : 20000 + }, + "local-port-min" : { + "description" : "Min port number to use when assigning globally unique service ports to apps.", + "type" : "integer", + "default" : 10000 + }, + "logging-level" : { + "description" : "Set logging level to one of: off, error, warn, info, debug, trace, all", + "type" : "string" + }, + "logstash" : { + "description" : "Logs destination URI in format (udp|tcp|ssl)://:", + "type" : "string" + }, + "master" : { + "description" : "The URL of the Mesos master", + "type" : "string", + "default" : "zk://master.mesos:2181/mesos" + }, + "max-apps" : { + "description" : "The maximum number of applications that may be created.", + "type" : "integer" + }, + "max-instances-per-offer" : { + "description" : "Max instances per offer. Do not start more than this number of app or pod instances on a single offer.", + "type" : "integer", + "default" : 1 + }, + "mesos-authentication" : { + "description" : "Enabled: Will use framework authentication while registering with Mesos with principal and optional secret. Disabled: (Default) will not use framework authentication while registering with Mesos.", + "type" : "boolean", + "default" : false + }, + "mesos-authentication-principal" : { + "description" : "(Default: service.name) Mesos Authentication Principal.", + "type" : "string" + }, + "mesos-authentication-secret" : { + "description" : "Mesos Authentication Secret.", + "type" : "string" + }, + "mesos-authentication-secret-file" : { + "description" : "Path to a file containing the Mesos Authentication Secret.", + "type" : "string" + }, + "mesos-bridge-name" : { + "description" : "The name of the Mesos CNI network used by MESOS-type containers configured to use bridged networking", + "type" : "string", + "default" : "mesos-bridge" + }, + "mesos-leader-ui-url" : { + "description" : "The host and port (e.g. \"http://mesos_host:5050\") of the Mesos master.", + "type" : "string", + "default" : "/mesos" + }, + "mesos-role" : { + "description" : "(Default: service.name) Mesos role for this framework. If set, Marathon receives resource offers for the specified role in addition to resources with the role designation '*'.", + "type" : "string" + }, + "mesos-user" : { + "description" : "Mesos user for this framework.", + "type" : "string" + }, + "metrics" : { + "description" : "Enabled: (Deprecated) Ignored Disabled: (Deprecated) Ignored", + "type" : "boolean", + "default" : false + }, + "min-revive-offers-interval" : { + "description" : "Do not ask for all offers (also already seen ones) more often than this interval (ms).", + "type" : "integer", + "default" : 5000 + }, + "offer-matching-timeout" : { + "description" : "Offer matching timeout (ms). Stop trying to match additional tasks for this offer after this time.", + "type" : "integer", + "default" : 3000 + }, + "on-elected-prepare-timeout" : { + "description" : "The timeout for preparing the Marathon instance when elected as leader.", + "type" : "integer", + "default" : 180000 + }, + "plugin-conf" : { + "description" : "The plugin configuration file.", + "type" : "string" + }, + "plugin-dir" : { + "description" : "Path to a local directory containing plugin jars.", + "type" : "string" + }, + "reconciliation-initial-delay" : { + "description" : "This is the length of time, in milliseconds, before Marathon begins to periodically perform task reconciliation operations", + "type" : "integer", + "default" : 15000 + }, + "reconciliation-interval" : { + "description" : "This is the length of time, in milliseconds, between task reconciliation operations.", + "type" : "integer", + "default" : 600000 + }, + "reporter-datadog" : { + "description" : "URL to dogstatsd agent. e.g. udp://localhost:8125?prefix=marathon-test&tags=marathon&interval=10", + "type" : "string" + }, + "reporter-graphite" : { + "description" : "URL to graphite agent. e.g. tcp://localhost:2003?prefix=marathon-test&interval=10", + "type" : "string" + }, + "revive-offers-repetitions" : { + "description" : "Repeat every reviveOffer request this many times, delayed by the --min_revive_offers_interval.", + "type" : "integer", + "default" : 3 + }, + "scale-apps-initial-delay" : { + "description" : "This is the length of time, in milliseconds, before Marathon begins to periodically attempt to scale apps.", + "type" : "integer", + "default" : 15000 + }, + "scale-apps-interval" : { + "description" : "This is the length of time, in milliseconds, between task scale apps.", + "type" : "integer", + "default" : 300000 + }, + "sentry" : { + "description" : "URI for sentry, e.g. https://:@sentryserver/", + "type" : "string" + }, + "sentry-tags" : { + "description" : "Tags to post to sentry with, e.g: tag1:value1,tag2:value2", + "type" : "string" + }, + "ssl-keystore-password" : { + "description" : "Password for the keystore supplied with the `ssl_keystore_path` option. Required if `ssl_keystore_path` is supplied. May also be specified with the `MESOSPHERE_KEYSTORE_PASS` environment variable.", + "type" : "string" + }, + "ssl-keystore-path" : { + "description" : "Path to the SSL keystore. HTTPS (SSL) will be enabled if this option is supplied. Requires `--ssl_keystore_password`. May also be specified with the `MESOSPHERE_KEYSTORE_PATH` environment variable.", + "type" : "string" + }, + "store-cache" : { + "description" : "Enabled: (Default) Enable an in-memory cache for the storage layer. Disabled: Disable the in-memory cache for the storage layer. ", + "type" : "boolean", + "default" : true + }, + "task-launch-confirm-timeout" : { + "description" : "Time, in milliseconds, to wait for a task to enter the TASK_STAGING state before killing it.", + "type" : "integer", + "default" : 300000 + }, + "task-launch-timeout" : { + "description" : "Time, in milliseconds, to wait for a task to enter the TASK_RUNNING state before killing it.", + "type" : "integer", + "default" : 300000 + }, + "task-lost-expunge-initial-delay" : { + "description" : "This is the length of time, in milliseconds, before Marathon begins to periodically perform task expunge gc operations", + "type" : "integer", + "default" : 300000 + }, + "task-lost-expunge-interval" : { + "description" : "This is the length of time in milliseconds, for lost task gc operations.", + "type" : "integer", + "default" : 30000 + }, + "task-reservation-timeout" : { + "description" : "Time, in milliseconds, to wait for a new reservation to be acknowledged via a received offer before deleting it.", + "type" : "integer", + "default" : 20000 + }, + "webui-url" : { + "description" : "The HTTP(S) url of the web ui, defaulting to the advertised hostname.", + "type" : "string" + }, + "zk" : { + "description" : "ZooKeeper URL for storing state. Format: zk://host1:port1,host2:port2,.../path", + "type" : "string" + }, + "zk-compression" : { + "description" : "Enabled: (Default) Enable compression of zk nodes, if the size of the node is bigger than the configured threshold. Disabled: Disable compression of zk nodes", + "type" : "boolean", + "default" : true + }, + "zk-compression-threshold" : { + "description" : "(Default: 64 KB) Threshold in bytes, when compression is applied to the ZooKeeper node.", + "type" : "integer", + "default" : 65536 + }, + "zk-connection-timeout" : { + "description" : "The timeout to connect to ZooKeeper in milliseconds", + "type" : "integer", + "default" : 10000 + }, + "zk-max-node-size" : { + "description" : "(Default: 1 MiB) Maximum allowed ZooKeeper node size (in bytes).", + "type" : "integer", + "default" : 1024000 + }, + "zk-max-versions" : { + "description" : "Limit the number of versions, stored for one entity.", + "type" : "integer", + "default" : 50 + }, + "zk-session-timeout" : { + "description" : "The timeout for ZooKeeper sessions in milliseconds", + "type" : "integer", + "default" : 10000 + }, + "zk-timeout" : { + "description" : "The timeout for ZooKeeper operations in milliseconds.", + "type" : "integer", + "default" : 10000 + } + }, + "required" : [ "master" ], + "type" : "object" + } + }, + "required" : [ "service", "jvm", "marathon" ], + "type" : "object" +} \ No newline at end of file diff --git a/repo/packages/M/marathon/201/marathon.json.mustache b/repo/packages/M/marathon/201/marathon.json.mustache new file mode 100644 index 000000000..80e7d5cdd --- /dev/null +++ b/repo/packages/M/marathon/201/marathon.json.mustache @@ -0,0 +1,47 @@ + +{ + "id": "{{#service.group}}{{service.group}}/{{/service.group}}{{service.name}}", + "cpus": {{service.cpus}}, + "mem": {{service.mem}}, + "instances": {{service.instances}}, + "constraints": [["hostname", "UNIQUE"]], + "ports": [ + {{#marathon.http-port}}{{marathon.http-port}}{{/marathon.http-port}}{{^marathon.http-port}}0{{/marathon.http-port}} + , 0 + {{#marathon.ssl-keystore-path}} + {{#marathon.ssl-keystore-password}} + , {{#marathon.https-port}}{{marathon.https-port}}{{/marathon.https-port}}{{^marathon.https-port}}0{{/marathon.https-port}} + {{/marathon.ssl-keystore-password}} + {{/marathon.ssl-keystore-path}} + ], + "uris": {{service.uris}}, + "healthChecks": [ + { + "gracePeriodSeconds": 1800, + "intervalSeconds": 10, + "maxConsecutiveFailures": 3, + "path": "/ping", + "portIndex": 0, + "protocol": "MESOS_HTTP", + "timeoutSeconds": 5 + } + ], + "container": { + "type": "DOCKER", + "docker": { + "image": "{{resource.assets.container.docker.image}}", + "network": "HOST" + } + }, + "env": { + "JVM_OPTS": "-Xms{{jvm.heap-min}}m -Xmx{{jvm.heap-max}}m {{#jvm.opts}}{{jvm.opts}}{{/jvm.opts}}" + }, + "cmd": "LIBPROCESS_PORT=$PORT1 && ./bin/start {{#marathon.access-control-allow-origin}}--access_control_allow_origin \"{{marathon.access-control-allow-origin}}\"{{/marathon.access-control-allow-origin}} {{#marathon.backup-location}}--backup_location \"{{marathon.backup-location}}\"{{/marathon.backup-location}} {{#marathon.checkpoint}} --checkpoint{{/marathon.checkpoint}}{{^marathon.checkpoint}}--disable_checkpoint{{/marathon.checkpoint}} {{#marathon.decline-offer-duration}}--decline_offer_duration \"{{marathon.decline-offer-duration}}\"{{/marathon.decline-offer-duration}} {{#marathon.default-accepted-resource-roles}}--default_accepted_resource_roles \"{{marathon.default-accepted-resource-roles}}\"{{/marathon.default-accepted-resource-roles}} {{#marathon.default-network-name}}--default_network_name \"{{marathon.default-network-name}}\"{{/marathon.default-network-name}} {{#marathon.disable-http}}--disable_http{{/marathon.disable-http}} {{#marathon.draining-seconds}}--draining_seconds \"{{marathon.draining-seconds}}\"{{/marathon.draining-seconds}} {{#marathon.enable-features}}--enable_features \"{{marathon.enable-features}}\"{{/marathon.enable-features}} {{#marathon.env-vars-prefix}}--env_vars_prefix \"{{marathon.env-vars-prefix}}\"{{/marathon.env-vars-prefix}} {{#marathon.event-stream-max-outstanding-messages}}--event_stream_max_outstanding_messages \"{{marathon.event-stream-max-outstanding-messages}}\"{{/marathon.event-stream-max-outstanding-messages}} {{#marathon.executor}}--executor \"{{marathon.executor}}\"{{/marathon.executor}} {{#marathon.failover-timeout}}--failover_timeout \"{{marathon.failover-timeout}}\"{{/marathon.failover-timeout}} --framework_name {{#marathon.framework-name}}{{marathon.framework-name}}{{/marathon.framework-name}}{{^marathon.framework-name}}{{service.name}}{{/marathon.framework-name}} {{#marathon.ha}} --ha{{/marathon.ha}}{{^marathon.ha}}--disable_ha{{/marathon.ha}} --hostname {{#marathon.hostname}}{{marathon.hostname}}{{/marathon.hostname}}{{^marathon.hostname}}$LIBPROCESS_IP{{/marathon.hostname}} {{#marathon.http-address}}--http_address \"{{marathon.http-address}}\"{{/marathon.http-address}} {{#marathon.http-compression}} --http_compression{{/marathon.http-compression}}{{^marathon.http-compression}}--disable_http_compression{{/marathon.http-compression}} {{#marathon.http-credentials}}--http_credentials \"{{marathon.http-credentials}}\"{{/marathon.http-credentials}} {{#marathon.http-max-concurrent-requests}}--http_max_concurrent_requests \"{{marathon.http-max-concurrent-requests}}\"{{/marathon.http-max-concurrent-requests}} --http_port {{#marathon.http-port}}{{marathon.http-port}}{{/marathon.http-port}}{{^marathon.http-port}} $PORT0 {{/marathon.http-port}} {{#marathon.http-realm}}--http_realm \"{{marathon.http-realm}}\"{{/marathon.http-realm}} {{#marathon.https-address}}--https_address \"{{marathon.https-address}}\"{{/marathon.https-address}} {{#marathon.ssl-keystore-path}}--https_port {{#marathon.https-port}}{{marathon.https-port}}{{/marathon.https-port}}{{^marathon.https-port}} $PORT2 {{/marathon.https-port}}{{/marathon.ssl-keystore-path}} {{#marathon.launch-token-refresh-interval}}--launch_token_refresh_interval \"{{marathon.launch-token-refresh-interval}}\"{{/marathon.launch-token-refresh-interval}} {{#marathon.launch-tokens}}--launch_tokens \"{{marathon.launch-tokens}}\"{{/marathon.launch-tokens}} {{#marathon.leader-proxy-connection-timeout}}--leader_proxy_connection_timeout \"{{marathon.leader-proxy-connection-timeout}}\"{{/marathon.leader-proxy-connection-timeout}} {{#marathon.leader-proxy-read-timeout}}--leader_proxy_read_timeout \"{{marathon.leader-proxy-read-timeout}}\"{{/marathon.leader-proxy-read-timeout}} {{#marathon.leader-proxy-ssl-ignore-hostname}}--leader_proxy_ssl_ignore_hostname \"{{marathon.leader-proxy-ssl-ignore-hostname}}\"{{/marathon.leader-proxy-ssl-ignore-hostname}} {{#marathon.local-port-max}}--local_port_max \"{{marathon.local-port-max}}\"{{/marathon.local-port-max}} {{#marathon.local-port-min}}--local_port_min \"{{marathon.local-port-min}}\"{{/marathon.local-port-min}} {{#marathon.logging-level}}--logging_level \"{{marathon.logging-level}}\"{{/marathon.logging-level}} {{#marathon.logstash}}--logstash \"{{marathon.logstash}}\"{{/marathon.logstash}} {{#marathon.master}}--master \"{{marathon.master}}\"{{/marathon.master}} {{#marathon.max-apps}}--max_apps \"{{marathon.max-apps}}\"{{/marathon.max-apps}} {{#marathon.max-instances-per-offer}}--max_instances_per_offer \"{{marathon.max-instances-per-offer}}\"{{/marathon.max-instances-per-offer}} {{#marathon.mesos-authentication}} --mesos_authentication{{/marathon.mesos-authentication}}{{^marathon.mesos-authentication}}--disable_mesos_authentication{{/marathon.mesos-authentication}} --mesos_authentication_principal {{#marathon.mesos-authentication-principal}}{{marathon.mesos-authentication-principal}}{{/marathon.mesos-authentication-principal}}{{^marathon.mesos-authentication-principal}}{{service.name}}{{/marathon.mesos-authentication-principal}} {{#marathon.mesos-authentication-secret}}--mesos_authentication_secret \"{{marathon.mesos-authentication-secret}}\"{{/marathon.mesos-authentication-secret}} {{#marathon.mesos-authentication-secret-file}}--mesos_authentication_secret_file \"{{marathon.mesos-authentication-secret-file}}\"{{/marathon.mesos-authentication-secret-file}} {{#marathon.mesos-bridge-name}}--mesos_bridge_name \"{{marathon.mesos-bridge-name}}\"{{/marathon.mesos-bridge-name}} {{#marathon.mesos-leader-ui-url}}--mesos_leader_ui_url \"{{marathon.mesos-leader-ui-url}}\"{{/marathon.mesos-leader-ui-url}} --mesos_role {{#marathon.mesos-role}}{{marathon.mesos-role}}{{/marathon.mesos-role}}{{^marathon.mesos-role}}{{service.name}}{{/marathon.mesos-role}} {{#marathon.mesos-user}}--mesos_user \"{{marathon.mesos-user}}\"{{/marathon.mesos-user}} {{#marathon.metrics}} --metrics{{/marathon.metrics}}{{^marathon.metrics}}--disable_metrics{{/marathon.metrics}} {{#marathon.min-revive-offers-interval}}--min_revive_offers_interval \"{{marathon.min-revive-offers-interval}}\"{{/marathon.min-revive-offers-interval}} {{#marathon.offer-matching-timeout}}--offer_matching_timeout \"{{marathon.offer-matching-timeout}}\"{{/marathon.offer-matching-timeout}} {{#marathon.on-elected-prepare-timeout}}--on_elected_prepare_timeout \"{{marathon.on-elected-prepare-timeout}}\"{{/marathon.on-elected-prepare-timeout}} {{#marathon.plugin-conf}}--plugin_conf \"{{marathon.plugin-conf}}\"{{/marathon.plugin-conf}} {{#marathon.plugin-dir}}--plugin_dir \"{{marathon.plugin-dir}}\"{{/marathon.plugin-dir}} {{#marathon.reconciliation-initial-delay}}--reconciliation_initial_delay \"{{marathon.reconciliation-initial-delay}}\"{{/marathon.reconciliation-initial-delay}} {{#marathon.reconciliation-interval}}--reconciliation_interval \"{{marathon.reconciliation-interval}}\"{{/marathon.reconciliation-interval}} {{#marathon.reporter-datadog}}--reporter_datadog \"{{marathon.reporter-datadog}}\"{{/marathon.reporter-datadog}} {{#marathon.reporter-graphite}}--reporter_graphite \"{{marathon.reporter-graphite}}\"{{/marathon.reporter-graphite}} {{#marathon.revive-offers-repetitions}}--revive_offers_repetitions \"{{marathon.revive-offers-repetitions}}\"{{/marathon.revive-offers-repetitions}} {{#marathon.scale-apps-initial-delay}}--scale_apps_initial_delay \"{{marathon.scale-apps-initial-delay}}\"{{/marathon.scale-apps-initial-delay}} {{#marathon.scale-apps-interval}}--scale_apps_interval \"{{marathon.scale-apps-interval}}\"{{/marathon.scale-apps-interval}} {{#marathon.sentry}}--sentry \"{{marathon.sentry}}\"{{/marathon.sentry}} {{#marathon.sentry-tags}}--sentry_tags \"{{marathon.sentry-tags}}\"{{/marathon.sentry-tags}} {{#marathon.ssl-keystore-password}}--ssl_keystore_password \"{{marathon.ssl-keystore-password}}\"{{/marathon.ssl-keystore-password}} {{#marathon.ssl-keystore-path}}--ssl_keystore_path \"{{marathon.ssl-keystore-path}}\"{{/marathon.ssl-keystore-path}} {{#marathon.store-cache}} --store_cache{{/marathon.store-cache}}{{^marathon.store-cache}}--disable_store_cache{{/marathon.store-cache}} {{#marathon.task-launch-confirm-timeout}}--task_launch_confirm_timeout \"{{marathon.task-launch-confirm-timeout}}\"{{/marathon.task-launch-confirm-timeout}} {{#marathon.task-launch-timeout}}--task_launch_timeout \"{{marathon.task-launch-timeout}}\"{{/marathon.task-launch-timeout}} {{#marathon.task-lost-expunge-initial-delay}}--task_lost_expunge_initial_delay \"{{marathon.task-lost-expunge-initial-delay}}\"{{/marathon.task-lost-expunge-initial-delay}} {{#marathon.task-lost-expunge-interval}}--task_lost_expunge_interval \"{{marathon.task-lost-expunge-interval}}\"{{/marathon.task-lost-expunge-interval}} {{#marathon.task-reservation-timeout}}--task_reservation_timeout \"{{marathon.task-reservation-timeout}}\"{{/marathon.task-reservation-timeout}} {{#marathon.webui-url}}--webui_url \"{{marathon.webui-url}}\"{{/marathon.webui-url}} --zk {{#marathon.zk}}{{marathon.zk}}{{/marathon.zk}}{{^marathon.zk}}zk://master.mesos:2181/universe/{{service.name}}{{/marathon.zk}} {{#marathon.zk-compression}} --zk_compression{{/marathon.zk-compression}}{{^marathon.zk-compression}}--disable_zk_compression{{/marathon.zk-compression}} {{#marathon.zk-compression-threshold}}--zk_compression_threshold \"{{marathon.zk-compression-threshold}}\"{{/marathon.zk-compression-threshold}} {{#marathon.zk-connection-timeout}}--zk_connection_timeout \"{{marathon.zk-connection-timeout}}\"{{/marathon.zk-connection-timeout}} {{#marathon.zk-max-node-size}}--zk_max_node_size \"{{marathon.zk-max-node-size}}\"{{/marathon.zk-max-node-size}} {{#marathon.zk-max-versions}}--zk_max_versions \"{{marathon.zk-max-versions}}\"{{/marathon.zk-max-versions}} {{#marathon.zk-session-timeout}}--zk_session_timeout \"{{marathon.zk-session-timeout}}\"{{/marathon.zk-session-timeout}} {{#marathon.zk-timeout}}--zk_timeout \"{{marathon.zk-timeout}}\"{{/marathon.zk-timeout}}", + "labels": { + "DCOS_PACKAGE_FRAMEWORK_NAME": "{{#marathon.framework-name}}{{marathon.framework-name}}{{/marathon.framework-name}}{{^marathon.framework-name}}{{service.name}}{{/marathon.framework-name}}", + "DCOS_SERVICE_NAME": "{{service.name}}", + "DCOS_SERVICE_SCHEME": "http", + "DCOS_SERVICE_PORT_INDEX": "0" + } +} + diff --git a/repo/packages/M/marathon/201/package.json b/repo/packages/M/marathon/201/package.json new file mode 100644 index 000000000..c917082a5 --- /dev/null +++ b/repo/packages/M/marathon/201/package.json @@ -0,0 +1,19 @@ +{ + "packagingVersion" : "3.0", + "name" : "marathon", + "version" : "1.6.490", + "minDcosReleaseVersion" : "1.11", + "scm" : "https://github.com/mesosphere/marathon.git", + "maintainer" : "support@mesosphere.io", + "description" : "A container orchestration platform for Mesos and DCOS.", + "framework" : true, + "licenses" : [ { + "name" : "Apache License Version 2.0", + "url" : "https://github.com/mesosphere/marathon/blob/master/LICENSE" + } ], + "tags" : [ "init", "long-running" ], + "preInstallNotes" : "We recommend a minimum of one node with at least 2 CPU shares and 1GB of RAM available for the Marathon DCOS Service.", + "postInstallNotes" : "Marathon DCOS Service has been successfully installed!\n\n\tDocumentation: https://mesosphere.github.io/marathon\n\tIssues: https://github.com/mesosphere/marathon/issues\n", + "postUninstallNotes" : "The Marathon DCOS Service has been uninstalled and will no longer run.\nPlease follow the instructions at http://docs.mesosphere.com/services/marathon/#uninstall to clean up any persisted state", + "selected" : true +} diff --git a/repo/packages/M/marathon/201/resource.json b/repo/packages/M/marathon/201/resource.json new file mode 100644 index 000000000..a47c22d38 --- /dev/null +++ b/repo/packages/M/marathon/201/resource.json @@ -0,0 +1,14 @@ +{ + "images": { + "icon-small": "https://downloads.mesosphere.com/assets/universe/000/marathon-icon-small.png", + "icon-medium": "https://downloads.mesosphere.com/assets/universe/000/marathon-icon-medium.png", + "icon-large": "https://downloads.mesosphere.com/assets/universe/000/marathon-icon-large.png" + }, + "assets": { + "container": { + "docker": { + "image": "mesosphere/marathon:v1.6.490" + } + } + } +} From 84ff35dfd452f849c1ef10b80beab8902d0377be Mon Sep 17 00:00:00 2001 From: Tomas Barton Date: Thu, 12 Jul 2018 15:54:01 +0200 Subject: [PATCH 2/3] Add VIP support for MoM, replace ports by portDefinitions --- .../M/marathon/201/marathon.json.mustache | 32 +++++++++++++------ 1 file changed, 23 insertions(+), 9 deletions(-) diff --git a/repo/packages/M/marathon/201/marathon.json.mustache b/repo/packages/M/marathon/201/marathon.json.mustache index 80e7d5cdd..08b5406a8 100644 --- a/repo/packages/M/marathon/201/marathon.json.mustache +++ b/repo/packages/M/marathon/201/marathon.json.mustache @@ -5,15 +5,6 @@ "mem": {{service.mem}}, "instances": {{service.instances}}, "constraints": [["hostname", "UNIQUE"]], - "ports": [ - {{#marathon.http-port}}{{marathon.http-port}}{{/marathon.http-port}}{{^marathon.http-port}}0{{/marathon.http-port}} - , 0 - {{#marathon.ssl-keystore-path}} - {{#marathon.ssl-keystore-password}} - , {{#marathon.https-port}}{{marathon.https-port}}{{/marathon.https-port}}{{^marathon.https-port}}0{{/marathon.https-port}} - {{/marathon.ssl-keystore-password}} - {{/marathon.ssl-keystore-path}} - ], "uris": {{service.uris}}, "healthChecks": [ { @@ -33,6 +24,29 @@ "network": "HOST" } }, + "portDefinitions": [ + { + "port": {{#marathon.http-port}}{{marathon.http-port}}{{/marathon.http-port}}{{^marathon.http-port}}0{{/marathon.http-port}}, + "protocol": "tcp", + "name": "{{service.name}}", + "labels": { "VIP_0": "/{{service.name}}:80" } + }, + { + "port": 0, + "protocol": "tcp", + "name": "libprocess" + } + {{#marathon.ssl-keystore-path}} + {{#marathon.ssl-keystore-password}} + ,{ + "port": {{#marathon.https-port}}{{marathon.https-port}}{{/marathon.https-port}}{{^marathon.https-port}}0{{/marathon.https-port}}, + "protocol": "tcp", + "name": "{{service.name}}-https", + "labels": { "VIP_1": "/{{service.name}}:443" } + } + {{/marathon.ssl-keystore-password}} + {{/marathon.ssl-keystore-path}} + ], "env": { "JVM_OPTS": "-Xms{{jvm.heap-min}}m -Xmx{{jvm.heap-max}}m {{#jvm.opts}}{{jvm.opts}}{{/jvm.opts}}" }, From 43930fc7a338c868fb40842b850bacae903a5164 Mon Sep 17 00:00:00 2001 From: Tomas Barton Date: Fri, 13 Jul 2018 08:58:15 +0200 Subject: [PATCH 3/3] Support virtual networks --- repo/packages/M/marathon/201/config.json | 17 ++++++++++++++++- .../M/marathon/201/marathon.json.mustache | 5 +++++ 2 files changed, 21 insertions(+), 1 deletion(-) diff --git a/repo/packages/M/marathon/201/config.json b/repo/packages/M/marathon/201/config.json index 3721fe3a9..ff8f10d19 100644 --- a/repo/packages/M/marathon/201/config.json +++ b/repo/packages/M/marathon/201/config.json @@ -43,6 +43,21 @@ "type" : "string" }, "type" : "array" + }, + "virtual_network_enabled": { + "description": "Enable virtual networking", + "type": "boolean", + "default": false + }, + "virtual_network_name": { + "description": "The name of the virtual network to join", + "type": "string", + "default": "dcos" + }, + "virtual_network_plugin_labels": { + "description": "Labels to pass to the virtual network plugin. Comma-separated key:value pairs. For example: k_0:v_0,k_1:v_1,...,k_n:v_n", + "type": "string", + "default": "" } }, "required" : [ "cpus", "mem", "instances" ], @@ -433,4 +448,4 @@ }, "required" : [ "service", "jvm", "marathon" ], "type" : "object" -} \ No newline at end of file +} diff --git a/repo/packages/M/marathon/201/marathon.json.mustache b/repo/packages/M/marathon/201/marathon.json.mustache index 08b5406a8..5f14f69b3 100644 --- a/repo/packages/M/marathon/201/marathon.json.mustache +++ b/repo/packages/M/marathon/201/marathon.json.mustache @@ -48,6 +48,11 @@ {{/marathon.ssl-keystore-path}} ], "env": { + {{#service.virtual_network_enabled}} + "ENABLE_VIRTUAL_NETWORK": "yes", + "VIRTUAL_NETWORK_NAME": "{{service.virtual_network_name}}", + "VIRTUAL_NETWORK_PLUGIN_LABELS": "{{service.virtual_network_plugin_labels}}", + {{/service.virtual_network_enabled}} "JVM_OPTS": "-Xms{{jvm.heap-min}}m -Xmx{{jvm.heap-max}}m {{#jvm.opts}}{{jvm.opts}}{{/jvm.opts}}" }, "cmd": "LIBPROCESS_PORT=$PORT1 && ./bin/start {{#marathon.access-control-allow-origin}}--access_control_allow_origin \"{{marathon.access-control-allow-origin}}\"{{/marathon.access-control-allow-origin}} {{#marathon.backup-location}}--backup_location \"{{marathon.backup-location}}\"{{/marathon.backup-location}} {{#marathon.checkpoint}} --checkpoint{{/marathon.checkpoint}}{{^marathon.checkpoint}}--disable_checkpoint{{/marathon.checkpoint}} {{#marathon.decline-offer-duration}}--decline_offer_duration \"{{marathon.decline-offer-duration}}\"{{/marathon.decline-offer-duration}} {{#marathon.default-accepted-resource-roles}}--default_accepted_resource_roles \"{{marathon.default-accepted-resource-roles}}\"{{/marathon.default-accepted-resource-roles}} {{#marathon.default-network-name}}--default_network_name \"{{marathon.default-network-name}}\"{{/marathon.default-network-name}} {{#marathon.disable-http}}--disable_http{{/marathon.disable-http}} {{#marathon.draining-seconds}}--draining_seconds \"{{marathon.draining-seconds}}\"{{/marathon.draining-seconds}} {{#marathon.enable-features}}--enable_features \"{{marathon.enable-features}}\"{{/marathon.enable-features}} {{#marathon.env-vars-prefix}}--env_vars_prefix \"{{marathon.env-vars-prefix}}\"{{/marathon.env-vars-prefix}} {{#marathon.event-stream-max-outstanding-messages}}--event_stream_max_outstanding_messages \"{{marathon.event-stream-max-outstanding-messages}}\"{{/marathon.event-stream-max-outstanding-messages}} {{#marathon.executor}}--executor \"{{marathon.executor}}\"{{/marathon.executor}} {{#marathon.failover-timeout}}--failover_timeout \"{{marathon.failover-timeout}}\"{{/marathon.failover-timeout}} --framework_name {{#marathon.framework-name}}{{marathon.framework-name}}{{/marathon.framework-name}}{{^marathon.framework-name}}{{service.name}}{{/marathon.framework-name}} {{#marathon.ha}} --ha{{/marathon.ha}}{{^marathon.ha}}--disable_ha{{/marathon.ha}} --hostname {{#marathon.hostname}}{{marathon.hostname}}{{/marathon.hostname}}{{^marathon.hostname}}$LIBPROCESS_IP{{/marathon.hostname}} {{#marathon.http-address}}--http_address \"{{marathon.http-address}}\"{{/marathon.http-address}} {{#marathon.http-compression}} --http_compression{{/marathon.http-compression}}{{^marathon.http-compression}}--disable_http_compression{{/marathon.http-compression}} {{#marathon.http-credentials}}--http_credentials \"{{marathon.http-credentials}}\"{{/marathon.http-credentials}} {{#marathon.http-max-concurrent-requests}}--http_max_concurrent_requests \"{{marathon.http-max-concurrent-requests}}\"{{/marathon.http-max-concurrent-requests}} --http_port {{#marathon.http-port}}{{marathon.http-port}}{{/marathon.http-port}}{{^marathon.http-port}} $PORT0 {{/marathon.http-port}} {{#marathon.http-realm}}--http_realm \"{{marathon.http-realm}}\"{{/marathon.http-realm}} {{#marathon.https-address}}--https_address \"{{marathon.https-address}}\"{{/marathon.https-address}} {{#marathon.ssl-keystore-path}}--https_port {{#marathon.https-port}}{{marathon.https-port}}{{/marathon.https-port}}{{^marathon.https-port}} $PORT2 {{/marathon.https-port}}{{/marathon.ssl-keystore-path}} {{#marathon.launch-token-refresh-interval}}--launch_token_refresh_interval \"{{marathon.launch-token-refresh-interval}}\"{{/marathon.launch-token-refresh-interval}} {{#marathon.launch-tokens}}--launch_tokens \"{{marathon.launch-tokens}}\"{{/marathon.launch-tokens}} {{#marathon.leader-proxy-connection-timeout}}--leader_proxy_connection_timeout \"{{marathon.leader-proxy-connection-timeout}}\"{{/marathon.leader-proxy-connection-timeout}} {{#marathon.leader-proxy-read-timeout}}--leader_proxy_read_timeout \"{{marathon.leader-proxy-read-timeout}}\"{{/marathon.leader-proxy-read-timeout}} {{#marathon.leader-proxy-ssl-ignore-hostname}}--leader_proxy_ssl_ignore_hostname \"{{marathon.leader-proxy-ssl-ignore-hostname}}\"{{/marathon.leader-proxy-ssl-ignore-hostname}} {{#marathon.local-port-max}}--local_port_max \"{{marathon.local-port-max}}\"{{/marathon.local-port-max}} {{#marathon.local-port-min}}--local_port_min \"{{marathon.local-port-min}}\"{{/marathon.local-port-min}} {{#marathon.logging-level}}--logging_level \"{{marathon.logging-level}}\"{{/marathon.logging-level}} {{#marathon.logstash}}--logstash \"{{marathon.logstash}}\"{{/marathon.logstash}} {{#marathon.master}}--master \"{{marathon.master}}\"{{/marathon.master}} {{#marathon.max-apps}}--max_apps \"{{marathon.max-apps}}\"{{/marathon.max-apps}} {{#marathon.max-instances-per-offer}}--max_instances_per_offer \"{{marathon.max-instances-per-offer}}\"{{/marathon.max-instances-per-offer}} {{#marathon.mesos-authentication}} --mesos_authentication{{/marathon.mesos-authentication}}{{^marathon.mesos-authentication}}--disable_mesos_authentication{{/marathon.mesos-authentication}} --mesos_authentication_principal {{#marathon.mesos-authentication-principal}}{{marathon.mesos-authentication-principal}}{{/marathon.mesos-authentication-principal}}{{^marathon.mesos-authentication-principal}}{{service.name}}{{/marathon.mesos-authentication-principal}} {{#marathon.mesos-authentication-secret}}--mesos_authentication_secret \"{{marathon.mesos-authentication-secret}}\"{{/marathon.mesos-authentication-secret}} {{#marathon.mesos-authentication-secret-file}}--mesos_authentication_secret_file \"{{marathon.mesos-authentication-secret-file}}\"{{/marathon.mesos-authentication-secret-file}} {{#marathon.mesos-bridge-name}}--mesos_bridge_name \"{{marathon.mesos-bridge-name}}\"{{/marathon.mesos-bridge-name}} {{#marathon.mesos-leader-ui-url}}--mesos_leader_ui_url \"{{marathon.mesos-leader-ui-url}}\"{{/marathon.mesos-leader-ui-url}} --mesos_role {{#marathon.mesos-role}}{{marathon.mesos-role}}{{/marathon.mesos-role}}{{^marathon.mesos-role}}{{service.name}}{{/marathon.mesos-role}} {{#marathon.mesos-user}}--mesos_user \"{{marathon.mesos-user}}\"{{/marathon.mesos-user}} {{#marathon.metrics}} --metrics{{/marathon.metrics}}{{^marathon.metrics}}--disable_metrics{{/marathon.metrics}} {{#marathon.min-revive-offers-interval}}--min_revive_offers_interval \"{{marathon.min-revive-offers-interval}}\"{{/marathon.min-revive-offers-interval}} {{#marathon.offer-matching-timeout}}--offer_matching_timeout \"{{marathon.offer-matching-timeout}}\"{{/marathon.offer-matching-timeout}} {{#marathon.on-elected-prepare-timeout}}--on_elected_prepare_timeout \"{{marathon.on-elected-prepare-timeout}}\"{{/marathon.on-elected-prepare-timeout}} {{#marathon.plugin-conf}}--plugin_conf \"{{marathon.plugin-conf}}\"{{/marathon.plugin-conf}} {{#marathon.plugin-dir}}--plugin_dir \"{{marathon.plugin-dir}}\"{{/marathon.plugin-dir}} {{#marathon.reconciliation-initial-delay}}--reconciliation_initial_delay \"{{marathon.reconciliation-initial-delay}}\"{{/marathon.reconciliation-initial-delay}} {{#marathon.reconciliation-interval}}--reconciliation_interval \"{{marathon.reconciliation-interval}}\"{{/marathon.reconciliation-interval}} {{#marathon.reporter-datadog}}--reporter_datadog \"{{marathon.reporter-datadog}}\"{{/marathon.reporter-datadog}} {{#marathon.reporter-graphite}}--reporter_graphite \"{{marathon.reporter-graphite}}\"{{/marathon.reporter-graphite}} {{#marathon.revive-offers-repetitions}}--revive_offers_repetitions \"{{marathon.revive-offers-repetitions}}\"{{/marathon.revive-offers-repetitions}} {{#marathon.scale-apps-initial-delay}}--scale_apps_initial_delay \"{{marathon.scale-apps-initial-delay}}\"{{/marathon.scale-apps-initial-delay}} {{#marathon.scale-apps-interval}}--scale_apps_interval \"{{marathon.scale-apps-interval}}\"{{/marathon.scale-apps-interval}} {{#marathon.sentry}}--sentry \"{{marathon.sentry}}\"{{/marathon.sentry}} {{#marathon.sentry-tags}}--sentry_tags \"{{marathon.sentry-tags}}\"{{/marathon.sentry-tags}} {{#marathon.ssl-keystore-password}}--ssl_keystore_password \"{{marathon.ssl-keystore-password}}\"{{/marathon.ssl-keystore-password}} {{#marathon.ssl-keystore-path}}--ssl_keystore_path \"{{marathon.ssl-keystore-path}}\"{{/marathon.ssl-keystore-path}} {{#marathon.store-cache}} --store_cache{{/marathon.store-cache}}{{^marathon.store-cache}}--disable_store_cache{{/marathon.store-cache}} {{#marathon.task-launch-confirm-timeout}}--task_launch_confirm_timeout \"{{marathon.task-launch-confirm-timeout}}\"{{/marathon.task-launch-confirm-timeout}} {{#marathon.task-launch-timeout}}--task_launch_timeout \"{{marathon.task-launch-timeout}}\"{{/marathon.task-launch-timeout}} {{#marathon.task-lost-expunge-initial-delay}}--task_lost_expunge_initial_delay \"{{marathon.task-lost-expunge-initial-delay}}\"{{/marathon.task-lost-expunge-initial-delay}} {{#marathon.task-lost-expunge-interval}}--task_lost_expunge_interval \"{{marathon.task-lost-expunge-interval}}\"{{/marathon.task-lost-expunge-interval}} {{#marathon.task-reservation-timeout}}--task_reservation_timeout \"{{marathon.task-reservation-timeout}}\"{{/marathon.task-reservation-timeout}} {{#marathon.webui-url}}--webui_url \"{{marathon.webui-url}}\"{{/marathon.webui-url}} --zk {{#marathon.zk}}{{marathon.zk}}{{/marathon.zk}}{{^marathon.zk}}zk://master.mesos:2181/universe/{{service.name}}{{/marathon.zk}} {{#marathon.zk-compression}} --zk_compression{{/marathon.zk-compression}}{{^marathon.zk-compression}}--disable_zk_compression{{/marathon.zk-compression}} {{#marathon.zk-compression-threshold}}--zk_compression_threshold \"{{marathon.zk-compression-threshold}}\"{{/marathon.zk-compression-threshold}} {{#marathon.zk-connection-timeout}}--zk_connection_timeout \"{{marathon.zk-connection-timeout}}\"{{/marathon.zk-connection-timeout}} {{#marathon.zk-max-node-size}}--zk_max_node_size \"{{marathon.zk-max-node-size}}\"{{/marathon.zk-max-node-size}} {{#marathon.zk-max-versions}}--zk_max_versions \"{{marathon.zk-max-versions}}\"{{/marathon.zk-max-versions}} {{#marathon.zk-session-timeout}}--zk_session_timeout \"{{marathon.zk-session-timeout}}\"{{/marathon.zk-session-timeout}} {{#marathon.zk-timeout}}--zk_timeout \"{{marathon.zk-timeout}}\"{{/marathon.zk-timeout}}",