open-nomad/command/init.go

185 lines
4.3 KiB
Go
Raw Normal View History

2015-09-21 00:06:02 +00:00
package command
import (
"fmt"
"io/ioutil"
2015-09-21 00:06:02 +00:00
"os"
"strings"
)
const (
// DefaultInitName is the default name we use when
// initializing the example file
DefaultInitName = "example.nomad"
2015-09-21 00:06:02 +00:00
)
// InitCommand generates a new job template that you can customize to your
// liking, like vagrant init
type InitCommand struct {
Meta
}
func (c *InitCommand) Help() string {
helpText := `
Usage: nomad init
Creates an example job file that can be used as a starting
point to customize further.
`
return strings.TrimSpace(helpText)
2015-09-21 00:06:02 +00:00
}
func (c *InitCommand) Synopsis() string {
return "Create an example job file"
}
2015-09-21 00:06:02 +00:00
func (c *InitCommand) Run(args []string) int {
2015-09-30 21:21:50 +00:00
// Check for misuse
if len(args) != 0 {
c.Ui.Error(c.Help())
return 1
}
// Check if the file already exists
_, err := os.Stat(DefaultInitName)
2015-09-30 21:21:50 +00:00
if err != nil && !os.IsNotExist(err) {
c.Ui.Error(fmt.Sprintf("Failed to stat '%s': %v", DefaultInitName, err))
2015-09-21 00:06:02 +00:00
return 1
}
2015-09-30 21:21:50 +00:00
if !os.IsNotExist(err) {
c.Ui.Error(fmt.Sprintf("Job '%s' already exists", DefaultInitName))
return 1
}
2015-09-21 00:06:02 +00:00
// Write out the example
err = ioutil.WriteFile(DefaultInitName, []byte(defaultJob), 0660)
2015-09-21 00:06:02 +00:00
if err != nil {
c.Ui.Error(fmt.Sprintf("Failed to write '%s': %v", DefaultInitName, err))
2015-09-21 00:06:02 +00:00
return 1
}
// Success
c.Ui.Output(fmt.Sprintf("Example job file written to %s", DefaultInitName))
2015-09-21 00:06:02 +00:00
return 0
}
2015-09-30 21:21:50 +00:00
var defaultJob = strings.TrimSpace(`
# There can only be a single job definition per file.
# Create a job with ID and Name 'example'
job "example" {
# Run the job in the global region, which is the default.
# region = "global"
# Specify the datacenters within the region this job can run in.
datacenters = ["dc1"]
# Service type jobs optimize for long-lived services. This is
# the default but we can change to batch for short-lived tasks.
# type = "service"
# Priority controls our access to resources and scheduling priority.
# This can be 1 to 100, inclusively, and defaults to 50.
# priority = 50
# Restrict our job to only linux. We can specify multiple
# constraints as needed.
constraint {
2016-02-05 00:50:20 +00:00
attribute = "${attr.kernel.name}"
value = "linux"
}
2015-09-21 00:06:02 +00:00
# Configure the job to do rolling updates
update {
# Stagger updates every 10 seconds
stagger = "10s"
2015-09-21 00:06:02 +00:00
# Update a single task at a time
max_parallel = 1
}
# Create a 'cache' group. Each task in the group will be
# scheduled onto the same machine.
group "cache" {
# Control the number of instances of this groups.
# Defaults to 1
# count = 1
2015-12-18 20:17:13 +00:00
# Configure the restart policy for the task group. If not provided, a
# default is used based on the job type.
restart {
2015-12-18 20:17:13 +00:00
# The number of attempts to run the job within the specified interval.
attempts = 10
2015-12-18 20:17:13 +00:00
interval = "5m"
# A delay between a task failing and a restart occurring.
2015-11-03 01:30:41 +00:00
delay = "25s"
2015-12-18 20:17:13 +00:00
# Mode controls what happens when a task has restarted "attempts"
# times within the interval. "delay" mode delays the next restart
# till the next interval. "fail" mode does not restart the task if
# "attempts" has been hit within the interval.
mode = "delay"
}
# Define a task to run
task "redis" {
# Use Docker to run the task.
driver = "docker"
# Configure Docker driver with the image
config {
2015-09-23 01:10:33 +00:00
image = "redis:latest"
2015-11-12 23:59:18 +00:00
port_map {
db = 6379
}
}
2015-11-18 00:05:03 +00:00
service {
name = "${TASKGROUP}-redis"
2015-11-17 03:43:22 +00:00
tags = ["global", "cache"]
port = "db"
2015-11-18 00:05:03 +00:00
check {
2015-11-17 03:43:22 +00:00
name = "alive"
type = "tcp"
interval = "10s"
timeout = "2s"
}
}
# We must specify the resources required for
# this task to ensure it runs on a machine with
# enough capacity.
resources {
cpu = 500 # 500 Mhz
2015-09-23 01:10:33 +00:00
memory = 256 # 256MB
network {
mbits = 10
2015-11-12 23:59:18 +00:00
port "db" {
}
}
}
2016-03-16 03:28:33 +00:00
# The artifact block can be specified one or more times to download
2016-03-16 04:21:27 +00:00
# artifacts prior to the task being started. This is convenient for
# shipping configs or data needed by the task.
2016-03-16 03:28:33 +00:00
# artifact {
# source = "http://foo.com/artifact.tar.gz"
# options {
# checksum = "md5:c4aa853ad2215426eb7d70a21922e794"
# }
# }
2016-02-11 20:21:19 +00:00
# Specify configuration related to log rotation
# logs {
# max_files = 10
# max_file_size = 15
# }
2016-01-04 19:36:57 +00:00
# Controls the timeout between signalling a task it will be killed
# and killing the task. If not set a default is used.
# kill_timeout = "20s"
}
}
2015-09-21 00:06:02 +00:00
}
2015-09-30 21:21:50 +00:00
`)