1 # EC2 configuration for Arvados Node Manager.
2 # All times are in seconds unless specified otherwise.
5 # The dispatcher can customize the start and stop procedure for
6 # cloud nodes. For example, the SLURM dispatcher drains nodes
7 # through SLURM before shutting them down.
10 # Node Manager will ensure that there are at least this many nodes
11 # running at all times.
14 # Node Manager will not start any compute nodes when at least this
18 # Poll EC2 nodes and Arvados for new information every N seconds.
21 # Polls have exponential backoff when services fail to respond.
22 # This is the longest time to wait between polls.
25 # If Node Manager can't succesfully poll a service for this long,
26 # it will never start or stop compute nodes, on the assumption that its
27 # information is too outdated.
28 poll_stale_after = 600
30 # If Node Manager boots a cloud node, and it does not pair with an Arvados
31 # node before this long, assume that there was a cloud bootstrap failure and
32 # shut it down. Note that normal shutdown windows apply (see the Cloud
33 # section), so this should be shorter than the first shutdown window value.
34 boot_fail_after = 1800
36 # "Node stale time" affects two related behaviors.
37 # 1. If a compute node has been running for at least this long, but it
38 # isn't paired with an Arvados node, do not shut it down, but leave it alone.
39 # This prevents the node manager from shutting down a node that might
40 # actually be doing work, but is having temporary trouble contacting the
42 # 2. When the Node Manager starts a new compute node, it will try to reuse
43 # an Arvados node that hasn't been updated for this long.
44 node_stale_after = 14400
46 # File path for Certificate Authorities
47 certs_file = /etc/ssl/certs/ca-certificates.crt
51 file = /var/log/arvados/node-manager.log
53 # Log level for most Node Manager messages.
54 # Choose one of DEBUG, INFO, WARNING, ERROR, or CRITICAL.
55 # WARNING lets you know when polling a service fails.
56 # INFO additionally lets you know when a compute node is started or stopped.
59 # You can also set different log levels for specific libraries.
60 # Pykka is the Node Manager's actor library.
61 # Setting this to DEBUG will display tracebacks for uncaught
62 # exceptions in the actors, but it's also very chatty.
65 # Setting apiclient to INFO will log the URL of every Arvados API request.
69 host = zyxwv.arvadosapi.com
73 # Accept an untrusted SSL certificate from the API server?
79 # It's usually most cost-effective to shut down compute nodes during narrow
80 # windows of time. For example, EC2 bills each node by the hour, so the best
81 # time to shut down a node is right before a new hour of uptime starts.
82 # Shutdown windows define these periods of time. These are windows in
83 # full minutes, separated by commas. Counting from the time the node is
84 # booted, the node WILL NOT shut down for N1 minutes; then it MAY shut down
85 # for N2 minutes; then it WILL NOT shut down for N3 minutes; and so on.
86 # For example, "54, 5, 1" means the node may shut down from the 54th to the
87 # 59th minute of each hour of uptime.
88 # Specify at least two windows. You can add as many as you need beyond that.
89 shutdown_windows = 54, 5, 1
98 # This section defines filters that find compute nodes.
99 # Tags that you specify here will automatically be added to nodes you create.
100 # Replace colons in Amazon filters with underscores
101 # (e.g., write "tag:mytag" as "tag_mytag").
102 instance-state-name = running
103 tag_arvados-class = dynamic-compute
107 # New compute nodes will send pings to Arvados at this host.
108 # You may specify a port, and use brackets to disambiguate IPv6 addresses.
109 ping_host = hostname:port
111 # Give the name of an SSH key on AWS...
114 # ... or a file path for an SSH key that can log in to the compute node.
115 # (One or the other, not both.)
118 # The EC2 IDs of the image and subnet compute nodes should use.
122 # Comma-separated EC2 IDs for the security group(s) assigned to each
124 security_groups = idstring1, idstring2
127 # You can define any number of Size sections to list EC2 sizes you're
128 # willing to use. The Node Manager should boot the cheapest size(s) that
129 # can run jobs in the queue (N.B.: defining more than one size has not been
131 # Each size section MUST define the number of cores are available in this
132 # size class (since libcloud does not provide any consistent API for exposing
134 # You may also want to define the amount of scratch space (expressed
135 # in GB) for Crunch jobs. You can also override Amazon's provided
136 # data fields by setting the same names here.